gr533x_ll_i2c.h
Go to the documentation of this file.
1 /**
2  ****************************************************************************************
3  *
4  * @file gr533x_ll_i2c.h
5  * @author BLE Driver Team
6  * @brief Header file containing functions prototypes of I2C LL library.
7  *
8  ****************************************************************************************
9  * @attention
10  #####Copyright (c) 2019 GOODIX
11  All rights reserved.
12 
13  Redistribution and use in source and binary forms, with or without
14  modification, are permitted provided that the following conditions are met:
15  * Redistributions of source code must retain the above copyright
16  notice, this list of conditions and the following disclaimer.
17  * Redistributions in binary form must reproduce the above copyright
18  notice, this list of conditions and the following disclaimer in the
19  documentation and/or other materials provided with the distribution.
20  * Neither the name of GOODIX nor the names of its contributors may be used
21  to endorse or promote products derived from this software without
22  specific prior written permission.
23 
24  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27  ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE
28  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  POSSIBILITY OF SUCH DAMAGE.
35  ****************************************************************************************
36  */
37 
38 /** @addtogroup PERIPHERAL Peripheral Driver
39  * @{
40  */
41 
42 /** @addtogroup LL_DRIVER LL Driver
43  * @{
44  */
45 
46 /** @defgroup LL_I2C I2C
47  * @brief I2C LL module driver.
48  * @{
49  */
50 
51 /* Define to prevent recursive inclusion -------------------------------------*/
52 #ifndef __GR533x_LL_I2C_H__
53 #define __GR533x_LL_I2C_H__
54 
55 #ifdef __cplusplus
56 extern "C" {
57 #endif
58 
59 /* Includes ------------------------------------------------------------------*/
60 #include "gr533x.h"
61 
62 #if defined (I2C0) || defined (I2C1)
63 
64 /** @defgroup I2C_LL_STRUCTURES Structures
65  * @{
66  */
67 
68 /* Exported types ------------------------------------------------------------*/
69 /** @defgroup I2C_LL_ES_INIT I2C Exported init structure
70  * @{
71  */
72 
73 /**
74  * @brief LL I2C init Structure definition
75  */
76 typedef struct _ll_i2c_init
77 {
78  uint32_t speed; /**< Specifies the transfer speed. See @ref I2C_LL_EC_SPEED. */
79 
80  uint32_t own_address; /**< Specifies the device own address.
81  This parameter must be a value between Min_Data = 0x00 and Max_Data = 0x3FF
82 
83  This feature can be modified afterwards using unitary function @ref ll_i2c_set_own_address(). */
84 
85  uint32_t own_addr_size; /**< Specifies the device own address 1 size (7-bit or 10-bit).
86  This parameter can be a value of @ref I2C_LL_EC_OWNADDRESS
87 
88  This feature can be modified afterwards using unitary function @ref ll_i2c_set_own_address(). */
90 
91 /** @} */
92 
93 /** @} */
94 
95 /**
96  * @defgroup I2C_LL_MACRO Defines
97  * @{
98  */
99 
100 /* Exported constants --------------------------------------------------------*/
101 /** @defgroup I2C_LL_Exported_Constants I2C Exported Constants
102  * @{
103  */
104 
105 /** @defgroup I2C_LL_EC_GET_FLAG Get Flags Defines
106  * @brief Flags definitions which can be used with LL_I2C_ReadReg function
107  * @{
108  */
109 #define LL_I2C_INTR_STAT_SCL_STUCK_AT_LOW I2C_RAW_INT_STAT_SCL_STUCKLOW /**< SCL_STUCK_AT_LOW interrupt flag */
110 #define LL_I2C_INTR_STAT_MST_ON_HOLD I2C_RAW_INT_STAT_M_HOLD /**< MST_ON_HOLD interrupt flag */
111 #define LL_I2C_INTR_STAT_RESTART_DET I2C_RAW_INT_STAT_RESTART_DET /**< RESTART_DET interrupt flag */
112 #define LL_I2C_INTR_STAT_GEN_CALL I2C_RAW_INT_STAT_GEN_CALL /**< GEN_CALL interrupt flag */
113 #define LL_I2C_INTR_STAT_START_DET I2C_RAW_INT_STAT_START_DET /**< START_DET interrupt flag */
114 #define LL_I2C_INTR_STAT_STOP_DET I2C_RAW_INT_STAT_STOP_DET /**< STOP_DET interrupt flag */
115 #define LL_I2C_INTR_STAT_ACTIVITY I2C_RAW_INT_STAT_ACTIVITY /**< ACTIVITY interrupt flag */
116 #define LL_I2C_INTR_STAT_RX_DONE I2C_RAW_INT_STAT_RX_DONE /**< RX_DONE interrupt flag */
117 #define LL_I2C_INTR_STAT_TX_ABRT I2C_RAW_INT_STAT_TX_ABORT /**< TX_ABRT interrupt flag */
118 #define LL_I2C_INTR_STAT_RD_REQ I2C_RAW_INT_STAT_RD_REQ /**< RD_REQ interrupt flag */
119 #define LL_I2C_INTR_STAT_TX_EMPTY I2C_RAW_INT_STAT_TX_EMPTY /**< TX_EMPTY interrupt flag */
120 #define LL_I2C_INTR_STAT_TX_OVER I2C_RAW_INT_STAT_TX_OVER /**< TX_OVER interrupt flag */
121 #define LL_I2C_INTR_STAT_RX_FULL I2C_RAW_INT_STAT_RX_FULL /**< RX_FULL interrupt flag */
122 #define LL_I2C_INTR_STAT_RX_OVER I2C_RAW_INT_STAT_RX_OVER /**< RX_OVER interrupt flag */
123 #define LL_I2C_INTR_STAT_RX_UNDER I2C_RAW_INT_STAT_RX_UNDER /**< RX_UNDER interrupt flag */
124 
125 #define LL_I2C_ABRT_TX_FLUSH_CNT I2C_TX_ABORT_SRC_TX_FLUSH_CNT /**< Indcates the number of TX FOFO data command */
126 #define LL_I2C_ABRT_SDA_STUCK_AT_LOW I2C_TX_ABORT_SRC_ABORT_SDA_STUCK /**< The SDA stuck at low detected by master */
127 #define LL_I2C_ABRT_USER_ABRT I2C_TX_ABORT_SRC_ABORT_USER_ABORT /**< Transfer abort detected by master */
128 #define LL_I2C_ABRT_SLVRD_INTX I2C_TX_ABORT_SRC_ABORT_SLVRD_INTX /**< Slave trying to transmit to remote master in read mode */
129 #define LL_I2C_ABRT_SLV_ARBLOST I2C_TX_ABORT_SRC_ABORT_S_ARBLOST /**< Slave lost arbitration to remote master */
130 #define LL_I2C_ABRT_SLVFLUSH_TXFIFO I2C_TX_ABORT_SRC_ABORT_SLVFLUSH_TXFIFO /**< Slave flushes existing data in TX-FIFO upon getting read command */
131 #define LL_I2C_ABRT_ARB_LOST I2C_TX_ABORT_SRC_ABORT_LOST /**< Master or Slave Transmitter lost arbitration */
132 #define LL_I2C_ABRT_MST_DIS I2C_TX_ABORT_SRC_ABORT_MASTER_DIS /**< User intitating master operation when MASTER disabled */
133 #define LL_I2C_ABRT_10B_RD_NORSTRT I2C_TX_ABORT_SRC_ABORT_10B_RD_NORSTR /**< Master trying to read in 10-Bit addressing mode when RESTART disabled */
134 #define LL_I2C_ABRT_SBYTE_NORSTRT I2C_TX_ABORT_SRC_ABORT_SBYTE_NORSTRT /**< User trying to send START byte when RESTART disabled */
135 #define LL_I2C_ABRT_HS_NORSTRT I2C_TX_ABORT_SRC_ABORT_HS_NORSTRT /**< User trying to swidth Master to HS mode when RESTART disabled */
136 #define LL_I2C_ABRT_SBYTE_ACKDET I2C_TX_ABORT_SRC_ABORT_SBYTE_ACKDET /**< ACK detected for START byte */
137 #define LL_I2C_ABRT_HS_ACKDET I2C_TX_ABORT_SRC_ABORT_HS_ACKDET /**< HS Master code is ACKed in HS Mode */
138 #define LL_I2C_ABRT_GCALL_READ I2C_TX_ABORT_SRC_ABORT_GCALL_RD /**< GCALL is followed by read from bus */
139 #define LL_I2C_ABRT_GCALL_NOACK I2C_TX_ABORT_SRC_ABORT_GCALL_NOACK /**< GCALL is not ACKed by any slave */
140 #define LL_I2C_ABRT_TXDATA_NOACK I2C_TX_ABORT_SRC_ABORT_TX_NOACK /**< Transmitted data is not ACKed by addressed slave */
141 #define LL_I2C_ABRT_10ADDR2_NOACK I2C_TX_ABORT_SRC_ABORT_10B2_NOACK /**< Byte 2 of 10-Bit Address is not ACKed by any slave */
142 #define LL_I2C_ABRT_10ADDR1_NOACK I2C_TX_ABORT_SRC_ABORT_10B1_NOACK /**< Byte 1 of 10-Bit Address is not ACKed by any slave */
143 #define LL_I2C_ABRT_7B_ADDR_NOACK I2C_TX_ABORT_SRC_ABORT_7B_NOACK /**< 7Bit Address is not ACKed by any slave */
144 /** @} */
145 
146 /** @defgroup I2C_LL_EC_IT IT Defines
147  * @brief Interrupt definitions which can be used with LL_I2C_ReadReg and LL_I2C_WriteReg functions
148  * @{
149  */
150 #define LL_I2C_INTR_MASK_SCL_STUCK_AT_LOW I2C_INT_MASK_MASK_SCL_STUCKLOW /**< SCL_STUCK_AT_LOW interrupt flag */
151 #define LL_I2C_INTR_MASK_MST_ON_HOLD I2C_INT_MASK_MASK_M_HOLD /**< MST_ON_HOLD interrupt */
152 #define LL_I2C_INTR_MASK_RESTART_DET I2C_INT_MASK_MASK_RESTART_DET /**< RESTART_DET interrupt */
153 #define LL_I2C_INTR_MASK_GEN_CALL I2C_INT_MASK_MASK_GEN_CALL /**< GEN_CALL interrupt */
154 #define LL_I2C_INTR_MASK_START_DET I2C_INT_MASK_MASK_START_DET /**< START_DET interrupt */
155 #define LL_I2C_INTR_MASK_STOP_DET I2C_INT_MASK_MASK_STOP_DET /**< STOP_DET interrupt */
156 #define LL_I2C_INTR_MASK_ACTIVITY I2C_INT_MASK_MASK_ACTIVITY /**< ACTIVITY interrupt */
157 #define LL_I2C_INTR_MASK_RX_DONE I2C_INT_MASK_MASK_RX_DONE /**< RX_DONE interrupt */
158 #define LL_I2C_INTR_MASK_TX_ABRT I2C_INT_MASK_MASK_TX_ABORT /**< TX_ABRT interrupt */
159 #define LL_I2C_INTR_MASK_RD_REQ I2C_INT_MASK_MASK_RD_REQ /**< RD_REQ interrupt */
160 #define LL_I2C_INTR_MASK_TX_EMPTY I2C_INT_MASK_MASK_TX_EMPTY /**< TX_EMPTY interrupt */
161 #define LL_I2C_INTR_MASK_TX_OVER I2C_INT_MASK_MASK_TX_OVER /**< TX_OVER interrupt */
162 #define LL_I2C_INTR_MASK_RX_FULL I2C_INT_MASK_MASK_RX_FULL /**< RX_FULL interrupt */
163 #define LL_I2C_INTR_MASK_RX_OVER I2C_INT_MASK_MASK_RX_OVER /**< RX_OVER interrupt */
164 #define LL_I2C_INTR_MASK_RX_UNDER I2C_INT_MASK_MASK_RX_UNDER /**< RX_UNDER interrupt */
165 
166 #define LL_I2C_INTR_MASK_ALL 0x00007FFFU /**< All interrupt */
167 /** @} */
168 
169 /** @defgroup I2C_LL_EC_ADDRESSING_MODE Master Addressing Mode
170  * @{
171  */
172 #define LL_I2C_ADDRESSING_MODE_7BIT 0x00000000U /**< Master operates in 7-bit addressing mode. */
173 #define LL_I2C_ADDRESSING_MODE_10BIT I2C_CTRL_ADDR_BIT_M /**< Master operates in 10-bit addressing mode.*/
174 /** @} */
175 
176 /** @defgroup I2C_LL_EC_OWNADDRESS Own Address Length
177  * @{
178  */
179 #define LL_I2C_OWNADDRESS_7BIT 0x00000000U /**< Own address 1 is a 7-bit address. */
180 #define LL_I2C_OWNADDRESS_10BIT I2C_CTRL_ADDR_BIT_S /**< Own address 1 is a 10-bit address.*/
181 /** @} */
182 
183 
184 /** @defgroup I2C_LL_EC_GENERATE Start And Stop Generation
185  * @{
186  */
187 #define LL_I2C_CMD_SLV_NONE 0x00000000U /**< Slave No command. */
188 #define LL_I2C_CMD_MST_WRITE 0x00000000U /**< Master write command. */
189 #define LL_I2C_CMD_MST_READ I2C_DATA_CMD_CMD /**< Master read command. */
190 #define LL_I2C_CMD_MST_GEN_STOP I2C_DATA_CMD_STOP /**< Master issue STOP after this command. */
191 #define LL_I2C_CMD_MST_GEN_RESTART I2C_DATA_CMD_RESTART /**< Master issue RESTART before this command. */
192 /** @} */
193 
194 /** @defgroup I2C_LL_EC_SPEED_MODE Transfer Speed Mode
195  * @{
196  */
197 #define LL_I2C_SPEED_MODE_STANDARD (0x1U << I2C_CTRL_SPEED_POS) /**< Standard Speed mode(0 to 100 Kb/s) of operation. */
198 #define LL_I2C_SPEED_MODE_FAST (0x2U << I2C_CTRL_SPEED_POS) /**< Fast (400 Kb/s) or Fast Plus mode (1000 Kb/s) of operation. */
199 #define LL_I2C_SPEED_MODE_HIGH (0x3U << I2C_CTRL_SPEED_POS) /**< High Speed mode (3.4 Mb/s) of operation. */
200 /** @} */
201 
202 /** @defgroup I2C_LL_EC_SPEED Transfer Speed
203  * @{
204  */
205 #define LL_I2C_SPEED_100K (100000ul) /**< Standard Speed. */
206 #define LL_I2C_SPEED_400K (400000ul) /**< Fast Speed. */
207 #define LL_I2C_SPEED_1000K (1000000ul) /**< Fast Plus Speed. */
208 #define LL_I2C_SPEED_2000K (2000000ul) /**< High Speed. */
209 /** @} */
210 
211 /** @defgroup I2C_LL_EC_TX_FIFO_TH TX FIFO Threshold
212  * @{
213  */
214 #define LL_I2C_TX_FIFO_TH_EMPTY 0x00000000U /**< TX FIFO empty */
215 #define LL_I2C_TX_FIFO_TH_CHAR_1 0x00000001U /**< 1 character in TX FIFO */
216 #define LL_I2C_TX_FIFO_TH_CHAR_2 0x00000002U /**< 2 characters in TX FIFO */
217 #define LL_I2C_TX_FIFO_TH_CHAR_3 0x00000003U /**< 3 characters in TX FIFO */
218 #define LL_I2C_TX_FIFO_TH_CHAR_4 0x00000004U /**< 4 characters in TX FIFO */
219 #define LL_I2C_TX_FIFO_TH_CHAR_5 0x00000005U /**< 5 characters in TX FIFO */
220 #define LL_I2C_TX_FIFO_TH_CHAR_6 0x00000006U /**< 6 characters in TX FIFO */
221 #define LL_I2C_TX_FIFO_TH_CHAR_7 0x00000007U /**< 7 characters in TX FIFO */
222 #define LL_I2C_TX_FIFO_TH_CHAR_8 0x00000008U /**< 9 character in TX FIFO */
223 #define LL_I2C_TX_FIFO_TH_CHAR_9 0x00000009U /**< 9 characters in TX FIFO */
224 #define LL_I2C_TX_FIFO_TH_CHAR_10 0x0000000AU /**< 10 characters in TX FIFO */
225 #define LL_I2C_TX_FIFO_TH_CHAR_11 0x0000000BU /**< 11 characters in TX FIFO */
226 #define LL_I2C_TX_FIFO_TH_CHAR_12 0x0000000CU /**< 12 characters in TX FIFO */
227 #define LL_I2C_TX_FIFO_TH_CHAR_13 0x0000000DU /**< 13 characters in TX FIFO */
228 #define LL_I2C_TX_FIFO_TH_CHAR_14 0x0000000EU /**< 14 characters in TX FIFO */
229 #define LL_I2C_TX_FIFO_TH_CHAR_15 0x0000000FU /**< 15 character in TX FIFO */
230 #define LL_I2C_TX_FIFO_TH_CHAR_16 0x00000010U /**< 16 characters in TX FIFO */
231 #define LL_I2C_TX_FIFO_TH_CHAR_17 0x00000011U /**< 17 characters in TX FIFO */
232 #define LL_I2C_TX_FIFO_TH_CHAR_18 0x00000012U /**< 18 characters in TX FIFO */
233 #define LL_I2C_TX_FIFO_TH_CHAR_19 0x00000013U /**< 19 characters in TX FIFO */
234 #define LL_I2C_TX_FIFO_TH_CHAR_20 0x00000014U /**< 20 characters in TX FIFO */
235 #define LL_I2C_TX_FIFO_TH_CHAR_21 0x00000015U /**< 21 characters in TX FIFO */
236 #define LL_I2C_TX_FIFO_TH_CHAR_22 0x00000016U /**< 22 character in TX FIFO */
237 #define LL_I2C_TX_FIFO_TH_CHAR_23 0x00000017U /**< 23 characters in TX FIFO */
238 #define LL_I2C_TX_FIFO_TH_CHAR_24 0x00000018U /**< 24 characters in TX FIFO */
239 #define LL_I2C_TX_FIFO_TH_CHAR_25 0x00000019U /**< 25 characters in TX FIFO */
240 #define LL_I2C_TX_FIFO_TH_CHAR_26 0x0000001AU /**< 26 characters in TX FIFO */
241 #define LL_I2C_TX_FIFO_TH_CHAR_27 0x0000001BU /**< 27 characters in TX FIFO */
242 #define LL_I2C_TX_FIFO_TH_CHAR_28 0x0000001CU /**< 28 characters in TX FIFO */
243 #define LL_I2C_TX_FIFO_TH_CHAR_29 0x0000001DU /**< 29 characters in TX FIFO */
244 #define LL_I2C_TX_FIFO_TH_CHAR_30 0x0000001EU /**< 30 characters in TX FIFO */
245 #define LL_I2C_TX_FIFO_TH_CHAR_31 0x0000001FU /**< 31 characters in TX FIFO */
246 #define LL_I2C_TX_FIFO_TH_CHAR_32 0x00000020U /**< 32 characters in TX FIFO */
247 
248 /** @} */
249 
250 /** @defgroup I2C_LL_EC_RX_FIFO_TH RX FIFO Threshold
251  * @{
252  */
253 #define LL_I2C_RX_FIFO_TH_CHAR_1 0x00000000U /**< 1 character in RX FIFO */
254 #define LL_I2C_RX_FIFO_TH_CHAR_2 0x00000001U /**< 2 characters in RX FIFO */
255 #define LL_I2C_RX_FIFO_TH_CHAR_3 0x00000002U /**< 3 characters in RX FIFO */
256 #define LL_I2C_RX_FIFO_TH_CHAR_4 0x00000003U /**< 4 characters in RX FIFO */
257 #define LL_I2C_RX_FIFO_TH_CHAR_5 0x00000004U /**< 5 characters in RX FIFO */
258 #define LL_I2C_RX_FIFO_TH_CHAR_6 0x00000005U /**< 6 characters in RX FIFO */
259 #define LL_I2C_RX_FIFO_TH_CHAR_7 0x00000006U /**< 7 characters in RX FIFO */
260 #define LL_I2C_RX_FIFO_TH_CHAR_8 0x00000007U /**< 8 character in RX FIFO */
261 #define LL_I2C_RX_FIFO_TH_CHAR_9 0x00000008U /**< 9 characters in RX FIFO */
262 #define LL_I2C_RX_FIFO_TH_CHAR_10 0x00000009U /**< 10 characters in RX FIFO */
263 #define LL_I2C_RX_FIFO_TH_CHAR_11 0x0000000AU /**< 11 characters in RX FIFO */
264 #define LL_I2C_RX_FIFO_TH_CHAR_12 0x0000000BU /**< 12 characters in RX FIFO */
265 #define LL_I2C_RX_FIFO_TH_CHAR_13 0x0000000CU /**< 13 characters in RX FIFO */
266 #define LL_I2C_RX_FIFO_TH_CHAR_14 0x0000000DU /**< 14 characters in RX FIFO */
267 #define LL_I2C_RX_FIFO_TH_CHAR_15 0x0000000EU /**< 15 character in RX FIFO */
268 #define LL_I2C_RX_FIFO_TH_CHAR_16 0x0000000FU /**< 16 characters in RX FIFO */
269 #define LL_I2C_RX_FIFO_TH_CHAR_17 0x00000010U /**< 17 characters in RX FIFO */
270 #define LL_I2C_RX_FIFO_TH_CHAR_18 0x00000011U /**< 18 characters in RX FIFO */
271 #define LL_I2C_RX_FIFO_TH_CHAR_19 0x00000012U /**< 19 characters in RX FIFO */
272 #define LL_I2C_RX_FIFO_TH_CHAR_20 0x00000013U /**< 20 characters in RX FIFO */
273 #define LL_I2C_RX_FIFO_TH_CHAR_21 0x00000014U /**< 21 characters in RX FIFO */
274 #define LL_I2C_RX_FIFO_TH_CHAR_22 0x00000015U /**< 22 character in RX FIFO */
275 #define LL_I2C_RX_FIFO_TH_CHAR_23 0x00000016U /**< 23 characters in RX FIFO */
276 #define LL_I2C_RX_FIFO_TH_CHAR_24 0x00000017U /**< 24 characters in RX FIFO */
277 #define LL_I2C_RX_FIFO_TH_CHAR_25 0x00000018U /**< 25 characters in RX FIFO */
278 #define LL_I2C_RX_FIFO_TH_CHAR_26 0x00000019U /**< 26 characters in RX FIFO */
279 #define LL_I2C_RX_FIFO_TH_CHAR_27 0x0000001AU /**< 27 characters in RX FIFO */
280 #define LL_I2C_RX_FIFO_TH_CHAR_28 0x0000001BU /**< 28 characters in RX FIFO */
281 #define LL_I2C_RX_FIFO_TH_CHAR_29 0x0000001CU /**< 29 character in RX FIFO */
282 #define LL_I2C_RX_FIFO_TH_CHAR_30 0x0000001DU /**< 30 characters in RX FIFO */
283 #define LL_I2C_RX_FIFO_TH_CHAR_31 0x0000001EU /**< 31 characters in RX FIFO */
284 #define LL_I2C_RX_FIFO_TH_CHAR_32 0x0000001FU /**< 32 characters in RX FIFO */
285 #define LL_I2C_RX_FIFO_TH_FULL 0x00000020U /**< RX FIFO full */
286 /** @} */
287 
288 /** @defgroup I2C_LL_EC_DEFAULT_CONFIG InitStrcut default configuartion
289  * @{
290  */
291 
292 /**
293  * @brief LL I2C InitStrcut default configuartion
294  */
295 #define LL_I2C_DEFAULT_CONFIG \
296 { \
297  .speed = LL_I2C_SPEED_400K, \
298  .own_address = 0x55U, \
299  .own_addr_size = LL_I2C_OWNADDRESS_7BIT, \
300 }
301 /** @} */
302 
303 /** @} */
304 
305 /* Exported macro ------------------------------------------------------------*/
306 /** @defgroup I2C_LL_Exported_Macros I2C Exported Macros
307  * @{
308  */
309 
310 /** @defgroup I2C_LL_EM_WRITE_READ Common Write and read registers Macros
311  * @{
312  */
313 
314 /**
315  * @brief Write a value in I2C register
316  * @param __instance__ I2C instance
317  * @param __REG__ Register to be written
318  * @param __VALUE__ Value to be written in the register
319  * @retval None.
320  */
321 #define LL_I2C_WriteReg(__instance__, __REG__, __VALUE__) WRITE_REG(__instance__->__REG__, (__VALUE__))
322 
323 /**
324  * @brief Read a value in I2C register
325  * @param __instance__ I2C instance
326  * @param __REG__ Register to be read
327  * @retval Register value
328  */
329 #define LL_I2C_ReadReg(__instance__, __REG__) READ_REG(__instance__->__REG__)
330 /** @} */
331 
332 /** @defgroup I2C_LL_EM_Exported_Macros_Helper Exported_Macros_Helper
333  * @{
334  */
335 
336 /**
337  * @brief Compute CLK_SSL_CNT value according to Peripheral Clock and expected Speed.
338  * @param __PERIPHCLK__ Peripheral Clock frequency used for I2C instance
339  * @param __SPEED__ Speed value to achieve
340  * @retval CLK_SSL_CNT value to be used for XS_SCL_HCNT, XS_SCL_LCNT registers where X can be (S, F, H)
341  */
342 #define __LL_I2C_CONVERT_CLK_SSL_CNT(__PERIPHCLK__, __SPEED__) ((__PERIPHCLK__) / 2 / (__SPEED__))
343 
344 /**
345  * @brief Get Speed Mode according to expected Speed.
346  * @param __SPEED__ Speed value to achieve
347  * @retval Returned value can be one of the following values:
348  * @arg @ref LL_I2C_SPEED_MODE_STANDARD
349  * @arg @ref LL_I2C_SPEED_MODE_FAST
350  * @arg @ref LL_I2C_SPEED_MODE_HIGH
351  */
352 #define __LL_I2C_CONVERT_SPEED_MODE(__SPEED__) ((__SPEED__ <= LL_I2C_SPEED_100K) ? LL_I2C_SPEED_MODE_STANDARD : \
353  ((__SPEED__ <= LL_I2C_SPEED_1000K) ? LL_I2C_SPEED_MODE_FAST : LL_I2C_SPEED_MODE_HIGH))
354 /** @} */
355 
356 /** @} */
357 
358 /** @} */
359 
360 /* Private types -------------------------------------------------------------*/
361 /* Private variables ---------------------------------------------------------*/
362 /* Private constants ---------------------------------------------------------*/
363 /* Private macros ------------------------------------------------------------*/
364 
365 /* Exported functions --------------------------------------------------------*/
366 /** @defgroup I2C_LL_DRIVER_FUNCTIONS Functions
367  * @{
368  */
369 
370 /** @defgroup I2C_LL_EF_Configuration Configuration
371  * @{
372  */
373 
374 /**
375  * @brief Enable I2C peripheral (ENABLE = 1).
376  *
377  * Register|BitsName
378  * ---------------|---------------
379  * EN | ACTIVITY
380  *
381  * @param I2Cx I2C instance.
382  * @retval None.
383  */
384 __STATIC_INLINE void ll_i2c_enable(i2c_regs_t *I2Cx)
385 {
386  SET_BITS(I2Cx->EN, I2C_EN_ACTIVITY);
387 }
388 
389 /**
390  * @brief Disable I2C peripheral (ENABLE = 0).
391  * @note When ENABLE = 0, the TX FIFO and RX FIFO get flushed.
392  * Status bits in the IC_INTR_STAT register are still active until DW_apb_i2c goes into IDLE state.
393  * If the module is transmitting, it stops as well as deletes the contents of the transmit buffer
394  * after the current transfer is complete. If the module is receiving, the DW_apb_i2c stops
395  * the current transfer at the end of the current byte and does not acknowledge the transfer..
396  *
397  * Register|BitsName
398  * ---------------|---------------
399  * EN | ACTIVITY
400  *
401  * @param I2Cx I2C instance.
402  * @retval None.
403  */
404 __STATIC_INLINE void ll_i2c_disable(i2c_regs_t *I2Cx)
405 {
406  CLEAR_BITS(I2Cx->EN, I2C_EN_ACTIVITY);
407 }
408 
409 /**
410  * @brief Check if the I2C peripheral is enabled or disabled.
411  *
412  * Register|BitsName
413  * ---------------|---------------
414  * STAT | STAT_EN
415  *
416  * @param I2Cx I2C instance.
417  * @retval State of bit (1 or 0).
418  */
419 __STATIC_INLINE uint32_t ll_i2c_is_enabled(i2c_regs_t *I2Cx)
420 {
421  return (READ_BITS(I2Cx->STAT, I2C_EN_STAT_EN) == (I2C_EN_STAT_EN));
422 }
423 
424 /**
425  * @brief Enable I2C master mode.
426  *
427  * Register|BitsName
428  * ---------------|---------------
429  * CTRL | MASTER_ENABLE
430  * CTRL | SLAVE_DISABLE
431  * @param I2Cx I2C instance.
432  * @retval None.
433  */
434 __STATIC_INLINE void ll_i2c_enable_master_mode(i2c_regs_t *I2Cx)
435 {
436  SET_BITS(I2Cx->CTRL, I2C_CTRL_M_MODE | I2C_CTRL_S_DIS);
437 }
438 
439 /**
440  * @brief Disable I2C master mode and enable slave mode.
441  *
442  * Register|BitsName
443  * ---------------|---------------
444  * CTRL | MASTER_ENABLE
445  * CTRL | SLAVE_DISABLE
446  * @param I2Cx I2C instance.
447  * @retval None.
448  */
449 __STATIC_INLINE void ll_i2c_disable_master_mode(i2c_regs_t *I2Cx)
450 {
451  CLEAR_BITS(I2Cx->CTRL, I2C_CTRL_M_MODE | I2C_CTRL_S_DIS);
452 }
453 
454 /**
455  * @brief Check if I2C master mode is enabled or disabled.
456  *
457  * Register|BitsName
458  * ---------------|---------------
459  * CTRL | MASTER_ENABLE
460  * CTRL | SLAVE_DISABLE
461  *
462  * @param I2Cx I2C instance.
463  * @retval State of bit (1 or 0).
464  */
465 __STATIC_INLINE uint32_t ll_i2c_is_enabled_master_mode(i2c_regs_t *I2Cx)
466 {
467  return (READ_BITS(I2Cx->CTRL, I2C_CTRL_M_MODE | I2C_CTRL_S_DIS) == (I2C_CTRL_M_MODE | I2C_CTRL_S_DIS));
468 }
469 
470 /**
471  * @brief Enable General Call(slave mode).
472  * @note When enabled, the Address 0x00 is ACKed.
473  *
474  * Register|BitsName
475  * ---------------|---------------
476  * ACK_GEN_CALL | ACK_GEN_CALL
477  *
478  * @param I2Cx I2C instance.
479  * @retval None.
480  */
481 __STATIC_INLINE void ll_i2c_enable_general_call(i2c_regs_t *I2Cx)
482 {
483  SET_BITS(I2Cx->ACK_GEN_CALL, I2C_ACK_GEN_CALL_ACK_GEN_CALL);
484 }
485 
486 /**
487  * @brief Disable General Call(slave mode).
488  * @note When disabled, the Address 0x00 is NACKed.
489  *
490  * Register|BitsName
491  * ---------------|---------------
492  * ACK_GEN_CALL | ACK_GEN_CALL
493  *
494  * @param I2Cx I2C instance.
495  * @retval None.
496  */
497 __STATIC_INLINE void ll_i2c_disable_general_call(i2c_regs_t *I2Cx)
498 {
499  CLEAR_BITS(I2Cx->ACK_GEN_CALL, I2C_ACK_GEN_CALL_ACK_GEN_CALL);
500 }
501 
502 /**
503  * @brief Check if General Call is enabled or disabled(slave mode).
504  *
505  * Register|BitsName
506  * ---------------|---------------
507  * ACK_GEN_CALL | ACK_GEN_CALL
508  *
509  * @param I2Cx I2C instance.
510  * @retval State of bit (1 or 0).
511  */
512 __STATIC_INLINE uint32_t ll_i2c_is_enabled_general_call(i2c_regs_t *I2Cx)
513 {
514  return (READ_BITS(I2Cx->ACK_GEN_CALL, I2C_ACK_GEN_CALL_ACK_GEN_CALL) == (I2C_ACK_GEN_CALL_ACK_GEN_CALL));
515 }
516 
517 /**
518  * @brief Enable Master Restart.
519  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
520  * This bit determines whether RESTART conditions may be sent when acting as a master.
521  * Some older slaves do not support handling RESTART conditions.
522  * When RESTART is disabled, the master is prohibited from performing the following functions:
523  * - Performing any high-speed mode operation.
524  * - Performing direction changes in combined format mode.
525  * - Performing a read operation with a 10-bit address.
526  *
527  * Register|BitsName
528  * ---------------|---------------
529  * CTRL | RESTART_EN
530  *
531  * @param I2Cx I2C instance.
532  * @retval None.
533  */
534 __STATIC_INLINE void ll_i2c_enable_master_restart(i2c_regs_t *I2Cx)
535 {
536  SET_BITS(I2Cx->CTRL, I2C_CTRL_RESTART_EN);
537 }
538 
539 /**
540  * @brief Disable Master Restart.
541  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
542  *
543  * Register|BitsName
544  * ---------------|---------------
545  * CTRL | RESTART_EN
546  *
547  * @param I2Cx I2C instance.
548  * @retval None.
549  */
550 __STATIC_INLINE void ll_i2c_disable_master_restart(i2c_regs_t *I2Cx)
551 {
552  CLEAR_BITS(I2Cx->CTRL, I2C_CTRL_RESTART_EN);
553 }
554 
555 /**
556  * @brief Check if Master Restart is enabled or disabled.
557  *
558  * Register|BitsName
559  * ---------------|---------------
560  * CTRL | RESTART_EN
561  *
562  * @param I2Cx I2C instance.
563  * @retval State of bit (1 or 0).
564  */
565 __STATIC_INLINE uint32_t ll_i2c_is_enabled_master_restart(i2c_regs_t *I2Cx)
566 {
567  return (READ_BITS(I2Cx->CTRL, I2C_CTRL_RESTART_EN) == (I2C_CTRL_RESTART_EN));
568 }
569 
570 /**
571  * @brief Enable Slave issues STOP_DET interrupt only if addressed function.
572  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
573  * During a general call address, the slave does not issue the STOP_DET interrupt if
574  * STOP_DET_IF_ADDRESSED = 1'b1, even if the slave responds to the general call address
575  * by generating ACK. The STOP_DET interrupt is generated only when the transmitted
576  * address matches the slave address (SAR).
577  *
578  * Register|BitsName
579  * ---------------|---------------
580  * CTRL | STOP_DET_INT
581  *
582  * @param I2Cx I2C instance.
583  * @retval None.
584  */
585 __STATIC_INLINE void ll_i2c_enable_stop_det_if_addressed(i2c_regs_t *I2Cx)
586 {
587  SET_BITS(I2Cx->CTRL, I2C_CTRL_STOP_DET_INT);
588 }
589 
590 /**
591  * @brief Disable Slave issues STOP_DET interrupt only if addressed function.
592  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
593  *
594  * Register|BitsName
595  * ---------------|---------------
596  * CTRL | STOP_DET_INT
597  *
598  * @param I2Cx I2C instance.
599  * @retval None.
600  */
601 __STATIC_INLINE void ll_i2c_disable_stop_det_if_addressed(i2c_regs_t *I2Cx)
602 {
603  CLEAR_BITS(I2Cx->CTRL, I2C_CTRL_STOP_DET_INT);
604 }
605 
606 /**
607  * @brief Hold bus when the RX FIFO if full function.
608  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
609  *
610  * Register|BitsName
611  * ---------------|---------------
612  * CTRL | RXFIFO_FULL_HLD
613  *
614  * @param I2Cx I2C instance.
615  * @retval None.
616  */
617 __STATIC_INLINE void ll_i2c_hold_bus_if_rx_full(i2c_regs_t *I2Cx)
618 {
619  SET_BITS(I2Cx->CTRL, I2C_CTRL_RXFIFO_FULL_HLD);
620 }
621 
622 /**
623  * @brief overflow when the RX FIFO if full function.
624  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
625  *
626  * Register|BitsName
627  * ---------------|---------------
628  * CTRL | RXFIFO_FULL_HLD
629  *
630  * @param I2Cx I2C instance.
631  * @retval None.
632  */
633 __STATIC_INLINE void ll_i2c_overflow_if_rx_full(i2c_regs_t *I2Cx)
634 {
635  CLEAR_BITS(I2Cx->CTRL, I2C_CTRL_RXFIFO_FULL_HLD);
636 }
637 
638 /**
639  * @brief enable bus clear feature function.
640  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
641  *
642  * Register|BitsName
643  * ---------------|---------------
644  * CTRL | BUS_CLR_FEATURE
645  *
646  * @param I2Cx I2C instance.
647  * @retval None.
648  */
649 __STATIC_INLINE void ll_i2c_enable_bus_clear_feature(i2c_regs_t *I2Cx)
650 {
651  SET_BITS(I2Cx->CTRL, I2C_CTRL_BUS_CLR_FEATURE);
652 }
653 
654 /**
655  * @brief disable bus clear feature function.
656  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
657  *
658  * Register|BitsName
659  * ---------------|---------------
660  * CTRL | BUS_CLR_FEATURE
661  *
662  * @param I2Cx I2C instance.
663  * @retval None.
664  */
665 __STATIC_INLINE void ll_i2c_disable_bus_clear_feature(i2c_regs_t *I2Cx)
666 {
667  CLEAR_BITS(I2Cx->CTRL, I2C_CTRL_BUS_CLR_FEATURE);
668 }
669 
670 /**
671  * @brief check bus clear feature is enabled function.
672  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
673  *
674  * Register|BitsName
675  * ---------------|---------------
676  * CTRL | BUS_CLR_FEATURE
677  *
678  * @param I2Cx I2C instance.
679  * @retval None.
680  */
681 __STATIC_INLINE uint32_t ll_i2c_is_enabled_bus_clear_feature(i2c_regs_t *I2Cx)
682 {
683  return (READ_BITS(I2Cx->CTRL, I2C_CTRL_BUS_CLR_FEATURE) == (I2C_CTRL_BUS_CLR_FEATURE));
684 }
685 
686 /**
687  * @brief Check if Slave issues STOP_DET interrupt only if addressed function is enabled or disabled.
688  *
689  * Register|BitsName
690  * ---------------|---------------
691  * CTRL | STOP_DET_INT
692  *
693  * @param I2Cx I2C instance.
694  * @retval State of bit (1 or 0).
695  */
696 __STATIC_INLINE uint32_t ll_i2c_is_enabled_stop_det_if_addressed(i2c_regs_t *I2Cx)
697 {
698  return (READ_BITS(I2Cx->CTRL, I2C_CTRL_STOP_DET_INT) == (I2C_CTRL_STOP_DET_INT));
699 }
700 
701 /**
702  * @brief Configure the Master to transfers in 7-bit or 10-bit addressing mode.
703  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
704  *
705  * Register|BitsName
706  * ---------------|---------------
707  * CTRL | ADDR_BIT_M
708  *
709  * @param I2Cx I2C instance.
710  * @param addressing_mode This parameter can be one of the following values:
711  * @arg @ref LL_I2C_ADDRESSING_MODE_7BIT
712  * @arg @ref LL_I2C_ADDRESSING_MODE_10BIT
713  * @retval None.
714  */
715 __STATIC_INLINE void ll_i2c_set_master_addressing_mode(i2c_regs_t *I2Cx, uint32_t addressing_mode)
716 {
717  MODIFY_REG(I2Cx->CTRL, I2C_CTRL_ADDR_BIT_M, addressing_mode);
718 }
719 
720 /**
721  * @brief Get the Master addressing mode.
722  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
723  *
724  * Register|BitsName
725  * ---------------|---------------
726  * CTRL | ADDR_BIT_M
727  *
728  * @param I2Cx I2C instance.
729  * @retval Returned value can be one of the following values:
730  * @arg @ref LL_I2C_ADDRESSING_MODE_7BIT
731  * @arg @ref LL_I2C_ADDRESSING_MODE_10BIT
732  */
733 __STATIC_INLINE uint32_t ll_i2c_get_master_addressing_mode(i2c_regs_t *I2Cx)
734 {
735  return (uint32_t)(READ_BITS(I2Cx->CTRL, I2C_CTRL_ADDR_BIT_M));
736 }
737 
738 /**
739  * @brief Set the Own Address.
740  * @note The register IC_CON and IC_SAR can only be programmed when the I2C is disabled (IC_ENABLE = 0).
741  *
742  * Register|BitsName
743  * ---------------|---------------
744  * CTRL | ADDR_BIT_S
745  * S_ADDR | SAR
746  *
747  * @param I2Cx I2C instance.
748  * @param own_address This parameter must be a value range between 0 ~ 0x3FF(10-bit mode) or 0 ~ 0x7F(7-bit mode).
749  * Reserved address 0x00 to 0x07, or 0x78 to 0x7f should not be configured.
750  * @param own_addr_size This parameter can be one of the following values:
751  * @arg @ref LL_I2C_OWNADDRESS_7BIT
752  * @arg @ref LL_I2C_OWNADDRESS_10BIT
753  * @retval None.
754  */
755 __STATIC_INLINE void ll_i2c_set_own_address(i2c_regs_t *I2Cx, uint32_t own_address, uint32_t own_addr_size)
756 {
757  MODIFY_REG(I2Cx->CTRL, I2C_CTRL_ADDR_BIT_S, own_addr_size);
758  WRITE_REG(I2Cx->S_ADDR, own_address);
759 }
760 
761 /**
762  * @brief Set the SCL clock high-period count for standard speed.
763  * @note The register IC_SS_SCL_HCNT can only be programmed when the I2C is disabled (ENABLE = 0).
764  *
765  * Register|BitsName
766  * ---------------|---------------
767  * SS_CLK_HCOUNT | SS_SCL_HCNT
768  *
769  * @param I2Cx I2C instance.
770  * @param count This parameter must be a value range between 6 ~ 0xFFF5.
771  * @retval None.
772  */
773 __STATIC_INLINE void ll_i2c_set_clock_high_period_ss(i2c_regs_t *I2Cx, uint32_t count)
774 {
775  WRITE_REG(I2Cx->SS_CLK_HCOUNT, count);
776 }
777 
778 /**
779  * @brief Get the SCL clock high-period count for standard speed.
780  *
781  * Register|BitsName
782  * ---------------|---------------
783  * SS_CLK_HCOUNT | COUNT
784  *
785  * @param I2Cx I2C instance.
786  * @retval Value range between 0x6 and 0xFFF5.
787  */
788 __STATIC_INLINE uint32_t ll_i2c_get_clock_high_period_ss(i2c_regs_t *I2Cx)
789 {
790  return (uint32_t)(READ_BITS(I2Cx->SS_CLK_HCOUNT, I2C_SS_CLK_HCOUNT_COUNT));
791 }
792 
793 /**
794  * @brief Set the SCL clock low-period count for standard speed.
795  * @note The register IC_SS_SCL_LCNT can only be programmed when the I2C is disabled (ENABLE = 0).
796  *
797  * Register|BitsName
798  * ---------------|---------------
799  * SS_CLK_LCOUNT | COUNT
800  *
801  * @param I2Cx I2C instance.
802  * @param count This parameter must be a value range between 0x8 and 0xFFFF.
803  * @retval None.
804  */
805 __STATIC_INLINE void ll_i2c_set_clock_low_period_ss(i2c_regs_t *I2Cx, uint32_t count)
806 {
807  WRITE_REG(I2Cx->SS_CLK_LCOUNT, count);
808 }
809 
810 /**
811  * @brief Get the SCL clock low-period count for standard speed.
812  *
813  * Register|BitsName
814  * ---------------|---------------
815  * SS_CLK_LCOUNT | COUNT
816  *
817  * @param I2Cx I2C instance.
818  * @retval Value range between 0x8 and 0xFFFF.
819  */
820 __STATIC_INLINE uint32_t ll_i2c_get_clock_low_period_ss(i2c_regs_t *I2Cx)
821 {
822  return (uint32_t)(READ_BITS(I2Cx->SS_CLK_LCOUNT, I2C_SS_CLK_LCOUNT_COUNT));
823 }
824 
825 /**
826  * @brief Set the SCL clock high-period count for fast speed.
827  * @note The register IC_FS_SCL_HCNT can only be programmed when the I2C is disabled (ENABLE = 0).
828  *
829  * Register|BitsName
830  * ---------------|---------------
831  * FS_CLK_HCOUNT | COUNT
832  *
833  * @param I2Cx I2C instance.
834  * @param count range between 0x6 and 0xFFFF.
835  * @retval None.
836  */
837 __STATIC_INLINE void ll_i2c_set_clock_high_period_fs(i2c_regs_t *I2Cx, uint32_t count)
838 {
839  WRITE_REG(I2Cx->FS_CLK_HCOUNT, count);
840 }
841 
842 /**
843  * @brief Get the SCL clock high-period count for fast speed.
844  *
845  * Register|BitsName
846  * ---------------|---------------
847  * FS_CLK_HCOUNT | COUNT
848  *
849  * @param I2Cx I2C instance.
850  * @retval Value range between 0x6 and 0xFFFF.
851  */
852 __STATIC_INLINE uint32_t ll_i2c_get_clock_high_period_fs(i2c_regs_t *I2Cx)
853 {
854  return (uint32_t)(READ_BITS(I2Cx->FS_CLK_HCOUNT, I2C_FS_CLK_HCOUNT_COUNT));
855 }
856 
857 /**
858  * @brief Set the SCL clock low-period count for fast speed.
859  * @note The register IC_FS_SCL_LCNT can only be programmed when the I2C is disabled (ENABLE = 0).
860  *
861  * Register|BitsName
862  * ---------------|---------------
863  * FS_CLK_LCOUNT | COUNT
864  *
865  * @param I2Cx I2C instance.
866  * @param count range between 0x8 and 0xFFFF
867  * @retval None.
868  */
869 __STATIC_INLINE void ll_i2c_set_clock_low_period_fs(i2c_regs_t *I2Cx, uint32_t count)
870 {
871  WRITE_REG(I2Cx->FS_CLK_LCOUNT, count);
872 }
873 
874 /**
875  * @brief Get the SCL clock low-period count for fast speed.
876  *
877  * Register|BitsName
878  * ---------------|---------------
879  * FS_CLK_LCOUNT | COUNT
880  *
881  * @param I2Cx I2C instance.
882  * @retval Value range between 0x8 and 0xFFFF.
883  */
884 __STATIC_INLINE uint32_t ll_i2c_get_clock_low_period_fs(i2c_regs_t *I2Cx)
885 {
886  return (uint32_t)(READ_BITS(I2Cx->FS_CLK_LCOUNT, I2C_FS_CLK_LCOUNT_COUNT));
887 }
888 
889 /**
890  * @brief Get the SCL clock high-period count for high speed.
891  * @note The register IC_HS_SCL_HCNT can only be programmed when the I2C is disabled (ENABLE = 0).
892  *
893  * Register|BitsName
894  * ---------------|---------------
895  * HS_CLK_HCOUNT | COUNT
896  *
897  * @param I2Cx I2C instance.
898  * @param count range between 0x6 and 0xFFFF, should be larger than IC_HS_SPKLEN + 5.
899  * @retval None.
900  */
901 __STATIC_INLINE void ll_i2c_set_clock_high_period_hs(i2c_regs_t *I2Cx, uint32_t count)
902 {
903  WRITE_REG(I2Cx->HS_CLK_HCOUNT, count);
904 }
905 
906 /**
907  * @brief Get the SCL clock high-period count for high speed.
908  *
909  * Register|BitsName
910  * ---------------|---------------
911  * HS_CLK_HCOUNT | COUNT
912  *
913  * @param I2Cx I2C instance.
914  * @retval range between 0x6 and 0xFFFF, should be larger than IC_HS_SPKLEN + 7.
915  */
916 __STATIC_INLINE uint32_t ll_i2c_get_clock_high_period_hs(i2c_regs_t *I2Cx)
917 {
918  return (uint32_t)(READ_BITS(I2Cx->HS_CLK_HCOUNT, I2C_HS_CLK_HCOUNT_COUNT));
919 }
920 
921 /**
922  * @brief Get the SCL clock low-period count for high speed.
923  * @note The register IC_HS_SCL_LCNT can only be programmed when the I2C is disabled (ENABLE = 0).
924  *
925  * Register|BitsName
926  * ---------------|---------------
927  * HS_CLK_LCOUNT | COUNT
928  *
929  * @param I2Cx I2C instance.
930  * @param count range between 0x8 and 0xFFFF
931  * @retval None.
932  */
933 __STATIC_INLINE void ll_i2c_set_clock_low_period_hs(i2c_regs_t *I2Cx, uint32_t count)
934 {
935  WRITE_REG(I2Cx->HS_CLK_LCOUNT, count);
936 }
937 
938 /**
939  * @brief Get the SCL clock low-period count for high speed.
940  *
941  * Register|BitsName
942  * ---------------|---------------
943  * HS_CLK_LCOUNT | COUNT
944  *
945  * @param I2Cx I2C instance.
946  * @retval Value range between 0x8 and 0xFFFF
947  */
948 __STATIC_INLINE uint32_t ll_i2c_get_clock_low_period_hs(i2c_regs_t *I2Cx)
949 {
950  return (uint32_t)(READ_BITS(I2Cx->HS_CLK_LCOUNT, I2C_HS_CLK_LCOUNT_COUNT));
951 }
952 
953 /**
954  * @brief Set the spike len in fast speed mode.
955  * @note The register FS_SPKLEN can only be programmed when the I2C is disabled (ENABLE = 0).
956  *
957  * Register|BitsName
958  * ---------------|---------------
959  * FS_SPKLEN | FS_SPKLEN
960  *
961  * @param I2Cx I2C instance.
962  * @param length Spike len.
963  * @retval None.
964  */
965 __STATIC_INLINE void ll_i2c_set_spike_len_fs(i2c_regs_t *I2Cx, uint32_t length)
966 {
967  MODIFY_REG(I2Cx->FS_SPKLEN, I2C_FS_SPKLEN_FS_SPKLEN, length);
968 }
969 
970 /**
971  * @brief Get the spike len in fast speed mode.
972  *
973  * Register|BitsName
974  * ---------------|---------------
975  * FS_SPKLEN | FS_SPKLEN
976  *
977  * @param I2Cx I2C instance.
978  * @retval Value range between 0x2 and 0xFF.
979  */
980 __STATIC_INLINE uint32_t ll_i2c_get_spike_len_fs(i2c_regs_t *I2Cx)
981 {
982  return (uint32_t)(READ_BITS(I2Cx->FS_SPKLEN, I2C_FS_SPKLEN_FS_SPKLEN));
983 }
984 
985 /**
986  * @brief Set the spike len in high speed mode.
987  * @note The register FS_SPKLEN can only be programmed when the I2C is disabled (ENABLE = 0).
988  *
989  * Register|BitsName
990  * ---------------|---------------
991  * HS_SPKLEN | HS_SPKLEN
992  *
993  * @param I2Cx I2C instance.
994  * @param length Spike len.
995  * @retval None.
996  */
997 __STATIC_INLINE void ll_i2c_set_spike_len_hs(i2c_regs_t *I2Cx, uint32_t length)
998 {
999  MODIFY_REG(I2Cx->HS_SPKLEN, I2C_HS_SPKLEN_HS_SPKLEN, length);
1000 }
1001 
1002 /**
1003  * @brief Get the spike len in high speed mode.
1004  *
1005  * Register|BitsName
1006  * ---------------|---------------
1007  * HS_SPKLEN | HS_SPKLEN
1008  *
1009  * @param I2Cx I2C instance.
1010  * @retval Value range between 0x2 and 0xFF.
1011  */
1012 __STATIC_INLINE uint32_t ll_i2c_get_spike_len_hs(i2c_regs_t *I2Cx)
1013 {
1014  return (uint32_t)(READ_BITS(I2Cx->HS_SPKLEN, I2C_HS_SPKLEN_HS_SPKLEN));
1015 }
1016 
1017 /**
1018  * @brief Set I2C Speed mode.
1019  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
1020  *
1021  * Register|BitsName
1022  * ---------------|---------------
1023  * CTRL | SPEED
1024  *
1025  * @param I2Cx I2C instance.
1026  * @param speed_mode This parameter can be one of the following values:
1027  * @arg @ref LL_I2C_SPEED_MODE_STANDARD
1028  * @arg @ref LL_I2C_SPEED_MODE_FAST
1029  * @arg @ref LL_I2C_SPEED_MODE_HIGH
1030  * @retval None.
1031  */
1032 __STATIC_INLINE void ll_i2c_set_speed_mode(i2c_regs_t *I2Cx, uint32_t speed_mode)
1033 {
1034  MODIFY_REG(I2Cx->CTRL, I2C_CTRL_SPEED, speed_mode);
1035 }
1036 
1037 /**
1038  * @brief Get I2C Speed mode.
1039  *
1040  * Register|BitsName
1041  * ---------------|---------------
1042  * CTRL | SPEED
1043  *
1044  * @param I2Cx I2C instance.
1045  * @retval Value can be one of the following values:
1046  * @arg @ref LL_I2C_SPEED_MODE_STANDARD
1047  * @arg @ref LL_I2C_SPEED_MODE_FAST
1048  * @arg @ref LL_I2C_SPEED_MODE_HIGH
1049  */
1050 __STATIC_INLINE uint32_t ll_i2c_get_speed_mode(i2c_regs_t *I2Cx)
1051 {
1052  return (uint32_t)(READ_BITS(I2Cx->CTRL, I2C_CTRL_SPEED));
1053 }
1054 
1055 /**
1056  * @brief Set I2C High Speed Master Code Address.
1057  * @note The register IC_CON can only be programmed when the I2C is disabled (ENABLE = 0).
1058  *
1059  * Register|BitsName
1060  * ---------------|---------------
1061  * M_HS_ADDR | HS_MAR
1062  *
1063  * @param I2Cx I2C instance.
1064  * @param code HS mode master code, range between 0x00 and 0x07.
1065  * @retval None.
1066  */
1067 __STATIC_INLINE void ll_i2c_set_high_speed_master_code(i2c_regs_t *I2Cx, uint32_t code)
1068 {
1069  WRITE_REG(I2Cx->M_HS_ADDR, code);
1070 }
1071 
1072 /**
1073  * @brief Get I2C Speed mode.
1074  *
1075  * Register|BitsName
1076  * ---------------|---------------
1077  * M_HS_ADDR | HS_MAR
1078  *
1079  * @param I2Cx I2C instance.
1080  * @retval Returned value range between 0x00 and 0x07.
1081  */
1082 __STATIC_INLINE uint32_t ll_i2c_get_high_speed_master_code(i2c_regs_t *I2Cx)
1083 {
1084  return (uint32_t)(READ_BITS(I2Cx->M_HS_ADDR, I2C_M_HS_ADDR_HS_ADDR));
1085 }
1086 
1087 /**
1088  * @brief Set the required transmit SDA hold time in units of ic_clk period.
1089  * @note The register IC_SDA_HOLD can only be programmed when the I2C is disabled (ENABLE = 0).
1090  *
1091  * Register|BitsName
1092  * ---------------|---------------
1093  * SDA_HOLD | TX_HOLD
1094  *
1095  * @param I2Cx I2C instance.
1096  * @param time SDA Tx hold time in units of ic_clk period.
1097  * Time should range between 1 and (N_SCL_LOW - 2) in master mode or 7 and (N_SCL_LOW - 2) in slave mode.
1098  * @retval None.
1099  */
1100 __STATIC_INLINE void ll_i2c_set_data_tx_hold_time(i2c_regs_t *I2Cx, uint32_t time)
1101 {
1102  MODIFY_REG(I2Cx->SDA_HOLD, I2C_SDA_HOLD_TX_HOLD, time << I2C_SDA_HOLD_TX_HOLD_POS);
1103 }
1104 
1105 /**
1106  * @brief Get the required transmit SDA hold time in units of ic_clk period.
1107  *
1108  * Register|BitsName
1109  * ---------------|---------------
1110  * SDA_HOLD | TX_HOLD
1111  *
1112  * @param I2Cx I2C instance.
1113  * @retval Value range between 1 and (N_SCL_LOW - 2) in master mode or 7 and (N_SCL_LOW - 2) in slave mode
1114  */
1115 __STATIC_INLINE uint32_t ll_i2c_get_data_tx_hold_time(i2c_regs_t *I2Cx)
1116 {
1117  return (uint32_t)(READ_BITS(I2Cx->SDA_HOLD, I2C_SDA_HOLD_TX_HOLD) >> I2C_SDA_HOLD_TX_HOLD_POS);
1118 }
1119 
1120 /**
1121  * @brief Set the required receive SDA hold time in units of ic_clk period.
1122  * @note The register IC_SDA_HOLD can only be programmed when the I2C is disabled (ENABLE = 0).
1123  *
1124  * Register|BitsName
1125  * ---------------|---------------
1126  * SDA_HOLD | RX_HOLD
1127  *
1128  * @param I2Cx I2C instance.
1129  * @param time SDA Tx hold time in units of ic_clk period.
1130  * Time should range between 1 and (N_SCL_LOW - 2) in master mode or 7 and (N_SCL_LOW - 2) in slave mode.
1131  * @retval Value between Min_Data=0x0 and Max_Data=0xF
1132  */
1133 __STATIC_INLINE void ll_i2c_set_data_rx_hold_time(i2c_regs_t *I2Cx, uint32_t time)
1134 {
1135  MODIFY_REG(I2Cx->SDA_HOLD, I2C_SDA_HOLD_RX_HOLD, time << I2C_SDA_HOLD_RX_HOLD_POS);
1136 }
1137 
1138 /**
1139  * @brief Get the required receive SDA hold time in units of ic_clk period.
1140  *
1141  * Register|BitsName
1142  * ---------------|---------------
1143  * SDA_HOLD | RX_HOLD
1144  *
1145  * @param I2Cx I2C instance.
1146  * @retval Value range between 1 and (N_SCL_LOW - 2) in master mode or 7 and (N_SCL_LOW - 2) in slave mode
1147  */
1148 __STATIC_INLINE uint32_t ll_i2c_get_data_rx_hold_time(i2c_regs_t *I2Cx)
1149 {
1150  return (uint32_t)(READ_BITS(I2Cx->SDA_HOLD, I2C_SDA_HOLD_RX_HOLD) >> I2C_SDA_HOLD_RX_HOLD_POS);
1151 }
1152 
1153 /**
1154  * @brief Set the SDA setup time when operating as a slave transmitter.
1155  * @note The register IC_SDA_SETUP can only be programmed when the I2C is disabled (ENABLE = 0).
1156  * The length of setup time is calculated using [(IC_SDA_SETUP - 1) * (ic_clk_period)], so if the
1157  * user requires 10 ic_clk periods of setup time, they should program a value of 11.
1158  *
1159  * Register|BitsName
1160  * ---------------|---------------
1161  * SDA_SETUP | SETUP
1162  *
1163  * @param I2Cx I2C instance.
1164  * @param time SDA data setup time in units of ic_clk period, range between 2 ~ 0xFF.
1165  * @retval None.
1166  */
1167 __STATIC_INLINE void ll_i2c_set_data_setup_time(i2c_regs_t *I2Cx, uint32_t time)
1168 {
1169  MODIFY_REG(I2Cx->SDA_SETUP, I2C_SDA_SETUP_SETUP, time);
1170 }
1171 
1172 /**
1173  * @brief Get the SDA setup time when operating as a slave transmitter.
1174  *
1175  * Register|BitsName
1176  * ---------------|---------------
1177  * SDA_SETUP | SETUP
1178  *
1179  * @param I2Cx I2C instance.
1180  * @retval Value range between 0x02 and 0xFF.
1181  */
1182 __STATIC_INLINE uint32_t ll_i2c_get_data_setup_time(i2c_regs_t *I2Cx)
1183 {
1184  return (uint32_t)(READ_BITS(I2Cx->SDA_SETUP, I2C_SDA_SETUP_SETUP));
1185 }
1186 
1187 /**
1188  * @brief Set threshold of entries (or below) that trigger the TX_EMPTY interrupt
1189  * @note TX FIFO threshold only can be configured after FIFO was enabled.
1190  *
1191  * Register|BitsName
1192  * ---------------|---------------
1193  * TX_FIFO_THD | THD
1194  *
1195  * @param I2Cx I2C instance
1196  * @param threshold This parameter can be one of the following values:
1197  * @arg @ref LL_I2C_TX_FIFO_TH_EMPTY
1198  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_1
1199  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_2
1200  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_3
1201  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_4
1202  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_5
1203  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_6
1204  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_7
1205  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_8
1206  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_9
1207  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_10
1208  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_11
1209  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_12
1210  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_13
1211  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_14
1212  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_15
1213  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_16
1214  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_17
1215  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_18
1216  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_19
1217  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_20
1218  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_21
1219  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_22
1220  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_23
1221  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_24
1222  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_25
1223  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_26
1224  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_27
1225  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_28
1226  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_29
1227  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_30
1228  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_31
1229  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_32
1230  * @retval None.
1231  */
1232 __STATIC_INLINE void ll_i2c_set_tx_fifo_threshold(i2c_regs_t *I2Cx, uint32_t threshold)
1233 {
1234  WRITE_REG(I2Cx->TX_FIFO_THD, threshold);
1235 }
1236 
1237 /**
1238  * @brief Get threshold of TX FIFO that triggers an THRE interrupt
1239  *
1240  * Register|BitsName
1241  * ---------------|---------------
1242  * TX_FIFO_THD | THD
1243  *
1244  * @param I2Cx I2C instance
1245  * @retval Returned value can be one of the following values:
1246  * @arg @ref LL_I2C_TX_FIFO_TH_EMPTY
1247  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_1
1248  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_2
1249  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_3
1250  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_4
1251  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_5
1252  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_6
1253  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_7
1254  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_8
1255  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_9
1256  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_10
1257  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_11
1258  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_12
1259  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_13
1260  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_14
1261  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_15
1262  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_16
1263  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_17
1264  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_18
1265  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_19
1266  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_20
1267  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_21
1268  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_22
1269  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_23
1270  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_24
1271  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_25
1272  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_26
1273  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_27
1274  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_28
1275  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_29
1276  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_30
1277  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_31
1278  * @arg @ref LL_I2C_TX_FIFO_TH_CHAR_32
1279  */
1280 __STATIC_INLINE uint32_t ll_i2c_get_tx_fifo_threshold(i2c_regs_t *I2Cx)
1281 {
1282  return (uint32_t)(READ_BITS(I2Cx->TX_FIFO_THD, I2C_TX_FIFO_THD_THD));
1283 }
1284 
1285 /**
1286  * @brief Set threshold of RX FIFO that triggers an RDA interrupt
1287  * @note TX FIFO threshold only can be configured after FIFO was enabled.
1288  *
1289  * Register|BitsName
1290  * ---------------|---------------
1291  * RX_FIFO_THD | THD
1292  *
1293  * @param I2Cx I2C instance
1294  * @param threshold This parameter can be one of the following values:
1295  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_1
1296  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_2
1297  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_3
1298  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_4
1299  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_5
1300  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_6
1301  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_7
1302  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_8
1303  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_9
1304  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_10
1305  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_11
1306  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_12
1307  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_13
1308  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_14
1309  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_15
1310  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_16
1311  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_17
1312  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_18
1313  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_19
1314  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_20
1315  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_21
1316  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_22
1317  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_23
1318  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_24
1319  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_25
1320  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_26
1321  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_27
1322  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_28
1323  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_29
1324  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_30
1325  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_31
1326  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_32
1327  * @arg @ref LL_I2C_RX_FIFO_TH_FULL
1328  * @retval None.
1329  */
1330 __STATIC_INLINE void ll_i2c_set_rx_fifo_threshold(i2c_regs_t *I2Cx, uint32_t threshold)
1331 {
1332  WRITE_REG(I2Cx->RX_FIFO_THD, threshold);
1333 }
1334 
1335 /**
1336  * @brief Get threshold of RX FIFO that triggers an RDA interrupt
1337  *
1338  * Register|BitsName
1339  * ---------------|---------------
1340  * RX_FIFO_THD | THD
1341  *
1342  * @param I2Cx I2C instance
1343  * @retval Returned value can be one of the following values:
1344  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_1
1345  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_2
1346  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_3
1347  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_4
1348  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_5
1349  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_6
1350  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_7
1351  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_8
1352  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_9
1353  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_10
1354  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_11
1355  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_12
1356  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_13
1357  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_14
1358  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_15
1359  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_16
1360  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_17
1361  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_18
1362  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_19
1363  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_20
1364  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_21
1365  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_22
1366  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_23
1367  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_24
1368  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_25
1369  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_26
1370  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_27
1371  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_28
1372  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_29
1373  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_30
1374  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_31
1375  * @arg @ref LL_I2C_RX_FIFO_TH_CHAR_32
1376  * @arg @ref LL_I2C_RX_FIFO_TH_FULL
1377  */
1378 __STATIC_INLINE uint32_t ll_i2c_get_rx_fifo_threshold(i2c_regs_t *I2Cx)
1379 {
1380  return (uint32_t)(READ_BITS(I2Cx->RX_FIFO_THD, I2C_RX_FIFO_THD_THD));
1381 }
1382 
1383 /**
1384  * @brief Get FIFO Transmission Level
1385  *
1386  * Register|BitsName
1387  * ---------------|---------------
1388  * RX_FIFO_THD | LEVEL
1389  *
1390  * @param I2Cx I2C instance
1391  * @retval Value range between 0x0 and 0x1F.
1392  */
1393 __STATIC_INLINE uint32_t ll_i2c_get_tx_fifo_level(i2c_regs_t *I2Cx)
1394 {
1395  return (uint32_t)(READ_BITS(I2Cx->TX_FIFO_LEVEL, I2C_TX_FIFO_LEVEL_LEVEL));
1396 }
1397 
1398 /**
1399  * @brief Get FIFO reception Level
1400  *
1401  * Register|BitsName
1402  * ---------------|---------------
1403  * RX_FIFO_THD | LEVEL
1404  *
1405  * @param I2Cx I2C instance
1406  * @retval Value range between 0x0 and 0x1F.
1407  */
1408 __STATIC_INLINE uint32_t ll_i2c_get_rx_fifo_level(i2c_regs_t *I2Cx)
1409 {
1410  return (uint32_t)(READ_BITS(I2Cx->RX_FIFO_LEVEL, I2C_RX_FIFO_LEVEL_LEVEL));
1411 }
1412 
1413 /**
1414  * @brief Master initates the SDA stuck at low recovery mechanism.
1415  *
1416  * Register|BitsName
1417  * ---------------|---------------
1418  * EN | SDA_STUCK_RECOVERY
1419  *
1420  * @param I2Cx I2C instance
1421  */
1422 __STATIC_INLINE void ll_i2c_enable_sda_stuck_recovery(i2c_regs_t *I2Cx)
1423 {
1424  SET_BITS(I2Cx->EN, I2C_EN_SDA_STUCK_RECOVERY);
1425 }
1426 
1427 /**
1428  * @brief Master disabled the SDA stuck at low recovery mechanism
1429  *
1430  * Register|BitsName
1431  * ---------------|---------------
1432  * EN | SDA_STUCK_RECOVERY
1433  *
1434  * @param I2Cx I2C instance
1435  */
1436 __STATIC_INLINE void ll_i2c_disable_sda_stuck_recovery(i2c_regs_t *I2Cx)
1437 {
1438  CLEAR_BITS(I2Cx->EN, I2C_EN_SDA_STUCK_RECOVERY);
1439 }
1440 
1441 /**
1442  * @brief the SDA stuck at low recovery mechanism is enabled or disabled.
1443  *
1444  * Register|BitsName
1445  * ---------------|---------------
1446  * EN | SDA_STUCK_RECOVERY
1447  *
1448  * @param I2Cx I2C instance
1449  * @retval State of bit (1 or 0).
1450  */
1451 __STATIC_INLINE uint32_t ll_i2c_is_enabled_sda_stuck_recovery(i2c_regs_t *I2Cx)
1452 {
1453  return (READ_BITS(I2Cx->EN, I2C_EN_SDA_STUCK_RECOVERY) == (I2C_EN_SDA_STUCK_RECOVERY));
1454 }
1455 
1456 /**
1457  * @brief Enable DMA reception requests.
1458  *
1459  * Register|BitsName
1460  * ---------------|---------------
1461  * EN | ABORT
1462  *
1463  * @param I2Cx I2C instance.
1464  * @retval None.
1465  */
1466 __STATIC_INLINE void ll_i2c_enable_transfer_abort(i2c_regs_t *I2Cx)
1467 {
1468  SET_BITS(I2Cx->EN, I2C_EN_ABORT);
1469 }
1470 
1471 /**
1472  * @brief Check if DMA reception requests are enabled or disabled.
1473  *
1474  * Register|BitsName
1475  * ---------------|---------------
1476  * EN | ABORT
1477  *
1478  * @param I2Cx I2C instance.
1479  * @retval State of bit (1 or 0).
1480  */
1481 __STATIC_INLINE uint32_t ll_i2c_is_enabled_transfer_abort(i2c_regs_t *I2Cx)
1482 {
1483  return (READ_BITS(I2Cx->EN, I2C_EN_ABORT) == (I2C_EN_ABORT));
1484 }
1485 
1486 /**
1487  * @brief Get the transmit abort source.
1488  * @note This can be used to retrieve source of TX_ABRT interrupt.
1489  *
1490  * Register|BitsName
1491  * ---------------|---------------
1492  * TX_ABORT_SRC | ABRT_USER_ABRT
1493  * TX_ABORT_SRC | ABRT_SLVRD_INTX
1494  * TX_ABORT_SRC | ABRT_SLV_ARBLOST
1495  * TX_ABORT_SRC | ABRT_SLVFLUSH_TXFIFO
1496  * TX_ABORT_SRC | ABRT_ARB_LOST
1497  * TX_ABORT_SRC | ABRT_MST_DIS
1498  * TX_ABORT_SRC | ABRT_10B_RD_NORSTRT
1499  * TX_ABORT_SRC | ABRT_SBYTE_NORSTRT
1500  * TX_ABORT_SRC | ABRT_HS_NORSTRT
1501  * TX_ABORT_SRC | ABRT_SBYTE_ACKDET
1502  * TX_ABORT_SRC | ABRT_HS_ACKDET
1503  * TX_ABORT_SRC | ABRT_GCALL_READ
1504  * TX_ABORT_SRC | ABRT_GCALL_NOACK
1505  * TX_ABORT_SRC | ABRT_TXDATA_NOACK
1506  * TX_ABORT_SRC | ABRT_10ADDR2_NOACK
1507  * TX_ABORT_SRC | ABRT_10ADDR1_NOACK
1508  * TX_ABORT_SRC | ABRT_7B_ADDR_NOACK
1509  *
1510  * @param I2Cx I2C instance
1511  * @retval Returned value can be a combination of the following values:
1512  * @arg @ref LL_I2C_ABRT_USER_ABRT
1513  * @arg @ref LL_I2C_ABRT_SLVRD_INTX
1514  * @arg @ref LL_I2C_ABRT_SLV_ARBLOST
1515  * @arg @ref LL_I2C_ABRT_SLVFLUSH_TXFIFO
1516  * @arg @ref LL_I2C_ABRT_ARB_LOST
1517  * @arg @ref LL_I2C_ABRT_MST_DIS
1518  * @arg @ref LL_I2C_ABRT_10B_RD_NORSTRT
1519  * @arg @ref LL_I2C_ABRT_SBYTE_NORSTRT
1520  * @arg @ref LL_I2C_ABRT_HS_NORSTRT
1521  * @arg @ref LL_I2C_ABRT_SBYTE_ACKDET
1522  * @arg @ref LL_I2C_ABRT_HS_ACKDET
1523  * @arg @ref LL_I2C_ABRT_GCALL_READ
1524  * @arg @ref LL_I2C_ABRT_GCALL_NOACK
1525  * @arg @ref LL_I2C_ABRT_TXDATA_NOACK
1526  * @arg @ref LL_I2C_ABRT_10ADDR2_NOACK
1527  * @arg @ref LL_I2C_ABRT_10ADDR1_NOACK
1528  * @arg @ref LL_I2C_ABRT_7B_ADDR_NOACK
1529  *
1530  * @note @arg @ref LL_I2C_ABRT_TX_FLUSH_CNT can be used as a mask to get the
1531  * number of Tx FIFO Data Commands which are flushed due to TX_ABRT
1532  * interrupt.
1533  */
1534 __STATIC_INLINE uint32_t ll_i2c_get_abort_source(i2c_regs_t *I2Cx)
1535 {
1536  return (uint32_t)(READ_REG(I2Cx->TX_ABORT_SRC) & (~I2C_TX_ABORT_SRC_TX_FLUSH_CNT));
1537 }
1538 
1539 /**
1540  * @brief Get the number of Tx FIFO Data Commands which are flushed due to TX_ABRT interrupt.
1541  *
1542  * Register|BitsName
1543  * ---------------|---------------
1544  * TX_ABORT_SRC | TX_FLUSH_CNT
1545  *
1546  * @param I2Cx I2C instance
1547  * @retval Tx flush count.
1548  */
1549 __STATIC_INLINE uint32_t ll_i2c_get_tx_flush_count(i2c_regs_t *I2Cx)
1550 {
1551  return (uint32_t)(READ_BITS(I2Cx->TX_ABORT_SRC, I2C_TX_ABORT_SRC_TX_FLUSH_CNT) >> I2C_TX_ABORT_SRC_TX_FLUSH_CNT_POS);
1552 }
1553 
1554 /** @} */
1555 
1556 /** @defgroup I2C_LL_EF_IT_Management IT_Management
1557  * @{
1558  */
1559 
1560 /**
1561  * @brief Enable specified interrupts.
1562  *
1563  * Register|BitsName
1564  * ---------------|---------------
1565  * INT_MASK | MASK_GEN_CALL
1566  * INT_MASK | MASK_START_DET
1567  * INT_MASK | MASK_STOP_DET
1568  * INT_MASK | MASK_ACTIVITY
1569  * INT_MASK | MASK_RX_DONE
1570  * INT_MASK | MASK_TX_ABRT
1571  * INT_MASK | MASK_RD_REQ
1572  * INT_MASK | MASK_TX_EMPTY
1573  * INT_MASK | MASK_TX_OVER
1574  * INT_MASK | MASK_RX_FULL
1575  * INT_MASK | MASK_RX_OVER
1576  * INT_MASK | MASK_RX_UNDER
1577  *
1578  * @param I2Cx I2C instance.
1579  * @param mask This parameter can be a combination of the following values:
1580  * @arg @ref LL_I2C_INTR_MASK_GEN_CALL
1581  * @arg @ref LL_I2C_INTR_MASK_START_DET
1582  * @arg @ref LL_I2C_INTR_MASK_STOP_DET
1583  * @arg @ref LL_I2C_INTR_MASK_ACTIVITY
1584  * @arg @ref LL_I2C_INTR_MASK_RX_DONE
1585  * @arg @ref LL_I2C_INTR_MASK_TX_ABRT
1586  * @arg @ref LL_I2C_INTR_MASK_RD_REQ
1587  * @arg @ref LL_I2C_INTR_MASK_TX_EMPTY
1588  * @arg @ref LL_I2C_INTR_MASK_TX_OVER
1589  * @arg @ref LL_I2C_INTR_MASK_RX_FULL
1590  * @arg @ref LL_I2C_INTR_MASK_RX_OVER
1591  * @arg @ref LL_I2C_INTR_MASK_RX_UNDER
1592  * @retval None.
1593  */
1594 __STATIC_INLINE void ll_i2c_enable_it(i2c_regs_t *I2Cx, uint32_t mask)
1595 {
1596  SET_BITS(I2Cx->INT_MASK, mask);
1597 }
1598 
1599 /**
1600  * @brief Disable specified interrupts.
1601  *
1602  * Register|BitsName
1603  * ---------------|---------------
1604  * INT_MASK | MASK_GEN_CALL
1605  * INT_MASK | MASK_START_DET
1606  * INT_MASK | MASK_STOP_DET
1607  * INT_MASK | MASK_ACTIVITY
1608  * INT_MASK | MASK_RX_DONE
1609  * INT_MASK | MASK_TX_ABRT
1610  * INT_MASK | MASK_RD_REQ
1611  * INT_MASK | MASK_TX_EMPTY
1612  * INT_MASK | MASK_TX_OVER
1613  * INT_MASK | MASK_RX_FULL
1614  * INT_MASK | MASK_RX_OVER
1615  * INT_MASK | MASK_RX_UNDER
1616  *
1617  * @param I2Cx I2C instance.
1618  * @param mask This parameter can be a combination of the following values:
1619  * @arg @ref LL_I2C_INTR_MASK_GEN_CALL
1620  * @arg @ref LL_I2C_INTR_MASK_START_DET
1621  * @arg @ref LL_I2C_INTR_MASK_STOP_DET
1622  * @arg @ref LL_I2C_INTR_MASK_ACTIVITY
1623  * @arg @ref LL_I2C_INTR_MASK_RX_DONE
1624  * @arg @ref LL_I2C_INTR_MASK_TX_ABRT
1625  * @arg @ref LL_I2C_INTR_MASK_RD_REQ
1626  * @arg @ref LL_I2C_INTR_MASK_TX_EMPTY
1627  * @arg @ref LL_I2C_INTR_MASK_TX_OVER
1628  * @arg @ref LL_I2C_INTR_MASK_RX_FULL
1629  * @arg @ref LL_I2C_INTR_MASK_RX_OVER
1630  * @arg @ref LL_I2C_INTR_MASK_RX_UNDER
1631  * @retval None.
1632  */
1633 __STATIC_INLINE void ll_i2c_disable_it(i2c_regs_t *I2Cx, uint32_t mask)
1634 {
1635  CLEAR_BITS(I2Cx->INT_MASK, mask);
1636 }
1637 
1638 /**
1639  * @brief Check if the specified interrupts are enabled or disabled.
1640  *
1641  * Register|BitsName
1642  * ---------------|---------------
1643  * INT_MASK | MASK_GEN_CALL
1644  * INT_MASK | MASK_START_DET
1645  * INT_MASK | MASK_STOP_DET
1646  * INT_MASK | MASK_ACTIVITY
1647  * INT_MASK | MASK_RX_DONE
1648  * INT_MASK | MASK_TX_ABRT
1649  * INT_MASK | MASK_RD_REQ
1650  * INT_MASK | MASK_TX_EMPTY
1651  * INT_MASK | MASK_TX_OVER
1652  * INT_MASK | MASK_RX_FULL
1653  * INT_MASK | MASK_RX_OVER
1654  * INT_MASK | MASK_RX_UNDER
1655  *
1656  * @param I2Cx I2C instance.
1657  * @param mask This parameter can be a combination of the following values:
1658  * @arg @ref LL_I2C_INTR_MASK_GEN_CALL
1659  * @arg @ref LL_I2C_INTR_MASK_START_DET
1660  * @arg @ref LL_I2C_INTR_MASK_STOP_DET
1661  * @arg @ref LL_I2C_INTR_MASK_ACTIVITY
1662  * @arg @ref LL_I2C_INTR_MASK_RX_DONE
1663  * @arg @ref LL_I2C_INTR_MASK_TX_ABRT
1664  * @arg @ref LL_I2C_INTR_MASK_RD_REQ
1665  * @arg @ref LL_I2C_INTR_MASK_TX_EMPTY
1666  * @arg @ref LL_I2C_INTR_MASK_TX_OVER
1667  * @arg @ref LL_I2C_INTR_MASK_RX_FULL
1668  * @arg @ref LL_I2C_INTR_MASK_RX_OVER
1669  * @arg @ref LL_I2C_INTR_MASK_RX_UNDER
1670  * @retval State of bit (1 or 0).
1671  */
1672 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it(i2c_regs_t *I2Cx, uint32_t mask)
1673 {
1674  return (READ_BITS(I2Cx->INT_MASK, mask) == (mask));
1675 }
1676 
1677 /**
1678  * @brief Enable SCL_STUCK_AT_LOW interrupt.
1679  *
1680  * Register|BitsName
1681  * ---------------|---------------
1682  * INT_MASK | SCL_STUCK_AT_LOW
1683  *
1684  * @param I2Cx I2C instance.
1685  * @retval None.
1686  */
1687 __STATIC_INLINE void ll_i2c_enable_it_scl_stuck_at_low(i2c_regs_t *I2Cx)
1688 {
1689  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_SCL_STUCKLOW);
1690 }
1691 /**
1692  * @brief Disable SCL_STUCK_AT_LOW interrupt.
1693  *
1694  * Register|BitsName
1695  * ---------------|---------------
1696  * INT_MASK | SCL_STUCK_AT_LOW
1697  *
1698  * @param I2Cx I2C instance.
1699  * @retval None.
1700  */
1701 __STATIC_INLINE void ll_i2c_disable_it_scl_stuck_at_low(i2c_regs_t *I2Cx)
1702 {
1703  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_SCL_STUCKLOW);
1704 }
1705 /**
1706  * @brief Check if the SCL_STUCK_AT_LOW Interrupt is enabled or disabled.
1707  *
1708  * Register|BitsName
1709  * ---------------|---------------
1710  * INT_MASK | SCL_STUCK_AT_LOW
1711  *
1712  * @param I2Cx I2C instance.
1713  * @retval State of bit (1 or 0).
1714  */
1715 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_scl_stuck_at_low(i2c_regs_t *I2Cx)
1716 {
1717  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_SCL_STUCKLOW) == (I2C_INT_MASK_MASK_SCL_STUCKLOW));
1718 }
1719 
1720 
1721 /**
1722  * @brief Enable MASTER_ON_HOLD interrupt.
1723  *
1724  * Register|BitsName
1725  * ---------------|---------------
1726  * INT_MASK | M_HOLD
1727  *
1728  * @param I2Cx I2C instance.
1729  * @retval None.
1730  */
1731 __STATIC_INLINE void ll_i2c_enable_it_master_on_hold(i2c_regs_t *I2Cx)
1732 {
1733  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_M_HOLD);
1734 }
1735 
1736 /**
1737  * @brief Disable MASTER_ON_HOLD interrupt.
1738  *
1739  * Register|BitsName
1740  * ---------------|---------------
1741  * INT_MASK | M_HOLD
1742  *
1743  * @param I2Cx I2C instance.
1744  * @retval None.
1745  */
1746 __STATIC_INLINE void ll_i2c_disable_it_master_on_hold(i2c_regs_t *I2Cx)
1747 {
1748  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_M_HOLD);
1749 }
1750 
1751 /**
1752  * @brief Check if the MASTER_ON_HOLD Interrupt is enabled or disabled.
1753  *
1754  * Register|BitsName
1755  * ---------------|---------------
1756  * INT_MASK | M_HOLD
1757  *
1758  * @param I2Cx I2C instance.
1759  * @retval State of bit (1 or 0).
1760  */
1761 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_master_on_hold(i2c_regs_t *I2Cx)
1762 {
1763  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_M_HOLD) == (I2C_INT_MASK_MASK_M_HOLD));
1764 }
1765 
1766 /**
1767  * @brief Enable RESTART_DET interrupt.
1768  *
1769  * Register|BitsName
1770  * ---------------|---------------
1771  * INT_MASK | RESTART_DET
1772  *
1773  * @param I2Cx I2C instance.
1774  * @retval None.
1775  */
1776 __STATIC_INLINE void ll_i2c_enable_it_restart_det(i2c_regs_t *I2Cx)
1777 {
1778  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RESTART_DET);
1779 }
1780 
1781 /**
1782  * @brief Disable RESTART_DET interrupt.
1783  *
1784  * Register|BitsName
1785  * ---------------|---------------
1786  * INT_MASK | RESTART_DET
1787  *
1788  * @param I2Cx I2C instance.
1789  * @retval None.
1790  */
1791 __STATIC_INLINE void ll_i2c_disable_it_restart_det(i2c_regs_t *I2Cx)
1792 {
1793  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RESTART_DET);
1794 }
1795 
1796 /**
1797  * @brief Check if the RESTART_DET Interrupt is enabled or disabled.
1798  *
1799  * Register|BitsName
1800  * ---------------|---------------
1801  * INT_MASK | RESTART_DET
1802  *
1803  * @param I2Cx I2C instance.
1804  * @retval State of bit (1 or 0).
1805  */
1806 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_restart_det(i2c_regs_t *I2Cx)
1807 {
1808  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RESTART_DET) == (I2C_INT_MASK_MASK_RESTART_DET));
1809 }
1810 
1811 /**
1812  * @brief Enable GEN_CALL interrupt.
1813  *
1814  * Register|BitsName
1815  * ---------------|---------------
1816  * INT_MASK | GEN_CALL
1817  *
1818  * @param I2Cx I2C instance.
1819  * @retval None.
1820  */
1821 __STATIC_INLINE void ll_i2c_enable_it_gen_call(i2c_regs_t *I2Cx)
1822 {
1823  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_GEN_CALL);
1824 }
1825 
1826 /**
1827  * @brief Disable GEN_CALL interrupt.
1828  *
1829  * Register|BitsName
1830  * ---------------|---------------
1831  * INT_MASK | GEN_CALL
1832  *
1833  * @param I2Cx I2C instance.
1834  * @retval None.
1835  */
1836 __STATIC_INLINE void ll_i2c_disable_it_gen_call(i2c_regs_t *I2Cx)
1837 {
1838  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_GEN_CALL);
1839 }
1840 
1841 /**
1842  * @brief Check if GEN_CALL interrupt is enabled or disabled.
1843  *
1844  * Register|BitsName
1845  * ---------------|---------------
1846  * INT_MASK | GEN_CALL
1847  *
1848  * @param I2Cx I2C instance.
1849  * @retval State of bit (1 or 0).
1850  */
1851 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_gen_call(i2c_regs_t *I2Cx)
1852 {
1853  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_GEN_CALL) == (I2C_INT_MASK_MASK_GEN_CALL));
1854 }
1855 
1856 /**
1857  * @brief Enable START_DET received interrupt.
1858  *
1859  * Register|BitsName
1860  * ---------------|---------------
1861  * INT_MASK | START_DET
1862  *
1863  * @param I2Cx I2C instance.
1864  * @retval None.
1865  */
1866 __STATIC_INLINE void ll_i2c_enable_it_start_det(i2c_regs_t *I2Cx)
1867 {
1868  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_START_DET);
1869 }
1870 
1871 /**
1872  * @brief Disable START_DET received interrupt.
1873  *
1874  * Register|BitsName
1875  * ---------------|---------------
1876  * INT_MASK | START_DET
1877  *
1878  * @param I2Cx I2C instance.
1879  * @retval None.
1880  */
1881 __STATIC_INLINE void ll_i2c_disable_it_start_det(i2c_regs_t *I2Cx)
1882 {
1883  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_START_DET);
1884 }
1885 
1886 /**
1887  * @brief Check if START_DET received interrupt is enabled or disabled.
1888  *
1889  * Register|BitsName
1890  * ---------------|---------------
1891  * INT_MASK | START_DET
1892  *
1893  * @param I2Cx I2C instance.
1894  * @retval State of bit (1 or 0).
1895  */
1896 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_start_det(i2c_regs_t *I2Cx)
1897 {
1898  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_START_DET) == (I2C_INT_MASK_MASK_START_DET));
1899 }
1900 
1901 /**
1902  * @brief Enable STOP_DET interrupt.
1903  *
1904  * Register|BitsName
1905  * ---------------|---------------
1906  * INT_MASK | STOP_DET
1907  *
1908  * @param I2Cx I2C instance.
1909  * @retval None.
1910  */
1911 __STATIC_INLINE void ll_i2c_enable_it_stop_det(i2c_regs_t *I2Cx)
1912 {
1913  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_STOP_DET);
1914 }
1915 
1916 /**
1917  * @brief Disable STOP_DET interrupt.
1918  *
1919  * Register|BitsName
1920  * ---------------|---------------
1921  * INT_MASK | STOP_DET
1922  *
1923  * @param I2Cx I2C instance.
1924  * @retval None.
1925  */
1926 __STATIC_INLINE void ll_i2c_disable_it_stop_det(i2c_regs_t *I2Cx)
1927 {
1928  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_STOP_DET);
1929 }
1930 
1931 /**
1932  * @brief Check if STOP_DET interrupt is enabled or disabled.
1933  *
1934  * Register|BitsName
1935  * ---------------|---------------
1936  * INT_MASK | STOP_DET
1937  *
1938  * @param I2Cx I2C instance.
1939  * @retval State of bit (1 or 0).
1940  */
1941 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_stop_det(i2c_regs_t *I2Cx)
1942 {
1943  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_STOP_DET) == (I2C_INT_MASK_MASK_STOP_DET));
1944 }
1945 
1946 /**
1947  * @brief Enable ACTIVITY interrupt.
1948  *
1949  * Register|BitsName
1950  * ---------------|---------------
1951  * INT_MASK | ACTIVITY
1952  *
1953  * @param I2Cx I2C instance.
1954  * @retval None.
1955  */
1956 __STATIC_INLINE void ll_i2c_enable_it_activity(i2c_regs_t *I2Cx)
1957 {
1958  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_ACTIVITY);
1959 }
1960 
1961 /**
1962  * @brief Disable ACTIVITY interrupt.
1963  *
1964  * Register|BitsName
1965  * ---------------|---------------
1966  * INT_MASK | ACTIVITY
1967  *
1968  * @param I2Cx I2C instance.
1969  * @retval None.
1970  */
1971 __STATIC_INLINE void ll_i2c_disable_it_activity(i2c_regs_t *I2Cx)
1972 {
1973  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_ACTIVITY);
1974 }
1975 
1976 /**
1977  * @brief Check if ACTIVITY interrupt is enabled or disabled.
1978  *
1979  * Register|BitsName
1980  * ---------------|---------------
1981  * INT_MASK | ACTIVITY
1982  *
1983  * @param I2Cx I2C instance.
1984  * @retval State of bit (1 or 0).
1985  */
1986 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_activity(i2c_regs_t *I2Cx)
1987 {
1988  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_ACTIVITY) == (I2C_INT_MASK_MASK_ACTIVITY));
1989 }
1990 
1991 /**
1992  * @brief Enable RX_DONE interrupt.
1993  *
1994  * Register|BitsName
1995  * ---------------|---------------
1996  * INT_MASK | RX_DONE
1997  *
1998  * @param I2Cx I2C instance.
1999  * @retval State of bit (1 or 0).
2000  */
2001 __STATIC_INLINE void ll_i2c_enable_it_rx_done(i2c_regs_t *I2Cx)
2002 {
2003  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_DONE);
2004 }
2005 
2006 /**
2007  * @brief Disable RX_DONE interrupt.
2008  *
2009  * Register|BitsName
2010  * ---------------|---------------
2011  * INT_MASK | RX_DONE
2012  *
2013  * @param I2Cx I2C instance.
2014  * @retval None.
2015  */
2016 __STATIC_INLINE void ll_i2c_disable_it_rx_done(i2c_regs_t *I2Cx)
2017 {
2018  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_DONE);
2019 }
2020 
2021 /**
2022  * @brief Check if RX_DONE interrupt is enabled or disabled.
2023  *
2024  * Register|BitsName
2025  * ---------------|---------------
2026  * INT_MASK | RX_DONE
2027  *
2028  * @param I2Cx I2C instance.
2029  * @retval State of bit (1 or 0).
2030  */
2031 __STATIC_INLINE uint32_t ll_i2c_is_enable_it_rx_done(i2c_regs_t *I2Cx)
2032 {
2033  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_DONE) == (I2C_INT_MASK_MASK_RX_DONE));
2034 }
2035 
2036 /**
2037  * @brief Enable TX_ABRT interrupt.
2038  *
2039  * Register|BitsName
2040  * ---------------|---------------
2041  * INT_MASK | TX_ABORT
2042  *
2043  * @param I2Cx I2C instance.
2044  * @retval None.
2045  */
2046 __STATIC_INLINE void ll_i2c_enable_it_rx_abort(i2c_regs_t *I2Cx)
2047 {
2048  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_ABORT);
2049 }
2050 
2051 /**
2052  * @brief Disable TX_ABRT interrupt.
2053  *
2054  * Register|BitsName
2055  * ---------------|---------------
2056  * INT_MASK | TX_ABORT
2057  *
2058  * @param I2Cx I2C instance.
2059  * @retval None.
2060  */
2061 __STATIC_INLINE void ll_i2c_disable_it_tx_abort(i2c_regs_t *I2Cx)
2062 {
2063  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_ABORT);
2064 }
2065 
2066 /**
2067  * @brief Check if TX_ABRT interrupt is enabled or disabled.
2068  *
2069  * Register|BitsName
2070  * ---------------|---------------
2071  * INT_MASK | TX_ABORT
2072  *
2073  * @param I2Cx I2C instance.
2074  * @retval None.
2075  */
2076 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_tx_abort(i2c_regs_t *I2Cx)
2077 {
2078  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_ABORT) == (I2C_INT_MASK_MASK_TX_ABORT));
2079 }
2080 
2081 /**
2082  * @brief Enable RD_REQ interrupt.
2083  *
2084  * Register|BitsName
2085  * ---------------|---------------
2086  * INT_MASK | RD_REQ
2087  *
2088  * @param I2Cx I2C instance.
2089  * @retval None.
2090  */
2091 __STATIC_INLINE void ll_i2c_enable_it_read_req(i2c_regs_t *I2Cx)
2092 {
2093  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RD_REQ);
2094 }
2095 
2096 /**
2097  * @brief Disable RD_REQ interrupt.
2098  *
2099  * Register|BitsName
2100  * ---------------|---------------
2101  * INT_MASK | RD_REQ
2102  *
2103  * @param I2Cx I2C instance.
2104  * @retval None.
2105  */
2106 __STATIC_INLINE void ll_i2c_disable_it_read_req(i2c_regs_t *I2Cx)
2107 {
2108  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RD_REQ);
2109 }
2110 
2111 /**
2112  * @brief Check if RD_REQ interrupt is enabled or disabled.
2113  *
2114  * Register|BitsName
2115  * ---------------|---------------
2116  * INT_MASK | RD_REQ
2117  *
2118  * @param I2Cx I2C instance.
2119  * @retval State of bit (1 or 0).
2120  */
2121 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_read_req(i2c_regs_t *I2Cx)
2122 {
2123  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RD_REQ) == (I2C_INT_MASK_MASK_RD_REQ));
2124 }
2125 
2126 /**
2127  * @brief Enable TX_EMPTY interrupt.
2128  *
2129  * Register|BitsName
2130  * ---------------|---------------
2131  * INT_MASK | TX_EMPTY
2132  *
2133  * @param I2Cx I2C instance.
2134  * @retval None.
2135  */
2136 __STATIC_INLINE void ll_i2c_enable_it_tx_empty(i2c_regs_t *I2Cx)
2137 {
2138  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_EMPTY);
2139 }
2140 
2141 /**
2142  * @brief Disable TX_EMPTY interrupt.
2143  *
2144  * Register|BitsName
2145  * ---------------|---------------
2146  * INT_MASK | TX_EMPTY
2147  *
2148  * @param I2Cx I2C instance.
2149  * @retval None.
2150  */
2151 __STATIC_INLINE void ll_i2c_disable_it_tx_empty(i2c_regs_t *I2Cx)
2152 {
2153  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_EMPTY);
2154 }
2155 
2156 /**
2157  * @brief Check if TX_EMPTY interrupt is enabled or disabled.
2158  *
2159  * Register|BitsName
2160  * ---------------|---------------
2161  * INT_MASK | TX_EMPTY
2162  *
2163  * @param I2Cx I2C instance.
2164  * @retval State of bit (1 or 0).
2165  */
2166 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_tx_empty(i2c_regs_t *I2Cx)
2167 {
2168  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_EMPTY) == (I2C_INT_MASK_MASK_TX_EMPTY));
2169 }
2170 
2171 /**
2172  * @brief Enable TX_OVER interrupt.
2173  *
2174  * Register|BitsName
2175  * ---------------|---------------
2176  * INT_MASK | TX_OVER
2177  *
2178  * @param I2Cx I2C instance.
2179  * @retval None.
2180  */
2181 __STATIC_INLINE void ll_i2c_enable_it_tx_over(i2c_regs_t *I2Cx)
2182 {
2183  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_OVER);
2184 }
2185 
2186 /**
2187  * @brief Disable TX_OVER interrupt.
2188  *
2189  * Register|BitsName
2190  * ---------------|---------------
2191  * INT_MASK | TX_OVER
2192  *
2193  * @param I2Cx I2C instance.
2194  * @retval None.
2195  */
2196 __STATIC_INLINE void ll_i2c_disable_it_tx_over(i2c_regs_t *I2Cx)
2197 {
2198  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_OVER);
2199 }
2200 
2201 /**
2202  * @brief Check if TX_OVER interrupt is enabled or disabled.
2203  *
2204  * Register|BitsName
2205  * ---------------|---------------
2206  * INT_MASK | TX_OVER
2207  *
2208  * @param I2Cx I2C instance.
2209  * @retval State of bit (1 or 0).
2210  */
2211 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_tx_over(i2c_regs_t *I2Cx)
2212 {
2213  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_TX_OVER) == (I2C_INT_MASK_MASK_TX_OVER));
2214 }
2215 
2216 /**
2217  * @brief Enable RX_FULL interrupt.
2218  *
2219  * Register|BitsName
2220  * ---------------|---------------
2221  * INT_MASK | RX_FULL
2222  *
2223  * @param I2Cx I2C instance.
2224  * @retval None.
2225  */
2226 __STATIC_INLINE void ll_i2c_enable_it_rx_full(i2c_regs_t *I2Cx)
2227 {
2228  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_FULL);
2229 }
2230 
2231 /**
2232  * @brief Disable RX_FULL interrupt.
2233  *
2234  * Register|BitsName
2235  * ---------------|---------------
2236  * INT_MASK | RX_FULL
2237  *
2238  * @param I2Cx I2C instance.
2239  * @retval None.
2240  */
2241 __STATIC_INLINE void ll_i2c_disbale_it_rx_full(i2c_regs_t *I2Cx)
2242 {
2243  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_FULL);
2244 }
2245 
2246 /**
2247  * @brief Check if RX_FULL interrupt is enabled or disabled.
2248  *
2249  * Register|BitsName
2250  * ---------------|---------------
2251  * INT_MASK | RX_FULL
2252  *
2253  * @param I2Cx I2C instance.
2254  * @retval None.
2255  */
2256 __STATIC_INLINE uint32_t ll_i2c_ls_enabled_it_rx_full(i2c_regs_t *I2Cx)
2257 {
2258  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_FULL) == (I2C_INT_MASK_MASK_RX_FULL));
2259 }
2260 
2261 /**
2262  * @brief Enable RX_OVER interrupt.
2263  *
2264  * Register|BitsName
2265  * ---------------|---------------
2266  * INT_MASK | RX_OVER
2267  *
2268  * @param I2Cx I2C instance.
2269  * @retval None.
2270  */
2271 __STATIC_INLINE void ll_i2c_enable_it_rx_over(i2c_regs_t *I2Cx)
2272 {
2273  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_OVER);
2274 }
2275 
2276 /**
2277  * @brief Disable RX_OVER interrupt.
2278  *
2279  * Register|BitsName
2280  * ---------------|---------------
2281  * INT_MASK | RX_OVER
2282  *
2283  * @param I2Cx I2C instance.
2284  * @retval None.
2285  */
2286 __STATIC_INLINE void ll_i2c_disable_it_rx_over(i2c_regs_t *I2Cx)
2287 {
2288  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_OVER);
2289 }
2290 
2291 /**
2292  * @brief Check if RX_OVER interrupt is enabled or disabled.
2293  *
2294  * Register|BitsName
2295  * ---------------|---------------
2296  * INT_MASK | RX_OVER
2297  *
2298  * @param I2Cx I2C instance.
2299  * @retval None.
2300  */
2301 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_rx_over(i2c_regs_t *I2Cx)
2302 {
2303  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_OVER) == (I2C_INT_MASK_MASK_RX_OVER));
2304 }
2305 
2306 /**
2307  * @brief Enable RX_UNDER interrupt.
2308  *
2309  * Register|BitsName
2310  * ---------------|---------------
2311  * INT_MASK | RX_UNDER
2312  *
2313  * @param I2Cx I2C instance.
2314  * @retval None.
2315  */
2316 __STATIC_INLINE void ll_i2c_enable_it_rx_under(i2c_regs_t *I2Cx)
2317 {
2318  SET_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_UNDER);
2319 }
2320 
2321 /**
2322  * @brief Disable RX_UNDER interrupt.
2323  *
2324  * Register|BitsName
2325  * ---------------|---------------
2326  * INT_MASK | RX_UNDER
2327  *
2328  * @param I2Cx I2C instance.
2329  * @retval None.
2330  */
2331 __STATIC_INLINE void ll_i2c_disable_it_rx_under(i2c_regs_t *I2Cx)
2332 {
2333  CLEAR_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_UNDER);
2334 }
2335 
2336 /**
2337  * @brief Check if RX_UNDER interrupt is enabled or disabled.
2338  *
2339  * Register|BitsName
2340  * ---------------|---------------
2341  * INT_MASK | RX_UNDER
2342  *
2343  * @param I2Cx I2C instance.
2344  * @retval None.
2345  */
2346 __STATIC_INLINE uint32_t ll_i2c_is_enabled_it_rx_under(i2c_regs_t *I2Cx)
2347 {
2348  return (READ_BITS(I2Cx->INT_MASK, I2C_INT_MASK_MASK_RX_UNDER) == (I2C_INT_MASK_MASK_RX_UNDER));
2349 }
2350 
2351 /** @} */
2352 
2353 /** @defgroup I2C_LL_EF_FLAG_management FLAG_management
2354  * @{
2355  */
2356 
2357 /**
2358  * @brief Get I2C interrupt flags
2359  *
2360  * Register|BitsName
2361  * ---------------|---------------
2362  * INT_STAT | MST_ON_HOLD
2363  * INT_STAT | RESTART_DET
2364  * INT_STAT | GEN_CALL
2365  * INT_STAT | START_DET
2366  * INT_STAT | STOP_DET
2367  * INT_STAT | ACTIVITY
2368  * INT_STAT | RX_DONE
2369  * INT_STAT | TX_ABRT
2370  * INT_STAT | RD_REQ
2371  * INT_STAT | TX_EMPTY
2372  * INT_STAT | TX_OVER
2373  * INT_STAT | RX_FULL
2374  * INT_STAT | RX_OVER
2375  * INT_STAT | RX_UNDER
2376  *
2377  * @param I2Cx I2C instance.
2378  * @retval Returned value can be one or combination of the following values:
2379  * @arg @ref LL_I2C_INTR_STAT_MST_ON_HOLD
2380  * @arg @ref LL_I2C_INTR_STAT_RESTART_DET
2381  * @arg @ref LL_I2C_INTR_STAT_GEN_CALL
2382  * @arg @ref LL_I2C_INTR_STAT_START_DET
2383  * @arg @ref LL_I2C_INTR_STAT_STOP_DET
2384  * @arg @ref LL_I2C_INTR_STAT_ACTIVITY
2385  * @arg @ref LL_I2C_INTR_STAT_RX_DONE
2386  * @arg @ref LL_I2C_INTR_STAT_TX_ABRT
2387  * @arg @ref LL_I2C_INTR_STAT_RD_REQ
2388  * @arg @ref LL_I2C_INTR_STAT_TX_EMPTY
2389  * @arg @ref LL_I2C_INTR_STAT_TX_OVER
2390  * @arg @ref LL_I2C_INTR_STAT_RX_FULL
2391  * @arg @ref LL_I2C_INTR_STAT_RX_OVER
2392  * @arg @ref LL_I2C_INTR_STAT_RX_UNDER
2393  */
2394 __STATIC_INLINE uint32_t ll_i2c_get_it_flag(i2c_regs_t *I2Cx)
2395 {
2396  return (uint32_t)(READ_REG(I2Cx->INT_STAT));
2397 }
2398 
2399 /**
2400  * @brief Get I2C RAW interrupt flags
2401  *
2402  * Register|BitsName
2403  * ---------------|---------------
2404  * RAW_INT_STAT | MST_ON_HOLD
2405  * RAW_INT_STAT | RESTART_DET
2406  * RAW_INT_STAT | GEN_CALL
2407  * RAW_INT_STAT | START_DET
2408  * RAW_INT_STAT | STOP_DET
2409  * RAW_INT_STAT | ACTIVITY
2410  * RAW_INT_STAT | RX_DONE
2411  * RAW_INT_STAT | TX_ABRT
2412  * RAW_INT_STAT | RD_REQ
2413  * RAW_INT_STAT | TX_EMPTY
2414  * RAW_INT_STAT | TX_OVER
2415  * RAW_INT_STAT | RX_FULL
2416  * RAW_INT_STAT | RX_OVER
2417  * RAW_INT_STAT | RX_UNDER
2418  *
2419  * @param I2Cx I2C instance.
2420  * @retval Returned value can be one or combination of the following values:
2421  * @arg @ref LL_I2C_INTR_STAT_MST_ON_HOLD
2422  * @arg @ref LL_I2C_INTR_STAT_RESTART_DET
2423  * @arg @ref LL_I2C_INTR_STAT_GEN_CALL
2424  * @arg @ref LL_I2C_INTR_STAT_START_DET
2425  * @arg @ref LL_I2C_INTR_STAT_STOP_DET
2426  * @arg @ref LL_I2C_INTR_STAT_ACTIVITY
2427  * @arg @ref LL_I2C_INTR_STAT_RX_DONE
2428  * @arg @ref LL_I2C_INTR_STAT_TX_ABRT
2429  * @arg @ref LL_I2C_INTR_STAT_RD_REQ
2430  * @arg @ref LL_I2C_INTR_STAT_TX_EMPTY
2431  * @arg @ref LL_I2C_INTR_STAT_TX_OVER
2432  * @arg @ref LL_I2C_INTR_STAT_RX_FULL
2433  * @arg @ref LL_I2C_INTR_STAT_RX_OVER
2434  * @arg @ref LL_I2C_INTR_STAT_RX_UNDER
2435  */
2436 __STATIC_INLINE uint32_t ll_i2c_get_raw_it_flag(i2c_regs_t *I2Cx)
2437 {
2438  return (uint32_t)(READ_REG(I2Cx->RAW_INT_STAT));
2439 }
2440 
2441 /**
2442  * @brief Indicate the status of SCL_STUCK_AT_LOW flag.
2443  * @note RESET: Clear default value.
2444  * SET : When SCL_STUCK_AT_LOW interrupt is actived.
2445  *
2446  * Register|BitsName
2447  * ---------------|---------------
2448  * INT_STAT | SCL_STUCK_AT_LOW
2449  *
2450  * @param I2Cx I2C instance.
2451  * @retval State of bit (1 or 0).
2452  */
2453 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_scl_stuck_at_low(i2c_regs_t *I2Cx)
2454 {
2455  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_SCL_STUCKLOW) == (I2C_INT_STAT_RAW_SCL_STUCKLOW));
2456 }
2457 
2458 /**
2459  * @brief Indicate the status of RAW_SCL_STUCK_AT_LOW flag.
2460  * @note RESET: Clear default value.
2461  * SET : When unmasked RAW_SCL_STUCK_AT_LOW interrupt is actived.
2462  *
2463  * Register|BitsName
2464  * ---------------|---------------
2465  * RAW_INT_STAT | RAW_SCL_STUCK_AT_LOW
2466  *
2467  * @param I2Cx I2C instance.
2468  * @retval State of bit (1 or 0).
2469  */
2470 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_scl_stuck_at_low(i2c_regs_t *I2Cx)
2471 {
2472  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_SCL_STUCKLOW) == (I2C_RAW_INT_STAT_SCL_STUCKLOW));
2473 }
2474 
2475 /**
2476  * @brief Indicate the status of MST_ON_HOLD flag.
2477  * @note RESET: Clear default value.
2478  * SET : When MST_ON_HOLD interrupt is actived.
2479  *
2480  * Register|BitsName
2481  * ---------------|---------------
2482  * INT_STAT | M_HOLD
2483  *
2484  * @param I2Cx I2C instance.
2485  * @retval State of bit (1 or 0).
2486  */
2487 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_master_on_hold(i2c_regs_t *I2Cx)
2488 {
2489  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_M_HOLD) == (I2C_INT_STAT_RAW_M_HOLD));
2490 }
2491 
2492 /**
2493  * @brief Indicate the status of RAW_MST_ON_HOLD flag.
2494  * @note RESET: Clear default value.
2495  * SET : When unmasked MST_ON_HOLD interrupt is actived.
2496  *
2497  * Register|BitsName
2498  * ---------------|---------------
2499  * RAW_INT_STAT | M_HOLD
2500  *
2501  * @param I2Cx I2C instance.
2502  * @retval State of bit (1 or 0).
2503  */
2504 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_master_on_hold(i2c_regs_t *I2Cx)
2505 {
2506  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_M_HOLD) == (I2C_RAW_INT_STAT_M_HOLD));
2507 }
2508 
2509 /**
2510  * @brief Indicate the status of RESTART_DET flag.
2511  * @note RESET: Clear default value.
2512  * SET : When masked RESTART_DET interrupt is actived.
2513  *
2514  * Register|BitsName
2515  * ---------------|---------------
2516  * INT_STAT | RESTART_DET
2517  *
2518  * @param I2Cx I2C instance.
2519  * @retval State of bit (1 or 0).
2520  */
2521 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_restart_det(i2c_regs_t *I2Cx)
2522 {
2523  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_RESTART_DET) == (I2C_INT_STAT_RAW_RESTART_DET));
2524 }
2525 
2526 /**
2527  * @brief Indicate the status of RAW_RESTART_DET flag.
2528  * @note RESET: Clear default value.
2529  * SET : When unmasked RESTART_DET interrupt is actived.
2530  *
2531  * Register|BitsName
2532  * ---------------|---------------
2533  * RAW_INT_STAT | RESTART_DET
2534  *
2535  * @param I2Cx I2C instance.
2536  * @retval State of bit (1 or 0).
2537  */
2538 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_restart_det(i2c_regs_t *I2Cx)
2539 {
2540  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_RESTART_DET) == (I2C_RAW_INT_STAT_RESTART_DET));
2541 }
2542 
2543 /**
2544  * @brief Indicate the status of GEN_CALL flag.
2545  * @note RESET: Clear default value.
2546  * SET : When masked GEN_CALL interrupt is actived.
2547  *
2548  * Register|BitsName
2549  * ---------------|---------------
2550  * INT_STAT | GEN_CALL
2551  *
2552  * @param I2Cx I2C instance.
2553  * @retval State of bit (1 or 0).
2554  */
2555 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_gen_call(i2c_regs_t *I2Cx)
2556 {
2557  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_GEN_CALL) == (I2C_INT_STAT_RAW_GEN_CALL));
2558 }
2559 
2560 /**
2561  * @brief Indicate the status of RAW_GEN_CALL flag.
2562  * @note RESET: Clear default value.
2563  * SET : When unmasked GEN_CALL interrupt is actived.
2564  *
2565  * Register|BitsName
2566  * ---------------|---------------
2567  * RAW_INT_STAT | GEN_CALL
2568  *
2569  * @param I2Cx I2C instance.
2570  * @retval State of bit (1 or 0).
2571  */
2572 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_gen_call(i2c_regs_t *I2Cx)
2573 {
2574  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_GEN_CALL) == (I2C_RAW_INT_STAT_GEN_CALL));
2575 }
2576 
2577 /**
2578  * @brief Indicate the status of START_DET flag.
2579  * @note RESET: Clear default value.
2580  * SET : When masked START_DET interrupt is actived.
2581  *
2582  * Register|BitsName
2583  * ---------------|---------------
2584  * INT_STAT | START_DET
2585  *
2586  * @param I2Cx I2C instance.
2587  * @retval State of bit (1 or 0).
2588  */
2589 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_start_det(i2c_regs_t *I2Cx)
2590 {
2591  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_START_DET) == (I2C_INT_STAT_RAW_START_DET));
2592 }
2593 
2594 /**
2595  * @brief Indicate the status of RAW_START_DET flag.
2596  * @note RESET: Clear default value.
2597  * SET : When unmasked START_DET interrupt is actived.
2598  *
2599  * Register|BitsName
2600  * ---------------|---------------
2601  * RAW_INT_STAT | START_DET
2602  *
2603  * @param I2Cx I2C instance.
2604  * @retval State of bit (1 or 0).
2605  */
2606 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_start_det(i2c_regs_t *I2Cx)
2607 {
2608  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_START_DET) == (I2C_RAW_INT_STAT_START_DET));
2609 }
2610 
2611 /**
2612  * @brief Indicate the status of STOP_DET flag.
2613  * @note RESET: Clear default value.
2614  * SET : When masked STOP_DET interrupt is actived.
2615  *
2616  * Register|BitsName
2617  * ---------------|---------------
2618  * INT_STAT | STOP_DET
2619  *
2620  * @param I2Cx I2C instance.
2621  * @retval State of bit (1 or 0).
2622  */
2623 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_stop_det(i2c_regs_t *I2Cx)
2624 {
2625  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_STOP_DET) == (I2C_INT_STAT_RAW_STOP_DET));
2626 }
2627 
2628 /**
2629  * @brief Indicate the status of RAW_STOP_DET flag.
2630  * @note RESET: Clear default value.
2631  * SET : When unmasked STOP_DET interrupt is actived.
2632  *
2633  * Register|BitsName
2634  * ---------------|---------------
2635  * RAW_INT_STAT | STOP_DET
2636  *
2637  * @param I2Cx I2C instance.
2638  * @retval State of bit (1 or 0).
2639  */
2640 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_stop_det(i2c_regs_t *I2Cx)
2641 {
2642  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_STOP_DET) == (I2C_RAW_INT_STAT_STOP_DET));
2643 }
2644 
2645 /**
2646  * @brief Indicate the status of ACTIVITY flag.
2647  * @note RESET: Clear default value.
2648  * SET : When masked ACTIVITY interrupt is actived.
2649  *
2650  * Register|BitsName
2651  * ---------------|---------------
2652  * INT_STAT | ACTIVITY
2653  *
2654  * @param I2Cx I2C instance.
2655  * @retval State of bit (1 or 0).
2656  */
2657 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_activity(i2c_regs_t *I2Cx)
2658 {
2659  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_ACTIVITY) == (I2C_INT_STAT_RAW_ACTIVITY));
2660 }
2661 
2662 /**
2663  * @brief Indicate the status of RAW_ACTIVITY flag.
2664  * @note RESET: Clear default value.
2665  * SET : When unmasked ACTIVITY interrupt is actived.
2666  *
2667  * Register|BitsName
2668  * ---------------|---------------
2669  * RAW_INT_STAT | ACTIVITY
2670  *
2671  * @param I2Cx I2C instance.
2672  * @retval State of bit (1 or 0).
2673  */
2674 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_activity(i2c_regs_t *I2Cx)
2675 {
2676  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_ACTIVITY) == (I2C_RAW_INT_STAT_ACTIVITY));
2677 }
2678 
2679 /**
2680  * @brief Indicate the status of RX_DONE flag.
2681  * @note RESET: Clear default value.
2682  * SET : When masked RX_DONE interrupt is actived.
2683  *
2684  * Register|BitsName
2685  * ---------------|---------------
2686  * INT_STAT | RX_DONE
2687  *
2688  * @param I2Cx I2C instance.
2689  * @retval State of bit (1 or 0).
2690  */
2691 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_done(i2c_regs_t *I2Cx)
2692 {
2693  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_RX_DONE) == (I2C_INT_STAT_RAW_RX_DONE));
2694 }
2695 
2696 /**
2697  * @brief Indicate the status of RAW_RX_DONE flag.
2698  * @note RESET: Clear default value.
2699  * SET : When unmasked RX_DONE interrupt is actived.
2700  *
2701  * Register|BitsName
2702  * ---------------|---------------
2703  * RAW_INT_STAT | RX_DONE
2704  *
2705  * @param I2Cx I2C instance.
2706  * @retval State of bit (1 or 0).
2707  */
2708 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_done(i2c_regs_t *I2Cx)
2709 {
2710  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_RX_DONE) == (I2C_RAW_INT_STAT_RX_DONE));
2711 }
2712 
2713 /**
2714  * @brief Indicate the status of TX_ABRT flag.
2715  * @note RESET: Clear default value.
2716  * SET : When masked TX_ABRT interrupt is actived.
2717  *
2718  * Register|BitsName
2719  * ---------------|---------------
2720  * INT_STAT | TX_ABORT
2721  *
2722  * @param I2Cx I2C instance.
2723  * @retval State of bit (1 or 0).
2724  */
2725 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_tx_abort(i2c_regs_t *I2Cx)
2726 {
2727  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_TX_ABORT) == (I2C_INT_STAT_RAW_TX_ABORT));
2728 }
2729 
2730 /**
2731  * @brief Indicate the status of RAW_TX_ABRT flag.
2732  * @note RESET: Clear default value.
2733  * SET : When unmasked TX_ABRT interrupt is actived.
2734  *
2735  * Register|BitsName
2736  * ---------------|---------------
2737  * RAW_INT_STAT | TX_ABORT
2738  *
2739  * @param I2Cx I2C instance.
2740  * @retval State of bit (1 or 0).
2741  */
2742 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_tx_abort(i2c_regs_t *I2Cx)
2743 {
2744  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_TX_ABORT) == (I2C_RAW_INT_STAT_TX_ABORT));
2745 }
2746 
2747 /**
2748  * @brief Indicate the status of RD_REQ flag.
2749  * @note RESET: Clear default value.
2750  * SET : When masked RD_REQ interrupt is actived.
2751  *
2752  * Register|BitsName
2753  * ---------------|---------------
2754  * INT_STAT | RD_REQ
2755  *
2756  * @param I2Cx I2C instance.
2757  * @retval State of bit (1 or 0).
2758  */
2759 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_read_req(i2c_regs_t *I2Cx)
2760 {
2761  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_RD_REQ) == (I2C_INT_STAT_RAW_RD_REQ));
2762 }
2763 
2764 /**
2765  * @brief Indicate the status of RAW_RD_REQ flag.
2766  * @note RESET: Clear default value.
2767  * SET : When unmasked RD_REQ interrupt is actived.
2768  *
2769  * Register|BitsName
2770  * ---------------|---------------
2771  * RAW_INT_STAT | RD_REQ
2772  *
2773  * @param I2Cx I2C instance.
2774  * @retval State of bit (1 or 0).
2775  */
2776 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_read_req(i2c_regs_t *I2Cx)
2777 {
2778  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_RD_REQ) == (I2C_RAW_INT_STAT_RD_REQ));
2779 }
2780 
2781 /**
2782  * @brief Indicate the status of TX_EMPTY flag.
2783  * @note RESET: Clear default value.
2784  * SET : When masked TX_EMPTY interrupt is actived.
2785  *
2786  * Register|BitsName
2787  * ---------------|---------------
2788  * INT_STAT | TX_EMPTY
2789  *
2790  * @param I2Cx I2C instance.
2791  * @retval State of bit (1 or 0).
2792  */
2793 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_tx_empty(i2c_regs_t *I2Cx)
2794 {
2795  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_TX_EMPTY) == (I2C_INT_STAT_RAW_TX_EMPTY));
2796 }
2797 
2798 /**
2799  * @brief Indicate the status of RAW_TX_EMPTY flag.
2800  * @note RESET: Clear default value.
2801  * SET : When unmasked TX_EMPTY interrupt is actived.
2802  *
2803  * Register|BitsName
2804  * ---------------|---------------
2805  * RAW_INT_STAT | TX_EMPTY
2806  *
2807  * @param I2Cx I2C instance.
2808  * @retval State of bit (1 or 0).
2809  */
2810 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_tx_empty(i2c_regs_t *I2Cx)
2811 {
2812  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_TX_EMPTY) == (I2C_RAW_INT_STAT_TX_EMPTY));
2813 }
2814 
2815 /**
2816  * @brief Indicate the status of TX_OVER flag.
2817  * @note RESET: Clear default value.
2818  * SET : When masked TX_OVER interrupt is actived.
2819  *
2820  * Register|BitsName
2821  * ---------------|---------------
2822  * INT_STAT | TX_OVER
2823  *
2824  * @param I2Cx I2C instance.
2825  * @retval State of bit (1 or 0).
2826  */
2827 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_tx_over(i2c_regs_t *I2Cx)
2828 {
2829  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_TX_OVER) == (I2C_INT_STAT_RAW_TX_OVER));
2830 }
2831 
2832 /**
2833  * @brief Indicate the status of RAW_TX_OVER flag.
2834  * @note RESET: Clear default value.
2835  * SET : When unmasked TX_OVER interrupt is actived.
2836  *
2837  * Register|BitsName
2838  * ---------------|---------------
2839  * RAW_INT_STAT | TX_OVER
2840  *
2841  * @param I2Cx I2C instance.
2842  * @retval State of bit (1 or 0).
2843  */
2844 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_tx_over(i2c_regs_t *I2Cx)
2845 {
2846  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_TX_OVER) == (I2C_RAW_INT_STAT_TX_OVER));
2847 }
2848 
2849 /**
2850  * @brief Indicate the status of RX_FULL flag.
2851  * @note RESET: Clear default value.
2852  * SET : When masked RX_FULL interrupt is actived.
2853  *
2854  * Register|BitsName
2855  * ---------------|---------------
2856  * INT_STAT | RX_FULL
2857  *
2858  * @param I2Cx I2C instance.
2859  * @retval State of bit (1 or 0).
2860  */
2861 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_full(i2c_regs_t *I2Cx)
2862 {
2863  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_RX_FULL) == (I2C_INT_STAT_RAW_RX_FULL));
2864 }
2865 
2866 /**
2867  * @brief Indicate the status of RAW_RX_FULL flag.
2868  * @note RESET: Clear default value.
2869  * SET : When unmasked RX_FULL interrupt is actived.
2870  *
2871  * Register|BitsName
2872  * ---------------|---------------
2873  * RAW_INT_STAT | RX_FULL
2874  *
2875  * @param I2Cx I2C instance.
2876  * @retval State of bit (1 or 0).
2877  */
2878 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_full(i2c_regs_t *I2Cx)
2879 {
2880  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_RX_FULL) == (I2C_RAW_INT_STAT_RX_FULL));
2881 }
2882 
2883 /**
2884  * @brief Indicate the status of RX_OVER flag.
2885  * @note RESET: Clear default value.
2886  * SET : When masked RX_OVER interrupt is actived.
2887  *
2888  * Register|BitsName
2889  * ---------------|---------------
2890  * INT_STAT | RX_OVER
2891  *
2892  * @param I2Cx I2C instance.
2893  * @retval State of bit (1 or 0).
2894  */
2895 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_over(i2c_regs_t *I2Cx)
2896 {
2897  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_STAT_RAW_RX_OVER) == (I2C_INT_STAT_RAW_RX_OVER));
2898 }
2899 
2900 /**
2901  * @brief Indicate the status of RAW_RX_OVER flag.
2902  * @note RESET: Clear default value.
2903  * SET : When unmasked RX_OVER interrupt is actived.
2904  *
2905  * Register|BitsName
2906  * ---------------|---------------
2907  * RAW_INT_STAT | RX_OVER
2908  *
2909  * @param I2Cx I2C instance.
2910  * @retval State of bit (1 or 0).
2911  */
2912 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_over(i2c_regs_t *I2Cx)
2913 {
2914  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_RX_OVER) == (I2C_RAW_INT_STAT_RX_OVER));
2915 }
2916 
2917 /**
2918  * @brief Indicate the status of RX_UNDER flag.
2919  * @note RESET: Clear default value.
2920  * SET : When masked RX_UNDER interrupt is actived.
2921  *
2922  * Register|BitsName
2923  * ---------------|---------------
2924  * INT_STAT | RX_UNDER
2925  *
2926  * @param I2Cx I2C instance.
2927  * @retval State of bit (1 or 0).
2928  */
2929 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_under(i2c_regs_t *I2Cx)
2930 {
2931  return (READ_BITS(I2Cx->INT_STAT, I2C_INT_MASK_MASK_RX_UNDER) == (I2C_INT_MASK_MASK_RX_UNDER));
2932 }
2933 
2934 /**
2935  * @brief Indicate the status of RAW_RX_UNDER flag.
2936  * @note RESET: Clear default value.
2937  * SET : When unmasked RX_UNDER interrupt is actived.
2938  *
2939  * Register|BitsName
2940  * ---------------|---------------
2941  * RAW_INT_STAT | RX_UNDER
2942  *
2943  * @param I2Cx I2C instance.
2944  * @retval State of bit (1 or 0).
2945  */
2946 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_under(i2c_regs_t *I2Cx)
2947 {
2948  return (READ_BITS(I2Cx->RAW_INT_STAT, I2C_RAW_INT_STAT_RX_UNDER) == (I2C_RAW_INT_STAT_RX_UNDER));
2949 }
2950 
2951 /**
2952  * @brief Clear the combined interrupt, all individual interrupts, and the IC_TX_ABRT_SOURCE register
2953  *
2954  * Register|BitsName
2955  * ---------------|---------------
2956  * CLR_INT | CLR_INTR
2957  *
2958  * @param I2Cx I2C instance.
2959  * @retval None.
2960  */
2961 __STATIC_INLINE void ll_i2c_clear_flag_intr(i2c_regs_t *I2Cx)
2962 {
2963  __IO uint32_t tmpreg;
2964  tmpreg = READ_REG(I2Cx->CLR_INT);
2965  (void) tmpreg;
2966 }
2967 
2968 /**
2969  * @brief Clear scl stuck interrupt, all individual interrupts, and the IC_TX_ABRT_SOURCE register
2970  *
2971  * Register|BitsName
2972  * ---------------|---------------
2973  * CLR_INT | CLR_INTR
2974  *
2975  * @param I2Cx I2C instance.
2976  * @retval None.
2977  */
2978 __STATIC_INLINE void ll_i2c_clear_flag_scl_stuck_det(i2c_regs_t *I2Cx)
2979 {
2980  __IO uint32_t tmpreg;
2981  tmpreg = READ_REG(I2Cx->CLR_SCL_STUCK_DET);
2982  (void) tmpreg;
2983 }
2984 
2985 /**
2986  * @brief Clear GEN_CALL flag.
2987  *
2988  * Register|BitsName
2989  * ---------------|---------------
2990  * CLR_GEN_CALL | CLR_GEN_CALL
2991  *
2992  * @param I2Cx I2C instance.
2993  * @retval None.
2994  */
2995 __STATIC_INLINE void ll_i2c_clear_flag_gen_call(i2c_regs_t *I2Cx)
2996 {
2997  __IO uint32_t tmpreg;
2998  tmpreg = READ_REG(I2Cx->CLR_GEN_CALL);
2999  (void) tmpreg;
3000 }
3001 
3002 /**
3003  * @brief Clear START_DET flag.
3004  *
3005  * Register|BitsName
3006  * ---------------|---------------
3007  * CLR_START_DET | CLR_START_DET
3008  *
3009  * @param I2Cx I2C instance.
3010  * @retval None.
3011  */
3012 __STATIC_INLINE void ll_i2c_clear_flag_start_det(i2c_regs_t *I2Cx)
3013 {
3014  __IO uint32_t tmpreg;
3015  tmpreg = READ_REG(I2Cx->CLR_START_DET);
3016  (void) tmpreg;
3017 }
3018 
3019 /**
3020  * @brief Clear STOP_DET flag.
3021  *
3022  * Register|BitsName
3023  * ---------------|---------------
3024  * CLR_STOP_DET | CLR_STOP_DET
3025  *
3026  * @param I2Cx I2C instance.
3027  * @retval None.
3028  */
3029 __STATIC_INLINE void ll_i2c_clear_flag_stop_det(i2c_regs_t *I2Cx)
3030 {
3031  __IO uint32_t tmpreg;
3032  tmpreg = READ_REG(I2Cx->CLR_STOP_DET);
3033  (void) tmpreg;
3034 }
3035 
3036 /**
3037  * @brief Clear ACTIVITY flag.
3038  *
3039  * Register|BitsName
3040  * ---------------|---------------
3041  * CLR_ACTIVITY | CLR_ACTIVITY
3042  *
3043  * @param I2Cx I2C instance.
3044  * @retval None.
3045  */
3046 __STATIC_INLINE void ll_i2c_clear_flag_activity(i2c_regs_t *I2Cx)
3047 {
3048  __IO uint32_t tmpreg;
3049  tmpreg = READ_REG(I2Cx->CLR_ACTIVITY);
3050  (void) tmpreg;
3051 }
3052 
3053 /**
3054  * @brief Clear RX_DONE flag.
3055  *
3056  * Register|BitsName
3057  * ---------------|---------------
3058  * CLR_RX_DONE | CLR_RX_DONE
3059  *
3060  * @param I2Cx I2C instance.
3061  * @retval None.
3062  */
3063 __STATIC_INLINE void ll_i2c_clear_flag_rx_done(i2c_regs_t *I2Cx)
3064 {
3065  __IO uint32_t tmpreg;
3066  tmpreg = READ_REG(I2Cx->CLR_RX_DONE);
3067  (void) tmpreg;
3068 }
3069 
3070 /**
3071  * @brief Clear TX_ABRT flag.
3072  *
3073  * Register|BitsName
3074  * ---------------|---------------
3075  * CLR_TX_ABORT | CLR_TX_ABRT
3076  *
3077  * @param I2Cx I2C instance.
3078  * @retval None.
3079  */
3080 __STATIC_INLINE void ll_i2c_clear_flag_tx_abort(i2c_regs_t *I2Cx)
3081 {
3082  __IO uint32_t tmpreg;
3083  tmpreg = READ_REG(I2Cx->CLR_TX_ABORT);
3084  (void) tmpreg;
3085 }
3086 
3087 /**
3088  * @brief Clear RD_REQ flag.
3089  *
3090  * Register|BitsName
3091  * ---------------|---------------
3092  * CLR_RD_REQ | CLR_RD_REQ
3093  *
3094  * @param I2Cx I2C instance.
3095  * @retval None.
3096  */
3097 __STATIC_INLINE void ll_i2c_clear_flag_read_req(i2c_regs_t *I2Cx)
3098 {
3099  __IO uint32_t tmpreg;
3100  tmpreg = READ_REG(I2Cx->CLR_RD_REQ);
3101  (void) tmpreg;
3102 }
3103 
3104 /**
3105  * @brief Clear TX_OVER flag.
3106  *
3107  * Register|BitsName
3108  * ---------------|---------------
3109  * CLR_TX_OVER | CLR_TX_OVER
3110  *
3111  * @param I2Cx I2C instance.
3112  * @retval None.
3113  */
3114 __STATIC_INLINE void ll_i2c_clear_flag_tx_over(i2c_regs_t *I2Cx)
3115 {
3116  __IO uint32_t tmpreg;
3117  tmpreg = READ_REG(I2Cx->CLR_TX_OVER);
3118  (void) tmpreg;
3119 }
3120 
3121 /**
3122  * @brief Clear RX_OVER flag.
3123  *
3124  * Register|BitsName
3125  * ---------------|---------------
3126  * CLR_RX_OVER | CLR_RX_OVER
3127  *
3128  * @param I2Cx I2C instance.
3129  * @retval None.
3130  */
3131 __STATIC_INLINE void ll_i2c_clear_flag_rx_over(i2c_regs_t *I2Cx)
3132 {
3133  __IO uint32_t tmpreg;
3134  tmpreg = READ_REG(I2Cx->CLR_RX_OVER);
3135  (void) tmpreg;
3136 }
3137 
3138 /**
3139  * @brief Clear RX_UNDER flag.
3140  *
3141  * Register|BitsName
3142  * ---------------|---------------
3143  * CLR_RX_UNDER | CLR_RX_UNDER
3144  *
3145  * @param I2Cx I2C instance.
3146  * @retval None.
3147  */
3148 __STATIC_INLINE void ll_i2c_clear_flag_rx_under(i2c_regs_t *I2Cx)
3149 {
3150  __IO uint32_t tmpreg;
3151  tmpreg = READ_REG(I2Cx->CLR_RX_UNDER);
3152  (void) tmpreg;
3153 }
3154 
3155 /**
3156  * @brief Indicate the status of IC_STATUS SDA stuck at low is not recovered flag.
3157  * @note RESET: stuck at low is recovered.
3158  * SET : stuck at low is not recovered.
3159  *
3160  * Register|BitsName
3161  * ---------------|---------------
3162  * STAT | SDA_STUCK_RCVR
3163  *
3164  * @param I2Cx I2C instance.
3165  * @retval State of bit (1 or 0).
3166  */
3167 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_sda_stuck_not_recovered(i2c_regs_t *I2Cx)
3168 {
3169  return (READ_BITS(I2Cx->STAT, I2C_STAT_SDA_STUCK_RCVR) == (I2C_STAT_SDA_STUCK_RCVR));
3170 }
3171 
3172 /**
3173  * @brief Indicate the status of IC_STATUS Slave FSM Activity Status flag.
3174  * @note RESET: Slave FSM is in IDLE state.
3175  * SET : When Slave FSM is not in IDLE state.
3176  *
3177  * Register|BitsName
3178  * ---------------|---------------
3179  * STAT | S_ACTIVITY
3180  *
3181  * @param I2Cx I2C instance.
3182  * @retval State of bit (1 or 0).
3183  */
3184 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_slave_activity(i2c_regs_t *I2Cx)
3185 {
3186  return (READ_BITS(I2Cx->STAT, I2C_STAT_S_ACTIVITY) == (I2C_STAT_S_ACTIVITY));
3187 }
3188 
3189 /**
3190  * @brief Indicate the status of IC_STATUS Master FSM Activity Status flag.
3191  * @note RESET: Master FSM is in IDLE state.
3192  * SET : When Master FSM is not in IDLE state.
3193  *
3194  * Register|BitsName
3195  * ---------------|---------------
3196  * STAT | M_ACTIVITY
3197  *
3198  * @param I2Cx I2C instance.
3199  * @retval State of bit (1 or 0).
3200  */
3201 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_master_activity(i2c_regs_t *I2Cx)
3202 {
3203  return (READ_BITS(I2Cx->STAT, I2C_STAT_M_ACTIVITY) == (I2C_STAT_M_ACTIVITY));
3204 }
3205 
3206 /**
3207  * @brief Indicate the status of IC_STATUS Receive FIFO Completely Full flag.
3208  * @note RESET: Receive FIFO is not full.
3209  * SET : When Receive FIFO is full.
3210  *
3211  * Register|BitsName
3212  * ---------------|---------------
3213  * STAT | RX_FIFO_CF
3214  *
3215  * @param I2Cx I2C instance.
3216  * @retval State of bit (1 or 0).
3217  */
3218 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_rff(i2c_regs_t *I2Cx)
3219 {
3220  return (READ_BITS(I2Cx->STAT, I2C_STAT_RX_FIFO_CF) == (I2C_STAT_RX_FIFO_CF));
3221 }
3222 
3223 /**
3224  * @brief Indicate the status of IC_STATUS Receive FIFO Not Empty flag.
3225  * @note RESET: Receive FIFO is empty.
3226  * SET : When Receive FIFO is not empty.
3227  *
3228  * Register|BitsName
3229  * ---------------|---------------
3230  * STAT | RX_FIFO_NE
3231  *
3232  * @param I2Cx I2C instance.
3233  * @retval State of bit (1 or 0).
3234  */
3235 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_rfne(i2c_regs_t *I2Cx)
3236 {
3237  return (READ_BITS(I2Cx->STAT, I2C_STAT_RX_FIFO_NE) == (I2C_STAT_RX_FIFO_NE));
3238 }
3239 
3240 /**
3241  * @brief Indicate the status of IC_STATUS Transmit FIFO Completely Empty flag.
3242  * @note RESET: Transmit FIFO is not empty.
3243  * SET : When Transmit FIFO is empty.
3244  *
3245  * Register|BitsName
3246  * ---------------|---------------
3247  * STAT | TX_FIFO_CE
3248  *
3249  * @param I2Cx I2C instance.
3250  * @retval State of bit (1 or 0).
3251  */
3252 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_tfe(i2c_regs_t *I2Cx)
3253 {
3254  return (READ_BITS(I2Cx->STAT, I2C_STAT_TX_FIFO_CE) == (I2C_STAT_TX_FIFO_CE));
3255 }
3256 
3257 /**
3258  * @brief Indicate the status of IC_STATUS Transmit FIFO Not Full flag.
3259  * @note RESET: Transmit FIFO is full.
3260  * SET : When Transmit FIFO is not full.
3261  *
3262  * Register|BitsName
3263  * ---------------|---------------
3264  * STAT | TX_FIFO_NF
3265  *
3266  * @param I2Cx I2C instance.
3267  * @retval State of bit (1 or 0).
3268  */
3269 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_tfnf(i2c_regs_t *I2Cx)
3270 {
3271  return (READ_BITS(I2Cx->STAT, I2C_STAT_TX_FIFO_NF) == (I2C_STAT_TX_FIFO_NF));
3272 }
3273 
3274 /**
3275  * @brief Indicate the status of IC_STATUS ACTIVITY flag.
3276  * @note RESET: I2C is idle.
3277  * SET : When I2C is active.
3278  *
3279  * Register|BitsName
3280  * ---------------|---------------
3281  * STAT | ACTIVITY
3282  *
3283  * @param I2Cx I2C instance.
3284  * @retval State of bit (1 or 0).
3285  */
3286 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_activity(i2c_regs_t *I2Cx)
3287 {
3288  return (READ_BITS(I2Cx->STAT, I2C_STAT_ACTIVITY) == (I2C_STAT_ACTIVITY));
3289 }
3290 
3291 /**
3292  * @brief Indicate the status of Slave Received Data Lost flag.
3293  * @note RESET: Slave RX Data is not lost.
3294  * SET : Slave RX Data is lost.
3295  *
3296  * Register|BitsName
3297  * ---------------|---------------
3298  * EN_STAT | S_RX_DATA_LOST
3299  *
3300  * @param I2Cx I2C instance.
3301  * @retval State of bit (1 or 0).
3302  */
3303 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_slave_rx_data_lost(i2c_regs_t *I2Cx)
3304 {
3305  return (READ_BITS(I2Cx->EN_STAT, I2C_EN_STAT_S_RX_DATA_LOST) == (I2C_EN_STAT_S_RX_DATA_LOST));
3306 }
3307 
3308 /**
3309  * @brief Indicate the status of Slave Disabled While Busy flag.
3310  * @note RESET: Slave is disabled when it is idle.
3311  * SET : Slave is disabled when it is active.
3312  *
3313  * Register|BitsName
3314  * ---------------|---------------
3315  * EN_STAT | S_DIS_BUSY
3316  *
3317  * @param I2Cx I2C instance.
3318  * @retval State of bit (1 or 0).
3319  */
3320 __STATIC_INLINE uint32_t ll_i2c_is_active_flag_slave_dis_whl_busy(i2c_regs_t *I2Cx)
3321 {
3322  return (READ_BITS(I2Cx->EN_STAT, I2C_EN_STAT_S_DIS_BUSY) == (I2C_EN_STAT_S_DIS_BUSY));
3323 }
3324 /** @} */
3325 
3326 /** @defgroup I2C_LL_EF_DMA_Management DMA_Management
3327  * @{
3328  */
3329 
3330 /**
3331  * @brief Enable DMA transmission requests.
3332  *
3333  * Register|BitsName
3334  * ---------------|---------------
3335  * DMA_CTRL | TX_EN
3336  *
3337  * @retval Value range between 0 ~ 0x8.
3338  * @retval None.
3339  */
3340 __STATIC_INLINE void ll_i2c_enable_dma_req_tx(i2c_regs_t *I2Cx)
3341 {
3342  SET_BITS(I2Cx->DMA_CTRL, I2C_DMA_CTRL_TX_EN);
3343 }
3344 
3345 /**
3346  * @brief Disable DMA transmission requests.
3347  *
3348  * Register|BitsName
3349  * ---------------|---------------
3350  * DMA_CTRL | TX_EN
3351  *
3352  * @param I2Cx I2C instance.
3353  * @retval None.
3354  */
3355 __STATIC_INLINE void ll_i2c_disable_dma_req_tx(i2c_regs_t *I2Cx)
3356 {
3357  CLEAR_BITS(I2Cx->DMA_CTRL, I2C_DMA_CTRL_TX_EN);
3358 }
3359 
3360 /**
3361  * @brief Check if DMA transmission requests are enabled or disabled.
3362  *
3363  * Register|BitsName
3364  * ---------------|---------------
3365  * DMA_CTRL | TX_EN
3366  *
3367  * @param I2Cx I2C instance.
3368  * @retval State of bit (1 or 0).
3369  */
3370 __STATIC_INLINE uint32_t ll_i2c_is_enabled_dma_req_tx(i2c_regs_t *I2Cx)
3371 {
3372  return (READ_BITS(I2Cx->DMA_CTRL, I2C_DMA_CTRL_TX_EN) == (I2C_DMA_CTRL_TX_EN));
3373 }
3374 
3375 /**
3376  * @brief Enable DMA reception requests.
3377  *
3378  * Register|BitsName
3379  * ---------------|---------------
3380  * DMA_CTRL | RX_EN
3381  *
3382  * @param I2Cx I2C instance.
3383  * @retval None.
3384  */
3385 __STATIC_INLINE void ll_i2c_enable_dma_req_rx(i2c_regs_t *I2Cx)
3386 {
3387  SET_BITS(I2Cx->DMA_CTRL, I2C_DMA_CTRL_RX_EN);
3388 }
3389 
3390 /**
3391  * @brief Disable DMA reception requests.
3392  *
3393  * Register|BitsName
3394  * ---------------|---------------
3395  * DMA_CTRL | RX_EN
3396  *
3397  * @param I2Cx I2C instance.
3398  * @retval None.
3399  */
3400 __STATIC_INLINE void ll_i2c_disable_dma_req_rx(i2c_regs_t *I2Cx)
3401 {
3402  CLEAR_BITS(I2Cx->DMA_CTRL, I2C_DMA_CTRL_RX_EN);
3403 }
3404 
3405 /**
3406  * @brief Check if DMA reception requests are enabled or disabled.
3407  *
3408  * Register|BitsName
3409  * ---------------|---------------
3410  * DMA_CTRL | RX_EN
3411  *
3412  * @param I2Cx I2C instance.
3413  * @retval State of bit (1 or 0).
3414  */
3415 __STATIC_INLINE uint32_t ll_i2c_is_enabled_dma_req_rx(i2c_regs_t *I2Cx)
3416 {
3417  return (READ_BITS(I2Cx->DMA_CTRL, I2C_DMA_CTRL_RX_EN) == (I2C_DMA_CTRL_RX_EN));
3418 }
3419 
3420 /**
3421  * @brief Set level of TX FIFO that requests a DMA transmit.
3422  * @note TX data level should equal to the watermark level, that is, the dma_tx_req
3423  * signal is generated when the number of valid data entries in the transmit
3424  * FIFO is equal to or below this field value, and TDMAE = 1.
3425  *
3426  * Register|BitsName
3427  * ---------------|---------------
3428  * DMA_TX_LEVEL | LEVEL
3429  *
3430  * @param I2Cx I2C instance
3431  * @param level This parameter should range between 0x0 and 0x8.
3432  * @retval None.
3433  */
3434 __STATIC_INLINE void ll_i2c_set_dma_tx_data_level(i2c_regs_t *I2Cx, uint32_t level)
3435 {
3436  WRITE_REG(I2Cx->DMA_TX_LEVEL, level);
3437 }
3438 
3439 /**
3440  * @brief Get level of TX FIFO that request a DMA transmit.
3441  *
3442  * Register|BitsName
3443  * ---------------|---------------
3444  * DMA_TX_LEVEL | LEVEL
3445  *
3446  * @param I2Cx I2C instance
3447  * @retval Returned value should range between 0x0 and 0x8.
3448  */
3449 __STATIC_INLINE uint32_t ll_i2c_get_dma_tx_data_level(i2c_regs_t *I2Cx)
3450 {
3451  return (uint32_t)(READ_BITS(I2Cx->DMA_TX_LEVEL, I2C_DMA_TX_LEVEL_LEVEL));
3452 }
3453 
3454 /**
3455  * @brief Set level of RX FIFO that requests a DMA receive.
3456  * @note The watermark level = DMARDL + 1, that is, dma_rx_req is generated when
3457  * the number of valid data entries in the receive FIFO is equal to or
3458  * more than this field value + 1, and RDMAE = 1. For instance, when DMARDL
3459  * is 0, then dma_rx_req is asserted when 1 or more data entries are present
3460  * in the receive FIFO.
3461  *
3462  * Register|BitsName
3463  * ---------------|---------------
3464  * DMA_RX_LEVEL | LEVEL
3465  *
3466  * @param I2Cx I2C instance
3467  * @param level This parameter should range between 0x0 and 0x8.
3468  * @retval None.
3469  */
3470 __STATIC_INLINE void ll_i2c_set_dma_rx_data_level(i2c_regs_t *I2Cx, uint32_t level)
3471 {
3472  WRITE_REG(I2Cx->DMA_RX_LEVEL, level);
3473 }
3474 
3475 /**
3476  * @brief Get level of RX FIFO that request a DMA receive.
3477  *
3478  * Register|BitsName
3479  * ---------------|---------------
3480  * DMA_RX_LEVEL | LEVEL
3481  *
3482  * @param I2Cx I2C instance
3483  * @retval Returned value should range between 0x0 and 0x8.
3484  */
3485 __STATIC_INLINE uint32_t ll_i2c_get_dma_rx_data_level(i2c_regs_t *I2Cx)
3486 {
3487  return (uint32_t)(READ_BITS(I2Cx->DMA_RX_LEVEL, I2C_DMA_RX_LEVEL_LEVEL));
3488 }
3489 
3490 /**
3491  * @brief Get the data register address used for DMA transfer
3492  *
3493  * Register|BitsName
3494  * ---------------|---------------
3495  * DATA_CMD | DAT
3496  *
3497  * @param I2Cx I2C instance
3498  * @retval Address of data register
3499  */
3500 __STATIC_INLINE uint32_t ll_i2c_dma_get_register_address(i2c_regs_t *I2Cx)
3501 {
3502  return ((uint32_t) & (I2Cx->DATA_CMD));
3503 }
3504 
3505 /**
3506  * @brief Set scl stuck timeout time
3507  *
3508  * Register|BitsName
3509  * --------------------------------| ---------------------
3510  * SCL_STUCK_AT_LOW_TIMEOUT | SCL_STUCK_LOW_TIMEOUT
3511  *
3512  * @param I2Cx I2C instance
3513  * @param timeout timeout time
3514  * @retval Address of data register
3515  */
3516 __STATIC_INLINE void ll_i2c_set_scl_stuck_at_low_timeout(i2c_regs_t *I2Cx, uint32_t timeout)
3517 {
3518  WRITE_REG(I2Cx->SCL_STUCK_TIMEOUT, timeout);
3519 }
3520 
3521 /**
3522  * @brief Set sda stuck timeout time
3523  *
3524  * Register|BitsName
3525  * --------------------------------| ---------------------
3526  * SDA_STUCK_AT_LOW_TIMEOUT | SDA_STUCK_LOW_TIMEOUT
3527  *
3528  * @param I2Cx I2C instance
3529  * @param timeout timeout time
3530  * @retval Address of data register
3531  */
3532 __STATIC_INLINE void ll_i2c_set_sda_stuck_at_low_timeout(i2c_regs_t *I2Cx, uint32_t timeout)
3533 {
3534  WRITE_REG(I2Cx->SDA_STUCK_TIMEOUT, timeout);
3535 }
3536 
3537 /** @} */
3538 
3539 /** @defgroup I2C_LL_EF_Data_Management Data_Management
3540  * @{
3541  */
3542 
3543 /**
3544  * @brief Configure the slave address for transfer (master mode).
3545  * @note The register IC_TAR can only be programmed when the I2C is disabled (ENABLE = 0).
3546  *
3547  * Register|BitsName
3548  * ---------------|---------------
3549  * TARGET_ADDR | TAR_ADDR
3550  *
3551  * @param I2Cx I2C instance.
3552  * @param slave_addr This parameter must be a value between 0x00 and 0x3F.
3553  * @retval None.
3554  */
3555 __STATIC_INLINE void ll_i2c_set_slave_address(i2c_regs_t *I2Cx, uint32_t slave_addr)
3556 {
3557  MODIFY_REG(I2Cx->TARGET_ADDR, I2C_TARGET_ADDR_TARGET, slave_addr << I2C_TARGET_ADDR_TARGET_POS);
3558 }
3559 
3560 /**
3561  * @brief Get the slave address programmed for transfer (master mode).
3562  *
3563  * Register|BitsName
3564  * ---------------|---------------
3565  * TARGET_ADDR | TAR_ADDR
3566  *
3567  * @param I2Cx I2C instance.
3568  * @retval Value between 0x0 and0x3F
3569  */
3570 __STATIC_INLINE uint32_t ll_i2c_get_slave_address(i2c_regs_t *I2Cx)
3571 {
3572  return (uint32_t)(READ_BITS(I2Cx->TARGET_ADDR, I2C_TARGET_ADDR_TARGET) >> I2C_TARGET_ADDR_TARGET_POS);
3573 }
3574 
3575 /**
3576  * @brief Handles I2Cx communication when starting transfer or during transfer (TC or TCR flag are set).
3577  * @note The register IC_CON and IC_TAR can only be programmed when the I2C is disabled (ENABLE = 0).
3578  *
3579  * Register|BitsName
3580  * ---------------|---------------
3581  * TARGET_ADDR | TAR_ADDR
3582  * CTRL | CON_10BITADDR_MST
3583  *
3584  * @param I2Cx I2C instance.
3585  * @param slave_addr Specifies the slave address to be programmed.
3586  * @param slave_addr_size This parameter can be one of the following values:
3587  * @arg @ref LL_I2C_ADDRESSING_MODE_7BIT
3588  * @arg @ref LL_I2C_ADDRESSING_MODE_10BIT
3589  * @note SlaveAddrSize in IC_CON register can only be programmed when the I2C is disabled (IC_ENABLE = 0).
3590  * @retval None.
3591  */
3592 __STATIC_INLINE void ll_i2c_handle_transfer(i2c_regs_t *I2Cx, uint32_t slave_addr, uint32_t slave_addr_size)
3593 {
3594  MODIFY_REG(I2Cx->TARGET_ADDR, I2C_TARGET_ADDR_TARGET, slave_addr << I2C_TARGET_ADDR_TARGET_POS);
3595  ll_i2c_set_master_addressing_mode(I2Cx, slave_addr_size);
3596 }
3597 
3598 /**
3599  * @brief Read Receive Data register.
3600  *
3601  * Register|BitsName
3602  * ---------------|---------------
3603  * DATA_CMD | DATA
3604  *
3605  * @param I2Cx I2C instance.
3606  * @retval Value between Min_Data=0x00 and Max_Data=0xFF
3607  */
3608 __STATIC_INLINE uint8_t ll_i2c_receive_data8(i2c_regs_t *I2Cx)
3609 {
3610  return (uint8_t)(READ_BITS(I2Cx->DATA_CMD, I2C_DATA_CMD_DATA));
3611 }
3612 
3613 /**
3614  * @brief Write in Transmit Data Register .
3615  *
3616  * Register|BitsName
3617  * ---------------|---------------
3618  * DATA_CMD | STOP
3619  * DATA_CMD | CMD
3620  * DATA_CMD | DATA
3621  *
3622  * @param I2Cx I2C instance.
3623  * @param data Value range between 0x00 and 0xFF.
3624  * @param cmd This parameter can be one of the following values:
3625  * @arg @ref LL_I2C_CMD_SLV_NONE
3626  * @arg @ref LL_I2C_CMD_MST_WRITE
3627  * @arg @ref LL_I2C_CMD_MST_READ
3628  * @arg @ref LL_I2C_CMD_MST_GEN_STOP
3629  * @arg @ref LL_I2C_CMD_MST_GEN_RESTART
3630  * @retval None.
3631  */
3632 __STATIC_INLINE void ll_i2c_transmit_data8(i2c_regs_t *I2Cx, uint8_t data, uint32_t cmd)
3633 {
3634  WRITE_REG(I2Cx->DATA_CMD, data | cmd);
3635 }
3636 
3637 /** @} */
3638 
3639 /** @defgroup I2C_LL_EF_Init Initialization and de-initialization functions
3640  * @{
3641  */
3642 
3643 /**
3644  * @brief De-initialize I2C registers (Registers restored to their default values).
3645  * @param I2Cx I2C instance
3646  * @retval An error_status_t enumeration value:
3647  * - SUCCESS: I2C registers are de-initialized
3648  * - ERROR: I2C registers are not de-initialized
3649  */
3650 error_status_t ll_i2c_deinit(i2c_regs_t *I2Cx);
3651 
3652 /**
3653  * @brief Initialize I2C registers according to the specified
3654  * parameters in p_i2c_init.
3655  * @param I2Cx I2C instance
3656  * @param p_i2c_init Pointer to a ll_i2c_init_t structure that contains the configuration
3657  * information for the specified I2C peripheral.
3658  * @retval An error_status_t enumeration value:
3659  * - SUCCESS: I2C registers are initialized according to p_i2c_init content
3660  * - ERROR: Problem occurred during I2C Registers initialization
3661  */
3662 error_status_t ll_i2c_init(i2c_regs_t *I2Cx, ll_i2c_init_t *p_i2c_init);
3663 
3664 /**
3665  * @brief Set each field of a @ref ll_i2c_init_t type structure to default value.
3666  * @param p_i2c_init Pointer to a @ref ll_i2c_init_t structure
3667  * whose fields will be set to default values.
3668  * @retval None
3669  */
3671 
3672 /** @} */
3673 
3674 /** @} */
3675 
3676 #endif /* I2C0 || I2C1 */
3677 
3678 #ifdef __cplusplus
3679 }
3680 #endif
3681 
3682 #endif /* __GR533x_LL_I2C_H__ */
3683 
3684 /** @} */
3685 
3686 /** @} */
3687 
3688 /** @} */
ll_i2c_is_active_flag_tx_over
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_tx_over(i2c_regs_t *I2Cx)
Indicate the status of TX_OVER flag.
Definition: gr533x_ll_i2c.h:2827
ll_i2c_enable
__STATIC_INLINE void ll_i2c_enable(i2c_regs_t *I2Cx)
Enable I2C peripheral (ENABLE = 1).
Definition: gr533x_ll_i2c.h:384
_ll_i2c_init::own_addr_size
uint32_t own_addr_size
Definition: gr533x_ll_i2c.h:85
ll_i2c_enable_stop_det_if_addressed
__STATIC_INLINE void ll_i2c_enable_stop_det_if_addressed(i2c_regs_t *I2Cx)
Enable Slave issues STOP_DET interrupt only if addressed function.
Definition: gr533x_ll_i2c.h:585
ll_i2c_is_active_flag_status_tfnf
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_tfnf(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS Transmit FIFO Not Full flag.
Definition: gr533x_ll_i2c.h:3269
ll_i2c_is_enabled_transfer_abort
__STATIC_INLINE uint32_t ll_i2c_is_enabled_transfer_abort(i2c_regs_t *I2Cx)
Check if DMA reception requests are enabled or disabled.
Definition: gr533x_ll_i2c.h:1481
ll_i2c_is_active_flag_rx_done
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_done(i2c_regs_t *I2Cx)
Indicate the status of RX_DONE flag.
Definition: gr533x_ll_i2c.h:2691
ll_i2c_get_clock_low_period_fs
__STATIC_INLINE uint32_t ll_i2c_get_clock_low_period_fs(i2c_regs_t *I2Cx)
Get the SCL clock low-period count for fast speed.
Definition: gr533x_ll_i2c.h:884
ll_i2c_enable_sda_stuck_recovery
__STATIC_INLINE void ll_i2c_enable_sda_stuck_recovery(i2c_regs_t *I2Cx)
Master initates the SDA stuck at low recovery mechanism.
Definition: gr533x_ll_i2c.h:1422
ll_i2c_get_tx_fifo_level
__STATIC_INLINE uint32_t ll_i2c_get_tx_fifo_level(i2c_regs_t *I2Cx)
Get FIFO Transmission Level.
Definition: gr533x_ll_i2c.h:1393
ll_i2c_is_enabled_it_stop_det
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_stop_det(i2c_regs_t *I2Cx)
Check if STOP_DET interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1941
ll_i2c_is_enabled_it_master_on_hold
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_master_on_hold(i2c_regs_t *I2Cx)
Check if the MASTER_ON_HOLD Interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1761
ll_i2c_set_speed_mode
__STATIC_INLINE void ll_i2c_set_speed_mode(i2c_regs_t *I2Cx, uint32_t speed_mode)
Set I2C Speed mode.
Definition: gr533x_ll_i2c.h:1032
ll_i2c_enable_it_tx_over
__STATIC_INLINE void ll_i2c_enable_it_tx_over(i2c_regs_t *I2Cx)
Enable TX_OVER interrupt.
Definition: gr533x_ll_i2c.h:2181
ll_i2c_disable_it_tx_over
__STATIC_INLINE void ll_i2c_disable_it_tx_over(i2c_regs_t *I2Cx)
Disable TX_OVER interrupt.
Definition: gr533x_ll_i2c.h:2196
ll_i2c_is_active_flag_status_master_activity
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_master_activity(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS Master FSM Activity Status flag.
Definition: gr533x_ll_i2c.h:3201
ll_i2c_get_rx_fifo_threshold
__STATIC_INLINE uint32_t ll_i2c_get_rx_fifo_threshold(i2c_regs_t *I2Cx)
Get threshold of RX FIFO that triggers an RDA interrupt.
Definition: gr533x_ll_i2c.h:1378
ll_i2c_get_abort_source
__STATIC_INLINE uint32_t ll_i2c_get_abort_source(i2c_regs_t *I2Cx)
Get the transmit abort source.
Definition: gr533x_ll_i2c.h:1534
ll_i2c_is_active_flag_raw_master_on_hold
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_master_on_hold(i2c_regs_t *I2Cx)
Indicate the status of RAW_MST_ON_HOLD flag.
Definition: gr533x_ll_i2c.h:2504
ll_i2c_is_active_flag_status_rfne
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_rfne(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS Receive FIFO Not Empty flag.
Definition: gr533x_ll_i2c.h:3235
ll_i2c_clear_flag_rx_under
__STATIC_INLINE void ll_i2c_clear_flag_rx_under(i2c_regs_t *I2Cx)
Clear RX_UNDER flag.
Definition: gr533x_ll_i2c.h:3148
ll_i2c_is_enabled_sda_stuck_recovery
__STATIC_INLINE uint32_t ll_i2c_is_enabled_sda_stuck_recovery(i2c_regs_t *I2Cx)
the SDA stuck at low recovery mechanism is enabled or disabled.
Definition: gr533x_ll_i2c.h:1451
ll_i2c_dma_get_register_address
__STATIC_INLINE uint32_t ll_i2c_dma_get_register_address(i2c_regs_t *I2Cx)
Get the data register address used for DMA transfer.
Definition: gr533x_ll_i2c.h:3500
ll_i2c_clear_flag_tx_over
__STATIC_INLINE void ll_i2c_clear_flag_tx_over(i2c_regs_t *I2Cx)
Clear TX_OVER flag.
Definition: gr533x_ll_i2c.h:3114
ll_i2c_disable_it_tx_empty
__STATIC_INLINE void ll_i2c_disable_it_tx_empty(i2c_regs_t *I2Cx)
Disable TX_EMPTY interrupt.
Definition: gr533x_ll_i2c.h:2151
ll_i2c_is_active_flag_raw_tx_abort
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_tx_abort(i2c_regs_t *I2Cx)
Indicate the status of RAW_TX_ABRT flag.
Definition: gr533x_ll_i2c.h:2742
ll_i2c_enable_dma_req_tx
__STATIC_INLINE void ll_i2c_enable_dma_req_tx(i2c_regs_t *I2Cx)
Enable DMA transmission requests.
Definition: gr533x_ll_i2c.h:3340
ll_i2c_is_enabled_it_start_det
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_start_det(i2c_regs_t *I2Cx)
Check if START_DET received interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1896
ll_i2c_is_enabled_stop_det_if_addressed
__STATIC_INLINE uint32_t ll_i2c_is_enabled_stop_det_if_addressed(i2c_regs_t *I2Cx)
Check if Slave issues STOP_DET interrupt only if addressed function is enabled or disabled.
Definition: gr533x_ll_i2c.h:696
ll_i2c_enable_it_start_det
__STATIC_INLINE void ll_i2c_enable_it_start_det(i2c_regs_t *I2Cx)
Enable START_DET received interrupt.
Definition: gr533x_ll_i2c.h:1866
ll_i2c_get_data_setup_time
__STATIC_INLINE uint32_t ll_i2c_get_data_setup_time(i2c_regs_t *I2Cx)
Get the SDA setup time when operating as a slave transmitter.
Definition: gr533x_ll_i2c.h:1182
ll_i2c_is_active_flag_raw_read_req
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_read_req(i2c_regs_t *I2Cx)
Indicate the status of RAW_RD_REQ flag.
Definition: gr533x_ll_i2c.h:2776
ll_i2c_is_active_flag_status_activity
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_activity(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS ACTIVITY flag.
Definition: gr533x_ll_i2c.h:3286
ll_i2c_enable_transfer_abort
__STATIC_INLINE void ll_i2c_enable_transfer_abort(i2c_regs_t *I2Cx)
Enable DMA reception requests.
Definition: gr533x_ll_i2c.h:1466
ll_i2c_is_enabled_bus_clear_feature
__STATIC_INLINE uint32_t ll_i2c_is_enabled_bus_clear_feature(i2c_regs_t *I2Cx)
check bus clear feature is enabled function.
Definition: gr533x_ll_i2c.h:681
ll_i2c_get_spike_len_fs
__STATIC_INLINE uint32_t ll_i2c_get_spike_len_fs(i2c_regs_t *I2Cx)
Get the spike len in fast speed mode.
Definition: gr533x_ll_i2c.h:980
ll_i2c_deinit
error_status_t ll_i2c_deinit(i2c_regs_t *I2Cx)
De-initialize I2C registers (Registers restored to their default values).
ll_i2c_is_active_flag_rx_under
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_under(i2c_regs_t *I2Cx)
Indicate the status of RX_UNDER flag.
Definition: gr533x_ll_i2c.h:2929
ll_i2c_set_tx_fifo_threshold
__STATIC_INLINE void ll_i2c_set_tx_fifo_threshold(i2c_regs_t *I2Cx, uint32_t threshold)
Set threshold of entries (or below) that trigger the TX_EMPTY interrupt.
Definition: gr533x_ll_i2c.h:1232
ll_i2c_is_active_flag_raw_activity
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_activity(i2c_regs_t *I2Cx)
Indicate the status of RAW_ACTIVITY flag.
Definition: gr533x_ll_i2c.h:2674
ll_i2c_get_clock_low_period_hs
__STATIC_INLINE uint32_t ll_i2c_get_clock_low_period_hs(i2c_regs_t *I2Cx)
Get the SCL clock low-period count for high speed.
Definition: gr533x_ll_i2c.h:948
ll_i2c_is_active_flag_stop_det
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_stop_det(i2c_regs_t *I2Cx)
Indicate the status of STOP_DET flag.
Definition: gr533x_ll_i2c.h:2623
ll_i2c_is_enabled_master_mode
__STATIC_INLINE uint32_t ll_i2c_is_enabled_master_mode(i2c_regs_t *I2Cx)
Check if I2C master mode is enabled or disabled.
Definition: gr533x_ll_i2c.h:465
ll_i2c_disable_dma_req_tx
__STATIC_INLINE void ll_i2c_disable_dma_req_tx(i2c_regs_t *I2Cx)
Disable DMA transmission requests.
Definition: gr533x_ll_i2c.h:3355
ll_i2c_disable_it_rx_over
__STATIC_INLINE void ll_i2c_disable_it_rx_over(i2c_regs_t *I2Cx)
Disable RX_OVER interrupt.
Definition: gr533x_ll_i2c.h:2286
_ll_i2c_init::speed
uint32_t speed
Definition: gr533x_ll_i2c.h:78
ll_i2c_enable_it_read_req
__STATIC_INLINE void ll_i2c_enable_it_read_req(i2c_regs_t *I2Cx)
Enable RD_REQ interrupt.
Definition: gr533x_ll_i2c.h:2091
ll_i2c_is_active_flag_rx_over
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_over(i2c_regs_t *I2Cx)
Indicate the status of RX_OVER flag.
Definition: gr533x_ll_i2c.h:2895
ll_i2c_is_enabled_it_rx_under
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_rx_under(i2c_regs_t *I2Cx)
Check if RX_UNDER interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2346
ll_i2c_enable_it_stop_det
__STATIC_INLINE void ll_i2c_enable_it_stop_det(i2c_regs_t *I2Cx)
Enable STOP_DET interrupt.
Definition: gr533x_ll_i2c.h:1911
ll_i2c_disable_dma_req_rx
__STATIC_INLINE void ll_i2c_disable_dma_req_rx(i2c_regs_t *I2Cx)
Disable DMA reception requests.
Definition: gr533x_ll_i2c.h:3400
ll_i2c_set_rx_fifo_threshold
__STATIC_INLINE void ll_i2c_set_rx_fifo_threshold(i2c_regs_t *I2Cx, uint32_t threshold)
Set threshold of RX FIFO that triggers an RDA interrupt.
Definition: gr533x_ll_i2c.h:1330
ll_i2c_is_active_flag_status_tfe
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_tfe(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS Transmit FIFO Completely Empty flag.
Definition: gr533x_ll_i2c.h:3252
ll_i2c_set_sda_stuck_at_low_timeout
__STATIC_INLINE void ll_i2c_set_sda_stuck_at_low_timeout(i2c_regs_t *I2Cx, uint32_t timeout)
Set sda stuck timeout time.
Definition: gr533x_ll_i2c.h:3532
ll_i2c_is_active_flag_restart_det
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_restart_det(i2c_regs_t *I2Cx)
Indicate the status of RESTART_DET flag.
Definition: gr533x_ll_i2c.h:2521
ll_i2c_overflow_if_rx_full
__STATIC_INLINE void ll_i2c_overflow_if_rx_full(i2c_regs_t *I2Cx)
overflow when the RX FIFO if full function.
Definition: gr533x_ll_i2c.h:633
ll_i2c_enable_it_scl_stuck_at_low
__STATIC_INLINE void ll_i2c_enable_it_scl_stuck_at_low(i2c_regs_t *I2Cx)
Enable SCL_STUCK_AT_LOW interrupt.
Definition: gr533x_ll_i2c.h:1687
ll_i2c_set_dma_rx_data_level
__STATIC_INLINE void ll_i2c_set_dma_rx_data_level(i2c_regs_t *I2Cx, uint32_t level)
Set level of RX FIFO that requests a DMA receive.
Definition: gr533x_ll_i2c.h:3470
ll_i2c_disable_it_restart_det
__STATIC_INLINE void ll_i2c_disable_it_restart_det(i2c_regs_t *I2Cx)
Disable RESTART_DET interrupt.
Definition: gr533x_ll_i2c.h:1791
ll_i2c_is_active_flag_master_on_hold
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_master_on_hold(i2c_regs_t *I2Cx)
Indicate the status of MST_ON_HOLD flag.
Definition: gr533x_ll_i2c.h:2487
ll_i2c_disable_it
__STATIC_INLINE void ll_i2c_disable_it(i2c_regs_t *I2Cx, uint32_t mask)
Disable specified interrupts.
Definition: gr533x_ll_i2c.h:1633
ll_i2c_disable_master_restart
__STATIC_INLINE void ll_i2c_disable_master_restart(i2c_regs_t *I2Cx)
Disable Master Restart.
Definition: gr533x_ll_i2c.h:550
ll_i2c_get_clock_high_period_hs
__STATIC_INLINE uint32_t ll_i2c_get_clock_high_period_hs(i2c_regs_t *I2Cx)
Get the SCL clock high-period count for high speed.
Definition: gr533x_ll_i2c.h:916
ll_i2c_disable_sda_stuck_recovery
__STATIC_INLINE void ll_i2c_disable_sda_stuck_recovery(i2c_regs_t *I2Cx)
Master disabled the SDA stuck at low recovery mechanism.
Definition: gr533x_ll_i2c.h:1436
ll_i2c_clear_flag_intr
__STATIC_INLINE void ll_i2c_clear_flag_intr(i2c_regs_t *I2Cx)
Clear the combined interrupt, all individual interrupts, and the IC_TX_ABRT_SOURCE register.
Definition: gr533x_ll_i2c.h:2961
ll_i2c_is_enabled_it_restart_det
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_restart_det(i2c_regs_t *I2Cx)
Check if the RESTART_DET Interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1806
ll_i2c_get_tx_flush_count
__STATIC_INLINE uint32_t ll_i2c_get_tx_flush_count(i2c_regs_t *I2Cx)
Get the number of Tx FIFO Data Commands which are flushed due to TX_ABRT interrupt.
Definition: gr533x_ll_i2c.h:1549
ll_i2c_get_tx_fifo_threshold
__STATIC_INLINE uint32_t ll_i2c_get_tx_fifo_threshold(i2c_regs_t *I2Cx)
Get threshold of TX FIFO that triggers an THRE interrupt.
Definition: gr533x_ll_i2c.h:1280
ll_i2c_disable_it_stop_det
__STATIC_INLINE void ll_i2c_disable_it_stop_det(i2c_regs_t *I2Cx)
Disable STOP_DET interrupt.
Definition: gr533x_ll_i2c.h:1926
ll_i2c_is_enabled_it_activity
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_activity(i2c_regs_t *I2Cx)
Check if ACTIVITY interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1986
ll_i2c_disable_it_scl_stuck_at_low
__STATIC_INLINE void ll_i2c_disable_it_scl_stuck_at_low(i2c_regs_t *I2Cx)
Disable SCL_STUCK_AT_LOW interrupt.
Definition: gr533x_ll_i2c.h:1701
ll_i2c_get_data_rx_hold_time
__STATIC_INLINE uint32_t ll_i2c_get_data_rx_hold_time(i2c_regs_t *I2Cx)
Get the required receive SDA hold time in units of ic_clk period.
Definition: gr533x_ll_i2c.h:1148
ll_i2c_get_clock_high_period_ss
__STATIC_INLINE uint32_t ll_i2c_get_clock_high_period_ss(i2c_regs_t *I2Cx)
Get the SCL clock high-period count for standard speed.
Definition: gr533x_ll_i2c.h:788
ll_i2c_init
error_status_t ll_i2c_init(i2c_regs_t *I2Cx, ll_i2c_init_t *p_i2c_init)
Initialize I2C registers according to the specified parameters in p_i2c_init.
ll_i2c_disbale_it_rx_full
__STATIC_INLINE void ll_i2c_disbale_it_rx_full(i2c_regs_t *I2Cx)
Disable RX_FULL interrupt.
Definition: gr533x_ll_i2c.h:2241
ll_i2c_get_slave_address
__STATIC_INLINE uint32_t ll_i2c_get_slave_address(i2c_regs_t *I2Cx)
Get the slave address programmed for transfer (master mode).
Definition: gr533x_ll_i2c.h:3570
ll_i2c_is_active_flag_rx_full
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_rx_full(i2c_regs_t *I2Cx)
Indicate the status of RX_FULL flag.
Definition: gr533x_ll_i2c.h:2861
ll_i2c_clear_flag_scl_stuck_det
__STATIC_INLINE void ll_i2c_clear_flag_scl_stuck_det(i2c_regs_t *I2Cx)
Clear scl stuck interrupt, all individual interrupts, and the IC_TX_ABRT_SOURCE register.
Definition: gr533x_ll_i2c.h:2978
ll_i2c_enable_it_master_on_hold
__STATIC_INLINE void ll_i2c_enable_it_master_on_hold(i2c_regs_t *I2Cx)
Enable MASTER_ON_HOLD interrupt.
Definition: gr533x_ll_i2c.h:1731
ll_i2c_is_enabled_it_tx_abort
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_tx_abort(i2c_regs_t *I2Cx)
Check if TX_ABRT interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2076
ll_i2c_set_own_address
__STATIC_INLINE void ll_i2c_set_own_address(i2c_regs_t *I2Cx, uint32_t own_address, uint32_t own_addr_size)
Set the Own Address.
Definition: gr533x_ll_i2c.h:755
ll_i2c_clear_flag_start_det
__STATIC_INLINE void ll_i2c_clear_flag_start_det(i2c_regs_t *I2Cx)
Clear START_DET flag.
Definition: gr533x_ll_i2c.h:3012
ll_i2c_set_master_addressing_mode
__STATIC_INLINE void ll_i2c_set_master_addressing_mode(i2c_regs_t *I2Cx, uint32_t addressing_mode)
Configure the Master to transfers in 7-bit or 10-bit addressing mode.
Definition: gr533x_ll_i2c.h:715
ll_i2c_disable_it_gen_call
__STATIC_INLINE void ll_i2c_disable_it_gen_call(i2c_regs_t *I2Cx)
Disable GEN_CALL interrupt.
Definition: gr533x_ll_i2c.h:1836
ll_i2c_clear_flag_stop_det
__STATIC_INLINE void ll_i2c_clear_flag_stop_det(i2c_regs_t *I2Cx)
Clear STOP_DET flag.
Definition: gr533x_ll_i2c.h:3029
ll_i2c_disable_it_start_det
__STATIC_INLINE void ll_i2c_disable_it_start_det(i2c_regs_t *I2Cx)
Disable START_DET received interrupt.
Definition: gr533x_ll_i2c.h:1881
ll_i2c_is_active_flag_activity
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_activity(i2c_regs_t *I2Cx)
Indicate the status of ACTIVITY flag.
Definition: gr533x_ll_i2c.h:2657
ll_i2c_hold_bus_if_rx_full
__STATIC_INLINE void ll_i2c_hold_bus_if_rx_full(i2c_regs_t *I2Cx)
Hold bus when the RX FIFO if full function.
Definition: gr533x_ll_i2c.h:617
ll_i2c_disable_master_mode
__STATIC_INLINE void ll_i2c_disable_master_mode(i2c_regs_t *I2Cx)
Disable I2C master mode and enable slave mode.
Definition: gr533x_ll_i2c.h:449
ll_i2c_is_active_flag_raw_gen_call
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_gen_call(i2c_regs_t *I2Cx)
Indicate the status of RAW_GEN_CALL flag.
Definition: gr533x_ll_i2c.h:2572
ll_i2c_get_master_addressing_mode
__STATIC_INLINE uint32_t ll_i2c_get_master_addressing_mode(i2c_regs_t *I2Cx)
Get the Master addressing mode.
Definition: gr533x_ll_i2c.h:733
ll_i2c_clear_flag_tx_abort
__STATIC_INLINE void ll_i2c_clear_flag_tx_abort(i2c_regs_t *I2Cx)
Clear TX_ABRT flag.
Definition: gr533x_ll_i2c.h:3080
ll_i2c_disable_it_activity
__STATIC_INLINE void ll_i2c_disable_it_activity(i2c_regs_t *I2Cx)
Disable ACTIVITY interrupt.
Definition: gr533x_ll_i2c.h:1971
ll_i2c_is_active_flag_slave_rx_data_lost
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_slave_rx_data_lost(i2c_regs_t *I2Cx)
Indicate the status of Slave Received Data Lost flag.
Definition: gr533x_ll_i2c.h:3303
_ll_i2c_init
LL I2C init Structure definition.
Definition: gr533x_ll_i2c.h:77
ll_i2c_is_active_flag_tx_abort
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_tx_abort(i2c_regs_t *I2Cx)
Indicate the status of TX_ABRT flag.
Definition: gr533x_ll_i2c.h:2725
ll_i2c_disable_it_read_req
__STATIC_INLINE void ll_i2c_disable_it_read_req(i2c_regs_t *I2Cx)
Disable RD_REQ interrupt.
Definition: gr533x_ll_i2c.h:2106
ll_i2c_is_enabled_general_call
__STATIC_INLINE uint32_t ll_i2c_is_enabled_general_call(i2c_regs_t *I2Cx)
Check if General Call is enabled or disabled(slave mode).
Definition: gr533x_ll_i2c.h:512
ll_i2c_get_dma_rx_data_level
__STATIC_INLINE uint32_t ll_i2c_get_dma_rx_data_level(i2c_regs_t *I2Cx)
Get level of RX FIFO that request a DMA receive.
Definition: gr533x_ll_i2c.h:3485
ll_i2c_enable_it
__STATIC_INLINE void ll_i2c_enable_it(i2c_regs_t *I2Cx, uint32_t mask)
Enable specified interrupts.
Definition: gr533x_ll_i2c.h:1594
ll_i2c_is_active_flag_slave_dis_whl_busy
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_slave_dis_whl_busy(i2c_regs_t *I2Cx)
Indicate the status of Slave Disabled While Busy flag.
Definition: gr533x_ll_i2c.h:3320
ll_i2c_is_enabled_dma_req_tx
__STATIC_INLINE uint32_t ll_i2c_is_enabled_dma_req_tx(i2c_regs_t *I2Cx)
Check if DMA transmission requests are enabled or disabled.
Definition: gr533x_ll_i2c.h:3370
ll_i2c_set_scl_stuck_at_low_timeout
__STATIC_INLINE void ll_i2c_set_scl_stuck_at_low_timeout(i2c_regs_t *I2Cx, uint32_t timeout)
Set scl stuck timeout time.
Definition: gr533x_ll_i2c.h:3516
ll_i2c_clear_flag_rx_done
__STATIC_INLINE void ll_i2c_clear_flag_rx_done(i2c_regs_t *I2Cx)
Clear RX_DONE flag.
Definition: gr533x_ll_i2c.h:3063
ll_i2c_set_clock_low_period_ss
__STATIC_INLINE void ll_i2c_set_clock_low_period_ss(i2c_regs_t *I2Cx, uint32_t count)
Set the SCL clock low-period count for standard speed.
Definition: gr533x_ll_i2c.h:805
ll_i2c_clear_flag_rx_over
__STATIC_INLINE void ll_i2c_clear_flag_rx_over(i2c_regs_t *I2Cx)
Clear RX_OVER flag.
Definition: gr533x_ll_i2c.h:3131
ll_i2c_is_enabled_dma_req_rx
__STATIC_INLINE uint32_t ll_i2c_is_enabled_dma_req_rx(i2c_regs_t *I2Cx)
Check if DMA reception requests are enabled or disabled.
Definition: gr533x_ll_i2c.h:3415
ll_i2c_is_active_flag_scl_stuck_at_low
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_scl_stuck_at_low(i2c_regs_t *I2Cx)
Indicate the status of SCL_STUCK_AT_LOW flag.
Definition: gr533x_ll_i2c.h:2453
ll_i2c_enable_dma_req_rx
__STATIC_INLINE void ll_i2c_enable_dma_req_rx(i2c_regs_t *I2Cx)
Enable DMA reception requests.
Definition: gr533x_ll_i2c.h:3385
ll_i2c_is_active_flag_tx_empty
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_tx_empty(i2c_regs_t *I2Cx)
Indicate the status of TX_EMPTY flag.
Definition: gr533x_ll_i2c.h:2793
ll_i2c_is_active_flag_raw_tx_empty
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_tx_empty(i2c_regs_t *I2Cx)
Indicate the status of RAW_TX_EMPTY flag.
Definition: gr533x_ll_i2c.h:2810
ll_i2c_is_enabled_it_rx_over
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_rx_over(i2c_regs_t *I2Cx)
Check if RX_OVER interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2301
ll_i2c_receive_data8
__STATIC_INLINE uint8_t ll_i2c_receive_data8(i2c_regs_t *I2Cx)
Read Receive Data register.
Definition: gr533x_ll_i2c.h:3608
ll_i2c_struct_init
void ll_i2c_struct_init(ll_i2c_init_t *p_i2c_init)
Set each field of a ll_i2c_init_t type structure to default value.
ll_i2c_disable_general_call
__STATIC_INLINE void ll_i2c_disable_general_call(i2c_regs_t *I2Cx)
Disable General Call(slave mode).
Definition: gr533x_ll_i2c.h:497
ll_i2c_is_enabled_it_tx_over
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_tx_over(i2c_regs_t *I2Cx)
Check if TX_OVER interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2211
ll_i2c_set_data_rx_hold_time
__STATIC_INLINE void ll_i2c_set_data_rx_hold_time(i2c_regs_t *I2Cx, uint32_t time)
Set the required receive SDA hold time in units of ic_clk period.
Definition: gr533x_ll_i2c.h:1133
ll_i2c_set_spike_len_hs
__STATIC_INLINE void ll_i2c_set_spike_len_hs(i2c_regs_t *I2Cx, uint32_t length)
Set the spike len in high speed mode.
Definition: gr533x_ll_i2c.h:997
ll_i2c_is_active_flag_raw_scl_stuck_at_low
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_scl_stuck_at_low(i2c_regs_t *I2Cx)
Indicate the status of RAW_SCL_STUCK_AT_LOW flag.
Definition: gr533x_ll_i2c.h:2470
ll_i2c_enable_it_rx_under
__STATIC_INLINE void ll_i2c_enable_it_rx_under(i2c_regs_t *I2Cx)
Enable RX_UNDER interrupt.
Definition: gr533x_ll_i2c.h:2316
ll_i2c_enable_general_call
__STATIC_INLINE void ll_i2c_enable_general_call(i2c_regs_t *I2Cx)
Enable General Call(slave mode).
Definition: gr533x_ll_i2c.h:481
ll_i2c_is_active_flag_status_slave_activity
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_slave_activity(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS Slave FSM Activity Status flag.
Definition: gr533x_ll_i2c.h:3184
ll_i2c_set_dma_tx_data_level
__STATIC_INLINE void ll_i2c_set_dma_tx_data_level(i2c_regs_t *I2Cx, uint32_t level)
Set level of TX FIFO that requests a DMA transmit.
Definition: gr533x_ll_i2c.h:3434
ll_i2c_is_enabled_it
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it(i2c_regs_t *I2Cx, uint32_t mask)
Check if the specified interrupts are enabled or disabled.
Definition: gr533x_ll_i2c.h:1672
ll_i2c_get_dma_tx_data_level
__STATIC_INLINE uint32_t ll_i2c_get_dma_tx_data_level(i2c_regs_t *I2Cx)
Get level of TX FIFO that request a DMA transmit.
Definition: gr533x_ll_i2c.h:3449
ll_i2c_is_active_flag_raw_rx_done
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_done(i2c_regs_t *I2Cx)
Indicate the status of RAW_RX_DONE flag.
Definition: gr533x_ll_i2c.h:2708
ll_i2c_get_high_speed_master_code
__STATIC_INLINE uint32_t ll_i2c_get_high_speed_master_code(i2c_regs_t *I2Cx)
Get I2C Speed mode.
Definition: gr533x_ll_i2c.h:1082
ll_i2c_set_clock_high_period_fs
__STATIC_INLINE void ll_i2c_set_clock_high_period_fs(i2c_regs_t *I2Cx, uint32_t count)
Set the SCL clock high-period count for fast speed.
Definition: gr533x_ll_i2c.h:837
ll_i2c_enable_it_rx_over
__STATIC_INLINE void ll_i2c_enable_it_rx_over(i2c_regs_t *I2Cx)
Enable RX_OVER interrupt.
Definition: gr533x_ll_i2c.h:2271
ll_i2c_enable_it_activity
__STATIC_INLINE void ll_i2c_enable_it_activity(i2c_regs_t *I2Cx)
Enable ACTIVITY interrupt.
Definition: gr533x_ll_i2c.h:1956
ll_i2c_is_active_flag_raw_start_det
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_start_det(i2c_regs_t *I2Cx)
Indicate the status of RAW_START_DET flag.
Definition: gr533x_ll_i2c.h:2606
ll_i2c_ls_enabled_it_rx_full
__STATIC_INLINE uint32_t ll_i2c_ls_enabled_it_rx_full(i2c_regs_t *I2Cx)
Check if RX_FULL interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2256
ll_i2c_set_clock_high_period_hs
__STATIC_INLINE void ll_i2c_set_clock_high_period_hs(i2c_regs_t *I2Cx, uint32_t count)
Get the SCL clock high-period count for high speed.
Definition: gr533x_ll_i2c.h:901
ll_i2c_get_data_tx_hold_time
__STATIC_INLINE uint32_t ll_i2c_get_data_tx_hold_time(i2c_regs_t *I2Cx)
Get the required transmit SDA hold time in units of ic_clk period.
Definition: gr533x_ll_i2c.h:1115
ll_i2c_clear_flag_read_req
__STATIC_INLINE void ll_i2c_clear_flag_read_req(i2c_regs_t *I2Cx)
Clear RD_REQ flag.
Definition: gr533x_ll_i2c.h:3097
ll_i2c_is_active_flag_read_req
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_read_req(i2c_regs_t *I2Cx)
Indicate the status of RD_REQ flag.
Definition: gr533x_ll_i2c.h:2759
ll_i2c_get_spike_len_hs
__STATIC_INLINE uint32_t ll_i2c_get_spike_len_hs(i2c_regs_t *I2Cx)
Get the spike len in high speed mode.
Definition: gr533x_ll_i2c.h:1012
ll_i2c_enable_it_rx_done
__STATIC_INLINE void ll_i2c_enable_it_rx_done(i2c_regs_t *I2Cx)
Enable RX_DONE interrupt.
Definition: gr533x_ll_i2c.h:2001
ll_i2c_enable_master_restart
__STATIC_INLINE void ll_i2c_enable_master_restart(i2c_regs_t *I2Cx)
Enable Master Restart.
Definition: gr533x_ll_i2c.h:534
ll_i2c_init_t
struct _ll_i2c_init ll_i2c_init_t
LL I2C init Structure definition.
ll_i2c_is_enabled_it_tx_empty
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_tx_empty(i2c_regs_t *I2Cx)
Check if TX_EMPTY interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2166
ll_i2c_is_active_flag_gen_call
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_gen_call(i2c_regs_t *I2Cx)
Indicate the status of GEN_CALL flag.
Definition: gr533x_ll_i2c.h:2555
ll_i2c_clear_flag_activity
__STATIC_INLINE void ll_i2c_clear_flag_activity(i2c_regs_t *I2Cx)
Clear ACTIVITY flag.
Definition: gr533x_ll_i2c.h:3046
ll_i2c_is_active_flag_status_rff
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_rff(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS Receive FIFO Completely Full flag.
Definition: gr533x_ll_i2c.h:3218
ll_i2c_is_active_flag_status_sda_stuck_not_recovered
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_status_sda_stuck_not_recovered(i2c_regs_t *I2Cx)
Indicate the status of IC_STATUS SDA stuck at low is not recovered flag.
Definition: gr533x_ll_i2c.h:3167
ll_i2c_set_data_setup_time
__STATIC_INLINE void ll_i2c_set_data_setup_time(i2c_regs_t *I2Cx, uint32_t time)
Set the SDA setup time when operating as a slave transmitter.
Definition: gr533x_ll_i2c.h:1167
ll_i2c_enable_master_mode
__STATIC_INLINE void ll_i2c_enable_master_mode(i2c_regs_t *I2Cx)
Enable I2C master mode.
Definition: gr533x_ll_i2c.h:434
ll_i2c_set_clock_low_period_hs
__STATIC_INLINE void ll_i2c_set_clock_low_period_hs(i2c_regs_t *I2Cx, uint32_t count)
Get the SCL clock low-period count for high speed.
Definition: gr533x_ll_i2c.h:933
ll_i2c_disable_bus_clear_feature
__STATIC_INLINE void ll_i2c_disable_bus_clear_feature(i2c_regs_t *I2Cx)
disable bus clear feature function.
Definition: gr533x_ll_i2c.h:665
ll_i2c_get_rx_fifo_level
__STATIC_INLINE uint32_t ll_i2c_get_rx_fifo_level(i2c_regs_t *I2Cx)
Get FIFO reception Level.
Definition: gr533x_ll_i2c.h:1408
ll_i2c_get_it_flag
__STATIC_INLINE uint32_t ll_i2c_get_it_flag(i2c_regs_t *I2Cx)
Get I2C interrupt flags.
Definition: gr533x_ll_i2c.h:2394
ll_i2c_is_active_flag_raw_restart_det
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_restart_det(i2c_regs_t *I2Cx)
Indicate the status of RAW_RESTART_DET flag.
Definition: gr533x_ll_i2c.h:2538
ll_i2c_is_enabled_it_read_req
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_read_req(i2c_regs_t *I2Cx)
Check if RD_REQ interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2121
ll_i2c_enable_it_gen_call
__STATIC_INLINE void ll_i2c_enable_it_gen_call(i2c_regs_t *I2Cx)
Enable GEN_CALL interrupt.
Definition: gr533x_ll_i2c.h:1821
ll_i2c_disable_stop_det_if_addressed
__STATIC_INLINE void ll_i2c_disable_stop_det_if_addressed(i2c_regs_t *I2Cx)
Disable Slave issues STOP_DET interrupt only if addressed function.
Definition: gr533x_ll_i2c.h:601
ll_i2c_is_enabled_master_restart
__STATIC_INLINE uint32_t ll_i2c_is_enabled_master_restart(i2c_regs_t *I2Cx)
Check if Master Restart is enabled or disabled.
Definition: gr533x_ll_i2c.h:565
ll_i2c_get_speed_mode
__STATIC_INLINE uint32_t ll_i2c_get_speed_mode(i2c_regs_t *I2Cx)
Get I2C Speed mode.
Definition: gr533x_ll_i2c.h:1050
ll_i2c_enable_bus_clear_feature
__STATIC_INLINE void ll_i2c_enable_bus_clear_feature(i2c_regs_t *I2Cx)
enable bus clear feature function.
Definition: gr533x_ll_i2c.h:649
ll_i2c_disable_it_master_on_hold
__STATIC_INLINE void ll_i2c_disable_it_master_on_hold(i2c_regs_t *I2Cx)
Disable MASTER_ON_HOLD interrupt.
Definition: gr533x_ll_i2c.h:1746
ll_i2c_set_slave_address
__STATIC_INLINE void ll_i2c_set_slave_address(i2c_regs_t *I2Cx, uint32_t slave_addr)
Configure the slave address for transfer (master mode).
Definition: gr533x_ll_i2c.h:3555
ll_i2c_set_high_speed_master_code
__STATIC_INLINE void ll_i2c_set_high_speed_master_code(i2c_regs_t *I2Cx, uint32_t code)
Set I2C High Speed Master Code Address.
Definition: gr533x_ll_i2c.h:1067
ll_i2c_disable_it_rx_done
__STATIC_INLINE void ll_i2c_disable_it_rx_done(i2c_regs_t *I2Cx)
Disable RX_DONE interrupt.
Definition: gr533x_ll_i2c.h:2016
ll_i2c_is_enabled
__STATIC_INLINE uint32_t ll_i2c_is_enabled(i2c_regs_t *I2Cx)
Check if the I2C peripheral is enabled or disabled.
Definition: gr533x_ll_i2c.h:419
ll_i2c_enable_it_restart_det
__STATIC_INLINE void ll_i2c_enable_it_restart_det(i2c_regs_t *I2Cx)
Enable RESTART_DET interrupt.
Definition: gr533x_ll_i2c.h:1776
ll_i2c_is_active_flag_raw_rx_full
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_full(i2c_regs_t *I2Cx)
Indicate the status of RAW_RX_FULL flag.
Definition: gr533x_ll_i2c.h:2878
ll_i2c_is_active_flag_raw_rx_under
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_under(i2c_regs_t *I2Cx)
Indicate the status of RAW_RX_UNDER flag.
Definition: gr533x_ll_i2c.h:2946
ll_i2c_set_clock_high_period_ss
__STATIC_INLINE void ll_i2c_set_clock_high_period_ss(i2c_regs_t *I2Cx, uint32_t count)
Set the SCL clock high-period count for standard speed.
Definition: gr533x_ll_i2c.h:773
ll_i2c_is_active_flag_raw_tx_over
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_tx_over(i2c_regs_t *I2Cx)
Indicate the status of RAW_TX_OVER flag.
Definition: gr533x_ll_i2c.h:2844
ll_i2c_is_active_flag_raw_stop_det
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_stop_det(i2c_regs_t *I2Cx)
Indicate the status of RAW_STOP_DET flag.
Definition: gr533x_ll_i2c.h:2640
ll_i2c_disable_it_rx_under
__STATIC_INLINE void ll_i2c_disable_it_rx_under(i2c_regs_t *I2Cx)
Disable RX_UNDER interrupt.
Definition: gr533x_ll_i2c.h:2331
ll_i2c_set_clock_low_period_fs
__STATIC_INLINE void ll_i2c_set_clock_low_period_fs(i2c_regs_t *I2Cx, uint32_t count)
Set the SCL clock low-period count for fast speed.
Definition: gr533x_ll_i2c.h:869
ll_i2c_is_enable_it_rx_done
__STATIC_INLINE uint32_t ll_i2c_is_enable_it_rx_done(i2c_regs_t *I2Cx)
Check if RX_DONE interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:2031
ll_i2c_handle_transfer
__STATIC_INLINE void ll_i2c_handle_transfer(i2c_regs_t *I2Cx, uint32_t slave_addr, uint32_t slave_addr_size)
Handles I2Cx communication when starting transfer or during transfer (TC or TCR flag are set).
Definition: gr533x_ll_i2c.h:3592
ll_i2c_clear_flag_gen_call
__STATIC_INLINE void ll_i2c_clear_flag_gen_call(i2c_regs_t *I2Cx)
Clear GEN_CALL flag.
Definition: gr533x_ll_i2c.h:2995
ll_i2c_is_enabled_it_scl_stuck_at_low
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_scl_stuck_at_low(i2c_regs_t *I2Cx)
Check if the SCL_STUCK_AT_LOW Interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1715
ll_i2c_is_active_flag_start_det
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_start_det(i2c_regs_t *I2Cx)
Indicate the status of START_DET flag.
Definition: gr533x_ll_i2c.h:2589
ll_i2c_get_clock_high_period_fs
__STATIC_INLINE uint32_t ll_i2c_get_clock_high_period_fs(i2c_regs_t *I2Cx)
Get the SCL clock high-period count for fast speed.
Definition: gr533x_ll_i2c.h:852
ll_i2c_enable_it_rx_abort
__STATIC_INLINE void ll_i2c_enable_it_rx_abort(i2c_regs_t *I2Cx)
Enable TX_ABRT interrupt.
Definition: gr533x_ll_i2c.h:2046
ll_i2c_enable_it_tx_empty
__STATIC_INLINE void ll_i2c_enable_it_tx_empty(i2c_regs_t *I2Cx)
Enable TX_EMPTY interrupt.
Definition: gr533x_ll_i2c.h:2136
ll_i2c_set_data_tx_hold_time
__STATIC_INLINE void ll_i2c_set_data_tx_hold_time(i2c_regs_t *I2Cx, uint32_t time)
Set the required transmit SDA hold time in units of ic_clk period.
Definition: gr533x_ll_i2c.h:1100
_ll_i2c_init::own_address
uint32_t own_address
Definition: gr533x_ll_i2c.h:80
ll_i2c_disable
__STATIC_INLINE void ll_i2c_disable(i2c_regs_t *I2Cx)
Disable I2C peripheral (ENABLE = 0).
Definition: gr533x_ll_i2c.h:404
ll_i2c_set_spike_len_fs
__STATIC_INLINE void ll_i2c_set_spike_len_fs(i2c_regs_t *I2Cx, uint32_t length)
Set the spike len in fast speed mode.
Definition: gr533x_ll_i2c.h:965
ll_i2c_is_enabled_it_gen_call
__STATIC_INLINE uint32_t ll_i2c_is_enabled_it_gen_call(i2c_regs_t *I2Cx)
Check if GEN_CALL interrupt is enabled or disabled.
Definition: gr533x_ll_i2c.h:1851
ll_i2c_disable_it_tx_abort
__STATIC_INLINE void ll_i2c_disable_it_tx_abort(i2c_regs_t *I2Cx)
Disable TX_ABRT interrupt.
Definition: gr533x_ll_i2c.h:2061
ll_i2c_is_active_flag_raw_rx_over
__STATIC_INLINE uint32_t ll_i2c_is_active_flag_raw_rx_over(i2c_regs_t *I2Cx)
Indicate the status of RAW_RX_OVER flag.
Definition: gr533x_ll_i2c.h:2912
ll_i2c_get_raw_it_flag
__STATIC_INLINE uint32_t ll_i2c_get_raw_it_flag(i2c_regs_t *I2Cx)
Get I2C RAW interrupt flags.
Definition: gr533x_ll_i2c.h:2436
ll_i2c_get_clock_low_period_ss
__STATIC_INLINE uint32_t ll_i2c_get_clock_low_period_ss(i2c_regs_t *I2Cx)
Get the SCL clock low-period count for standard speed.
Definition: gr533x_ll_i2c.h:820
ll_i2c_transmit_data8
__STATIC_INLINE void ll_i2c_transmit_data8(i2c_regs_t *I2Cx, uint8_t data, uint32_t cmd)
Write in Transmit Data Register .
Definition: gr533x_ll_i2c.h:3632
ll_i2c_enable_it_rx_full
__STATIC_INLINE void ll_i2c_enable_it_rx_full(i2c_regs_t *I2Cx)
Enable RX_FULL interrupt.
Definition: gr533x_ll_i2c.h:2226