Update MixerProfile.md
[inav.git] / lib / main / STM32F4 / Drivers / STM32F4xx_StdPeriph_Driver / src / stm32f4xx_i2c.c
blob832322102bd8266364e04d9ec5f8a0569b6da1b2
1 /**
2 ******************************************************************************
3 * @file stm32f4xx_i2c.c
4 * @author MCD Application Team
5 * @version V1.7.1
6 * @date 20-May-2016
7 * @brief This file provides firmware functions to manage the following
8 * functionalities of the Inter-integrated circuit (I2C)
9 * + Initialization and Configuration
10 * + Data transfers
11 * + PEC management
12 * + DMA transfers management
13 * + Interrupts, events and flags management
15 @verbatim
16 ===============================================================================
17 ##### How to use this driver #####
18 ===============================================================================
19 [..]
20 (#) Enable peripheral clock using RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2Cx, ENABLE)
21 function for I2C1, I2C2 or I2C3.
23 (#) Enable SDA, SCL and SMBA (when used) GPIO clocks using
24 RCC_AHBPeriphClockCmd() function.
26 (#) Peripherals alternate function:
27 (++) Connect the pin to the desired peripherals' Alternate
28 Function (AF) using GPIO_PinAFConfig() function
29 (++) Configure the desired pin in alternate function by:
30 GPIO_InitStruct->GPIO_Mode = GPIO_Mode_AF
31 (++) Select the type, pull-up/pull-down and output speed via
32 GPIO_PuPd, GPIO_OType and GPIO_Speed members
33 (++) Call GPIO_Init() function
34 Recommended configuration is Push-Pull, Pull-up, Open-Drain.
35 Add an external pull up if necessary (typically 4.7 KOhm).
37 (#) Program the Mode, duty cycle , Own address, Ack, Speed and Acknowledged
38 Address using the I2C_Init() function.
40 (#) Optionally you can enable/configure the following parameters without
41 re-initialization (i.e there is no need to call again I2C_Init() function):
42 (++) Enable the acknowledge feature using I2C_AcknowledgeConfig() function
43 (++) Enable the dual addressing mode using I2C_DualAddressCmd() function
44 (++) Enable the general call using the I2C_GeneralCallCmd() function
45 (++) Enable the clock stretching using I2C_StretchClockCmd() function
46 (++) Enable the fast mode duty cycle using the I2C_FastModeDutyCycleConfig()
47 function.
48 (++) Configure the NACK position for Master Receiver mode in case of
49 2 bytes reception using the function I2C_NACKPositionConfig().
50 (++) Enable the PEC Calculation using I2C_CalculatePEC() function
51 (++) For SMBus Mode:
52 (+++) Enable the Address Resolution Protocol (ARP) using I2C_ARPCmd() function
53 (+++) Configure the SMBusAlert pin using I2C_SMBusAlertConfig() function
55 (#) Enable the NVIC and the corresponding interrupt using the function
56 I2C_ITConfig() if you need to use interrupt mode.
58 (#) When using the DMA mode
59 (++) Configure the DMA using DMA_Init() function
60 (++) Active the needed channel Request using I2C_DMACmd() or
61 I2C_DMALastTransferCmd() function.
62 -@@- When using DMA mode, I2C interrupts may be used at the same time to
63 control the communication flow (Start/Stop/Ack... events and errors).
65 (#) Enable the I2C using the I2C_Cmd() function.
67 (#) Enable the DMA using the DMA_Cmd() function when using DMA mode in the
68 transfers.
70 @endverbatim
71 ******************************************************************************
72 * @attention
74 * <h2><center>&copy; COPYRIGHT 2016 STMicroelectronics</center></h2>
76 * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
77 * You may not use this file except in compliance with the License.
78 * You may obtain a copy of the License at:
80 * http://www.st.com/software_license_agreement_liberty_v2
82 * Unless required by applicable law or agreed to in writing, software
83 * distributed under the License is distributed on an "AS IS" BASIS,
84 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
85 * See the License for the specific language governing permissions and
86 * limitations under the License.
88 ******************************************************************************
89 */
91 /* Includes ------------------------------------------------------------------*/
92 #include "stm32f4xx_i2c.h"
93 #include "stm32f4xx_rcc.h"
95 /** @addtogroup STM32F4xx_StdPeriph_Driver
96 * @{
99 /** @defgroup I2C
100 * @brief I2C driver modules
101 * @{
104 /* Private typedef -----------------------------------------------------------*/
105 /* Private define ------------------------------------------------------------*/
107 #define CR1_CLEAR_MASK ((uint16_t)0xFBF5) /*<! I2C registers Masks */
108 #define FLAG_MASK ((uint32_t)0x00FFFFFF) /*<! I2C FLAG mask */
109 #define ITEN_MASK ((uint32_t)0x07000000) /*<! I2C Interrupt Enable mask */
111 /* Private macro -------------------------------------------------------------*/
112 /* Private variables ---------------------------------------------------------*/
113 /* Private function prototypes -----------------------------------------------*/
114 /* Private functions ---------------------------------------------------------*/
116 /** @defgroup I2C_Private_Functions
117 * @{
120 /** @defgroup I2C_Group1 Initialization and Configuration functions
121 * @brief Initialization and Configuration functions
123 @verbatim
124 ===============================================================================
125 ##### Initialization and Configuration functions #####
126 ===============================================================================
128 @endverbatim
129 * @{
133 * @brief Deinitialize the I2Cx peripheral registers to their default reset values.
134 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
135 * @retval None
137 void I2C_DeInit(I2C_TypeDef* I2Cx)
139 /* Check the parameters */
140 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
142 if (I2Cx == I2C1)
144 /* Enable I2C1 reset state */
145 RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C1, ENABLE);
146 /* Release I2C1 from reset state */
147 RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C1, DISABLE);
149 else if (I2Cx == I2C2)
151 /* Enable I2C2 reset state */
152 RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C2, ENABLE);
153 /* Release I2C2 from reset state */
154 RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C2, DISABLE);
156 else
158 if (I2Cx == I2C3)
160 /* Enable I2C3 reset state */
161 RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C3, ENABLE);
162 /* Release I2C3 from reset state */
163 RCC_APB1PeriphResetCmd(RCC_APB1Periph_I2C3, DISABLE);
169 * @brief Initializes the I2Cx peripheral according to the specified
170 * parameters in the I2C_InitStruct.
172 * @note To use the I2C at 400 KHz (in fast mode), the PCLK1 frequency
173 * (I2C peripheral input clock) must be a multiple of 10 MHz.
175 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
176 * @param I2C_InitStruct: pointer to a I2C_InitTypeDef structure that contains
177 * the configuration information for the specified I2C peripheral.
178 * @retval None
180 void I2C_Init(I2C_TypeDef* I2Cx, I2C_InitTypeDef* I2C_InitStruct)
182 uint16_t tmpreg = 0, freqrange = 0;
183 uint16_t result = 0x04;
184 uint32_t pclk1 = 8000000;
185 RCC_ClocksTypeDef rcc_clocks;
186 /* Check the parameters */
187 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
188 assert_param(IS_I2C_CLOCK_SPEED(I2C_InitStruct->I2C_ClockSpeed));
189 assert_param(IS_I2C_MODE(I2C_InitStruct->I2C_Mode));
190 assert_param(IS_I2C_DUTY_CYCLE(I2C_InitStruct->I2C_DutyCycle));
191 assert_param(IS_I2C_OWN_ADDRESS1(I2C_InitStruct->I2C_OwnAddress1));
192 assert_param(IS_I2C_ACK_STATE(I2C_InitStruct->I2C_Ack));
193 assert_param(IS_I2C_ACKNOWLEDGE_ADDRESS(I2C_InitStruct->I2C_AcknowledgedAddress));
195 /*---------------------------- I2Cx CR2 Configuration ------------------------*/
196 /* Get the I2Cx CR2 value */
197 tmpreg = I2Cx->CR2;
198 /* Clear frequency FREQ[5:0] bits */
199 tmpreg &= (uint16_t)~((uint16_t)I2C_CR2_FREQ);
200 /* Get pclk1 frequency value */
201 RCC_GetClocksFreq(&rcc_clocks);
202 pclk1 = rcc_clocks.PCLK1_Frequency;
203 /* Set frequency bits depending on pclk1 value */
204 freqrange = (uint16_t)(pclk1 / 1000000);
205 tmpreg |= freqrange;
206 /* Write to I2Cx CR2 */
207 I2Cx->CR2 = tmpreg;
209 /*---------------------------- I2Cx CCR Configuration ------------------------*/
210 /* Disable the selected I2C peripheral to configure TRISE */
211 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_PE);
212 /* Reset tmpreg value */
213 /* Clear F/S, DUTY and CCR[11:0] bits */
214 tmpreg = 0;
216 /* Configure speed in standard mode */
217 if (I2C_InitStruct->I2C_ClockSpeed <= 100000)
219 /* Standard mode speed calculate */
220 result = (uint16_t)(pclk1 / (I2C_InitStruct->I2C_ClockSpeed << 1));
221 /* Test if CCR value is under 0x4*/
222 if (result < 0x04)
224 /* Set minimum allowed value */
225 result = 0x04;
227 /* Set speed value for standard mode */
228 tmpreg |= result;
229 /* Set Maximum Rise Time for standard mode */
230 I2Cx->TRISE = freqrange + 1;
232 /* Configure speed in fast mode */
233 /* To use the I2C at 400 KHz (in fast mode), the PCLK1 frequency (I2C peripheral
234 input clock) must be a multiple of 10 MHz */
235 else /*(I2C_InitStruct->I2C_ClockSpeed <= 400000)*/
237 if (I2C_InitStruct->I2C_DutyCycle == I2C_DutyCycle_2)
239 /* Fast mode speed calculate: Tlow/Thigh = 2 */
240 result = (uint16_t)(pclk1 / (I2C_InitStruct->I2C_ClockSpeed * 3));
242 else /*I2C_InitStruct->I2C_DutyCycle == I2C_DutyCycle_16_9*/
244 /* Fast mode speed calculate: Tlow/Thigh = 16/9 */
245 result = (uint16_t)(pclk1 / (I2C_InitStruct->I2C_ClockSpeed * 25));
246 /* Set DUTY bit */
247 result |= I2C_DutyCycle_16_9;
250 /* Test if CCR value is under 0x1*/
251 if ((result & I2C_CCR_CCR) == 0)
253 /* Set minimum allowed value */
254 result |= (uint16_t)0x0001;
256 /* Set speed value and set F/S bit for fast mode */
257 tmpreg |= (uint16_t)(result | I2C_CCR_FS);
258 /* Set Maximum Rise Time for fast mode */
259 I2Cx->TRISE = (uint16_t)(((freqrange * (uint16_t)300) / (uint16_t)1000) + (uint16_t)1);
262 /* Write to I2Cx CCR */
263 I2Cx->CCR = tmpreg;
264 /* Enable the selected I2C peripheral */
265 I2Cx->CR1 |= I2C_CR1_PE;
267 /*---------------------------- I2Cx CR1 Configuration ------------------------*/
268 /* Get the I2Cx CR1 value */
269 tmpreg = I2Cx->CR1;
270 /* Clear ACK, SMBTYPE and SMBUS bits */
271 tmpreg &= CR1_CLEAR_MASK;
272 /* Configure I2Cx: mode and acknowledgement */
273 /* Set SMBTYPE and SMBUS bits according to I2C_Mode value */
274 /* Set ACK bit according to I2C_Ack value */
275 tmpreg |= (uint16_t)((uint32_t)I2C_InitStruct->I2C_Mode | I2C_InitStruct->I2C_Ack);
276 /* Write to I2Cx CR1 */
277 I2Cx->CR1 = tmpreg;
279 /*---------------------------- I2Cx OAR1 Configuration -----------------------*/
280 /* Set I2Cx Own Address1 and acknowledged address */
281 I2Cx->OAR1 = (I2C_InitStruct->I2C_AcknowledgedAddress | I2C_InitStruct->I2C_OwnAddress1);
285 * @brief Fills each I2C_InitStruct member with its default value.
286 * @param I2C_InitStruct: pointer to an I2C_InitTypeDef structure which will be initialized.
287 * @retval None
289 void I2C_StructInit(I2C_InitTypeDef* I2C_InitStruct)
291 /*---------------- Reset I2C init structure parameters values ----------------*/
292 /* initialize the I2C_ClockSpeed member */
293 I2C_InitStruct->I2C_ClockSpeed = 5000;
294 /* Initialize the I2C_Mode member */
295 I2C_InitStruct->I2C_Mode = I2C_Mode_I2C;
296 /* Initialize the I2C_DutyCycle member */
297 I2C_InitStruct->I2C_DutyCycle = I2C_DutyCycle_2;
298 /* Initialize the I2C_OwnAddress1 member */
299 I2C_InitStruct->I2C_OwnAddress1 = 0;
300 /* Initialize the I2C_Ack member */
301 I2C_InitStruct->I2C_Ack = I2C_Ack_Disable;
302 /* Initialize the I2C_AcknowledgedAddress member */
303 I2C_InitStruct->I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit;
307 * @brief Enables or disables the specified I2C peripheral.
308 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
309 * @param NewState: new state of the I2Cx peripheral.
310 * This parameter can be: ENABLE or DISABLE.
311 * @retval None
313 void I2C_Cmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
315 /* Check the parameters */
316 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
317 assert_param(IS_FUNCTIONAL_STATE(NewState));
318 if (NewState != DISABLE)
320 /* Enable the selected I2C peripheral */
321 I2Cx->CR1 |= I2C_CR1_PE;
323 else
325 /* Disable the selected I2C peripheral */
326 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_PE);
331 * @brief Enables or disables the Analog filter of I2C peripheral.
333 * @note This function can be used only for STM32F42xxx/STM3243xxx, STM32F401xx, STM32F410xx and STM32F411xE devices.
335 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
336 * @param NewState: new state of the Analog filter.
337 * This parameter can be: ENABLE or DISABLE.
338 * @note This function should be called before initializing and enabling
339 the I2C Peripheral.
340 * @retval None
342 void I2C_AnalogFilterCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
344 /* Check the parameters */
345 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
346 assert_param(IS_FUNCTIONAL_STATE(NewState));
347 if (NewState != DISABLE)
349 /* Enable the analog filter */
350 I2Cx->FLTR &= (uint16_t)~((uint16_t)I2C_FLTR_ANOFF);
352 else
354 /* Disable the analog filter */
355 I2Cx->FLTR |= I2C_FLTR_ANOFF;
360 * @brief Configures the Digital noise filter of I2C peripheral.
362 * @note This function can be used only for STM32F42xxx/STM3243xxx, STM32F401xx, STM32F410xx and STM32F411xE devices.
364 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
365 * @param I2C_DigitalFilter: Coefficient of digital noise filter.
366 * This parameter can be a number between 0x00 and 0x0F.
367 * @note This function should be called before initializing and enabling
368 the I2C Peripheral.
369 * @retval None
371 void I2C_DigitalFilterConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DigitalFilter)
373 uint16_t tmpreg = 0;
375 /* Check the parameters */
376 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
377 assert_param(IS_I2C_DIGITAL_FILTER(I2C_DigitalFilter));
379 /* Get the old register value */
380 tmpreg = I2Cx->FLTR;
382 /* Reset I2Cx DNF bit [3:0] */
383 tmpreg &= (uint16_t)~((uint16_t)I2C_FLTR_DNF);
385 /* Set I2Cx DNF coefficient */
386 tmpreg |= (uint16_t)((uint16_t)I2C_DigitalFilter & I2C_FLTR_DNF);
388 /* Store the new register value */
389 I2Cx->FLTR = tmpreg;
393 * @brief Generates I2Cx communication START condition.
394 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
395 * @param NewState: new state of the I2C START condition generation.
396 * This parameter can be: ENABLE or DISABLE.
397 * @retval None.
399 void I2C_GenerateSTART(I2C_TypeDef* I2Cx, FunctionalState NewState)
401 /* Check the parameters */
402 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
403 assert_param(IS_FUNCTIONAL_STATE(NewState));
404 if (NewState != DISABLE)
406 /* Generate a START condition */
407 I2Cx->CR1 |= I2C_CR1_START;
409 else
411 /* Disable the START condition generation */
412 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_START);
417 * @brief Generates I2Cx communication STOP condition.
418 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
419 * @param NewState: new state of the I2C STOP condition generation.
420 * This parameter can be: ENABLE or DISABLE.
421 * @retval None.
423 void I2C_GenerateSTOP(I2C_TypeDef* I2Cx, FunctionalState NewState)
425 /* Check the parameters */
426 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
427 assert_param(IS_FUNCTIONAL_STATE(NewState));
428 if (NewState != DISABLE)
430 /* Generate a STOP condition */
431 I2Cx->CR1 |= I2C_CR1_STOP;
433 else
435 /* Disable the STOP condition generation */
436 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_STOP);
441 * @brief Transmits the address byte to select the slave device.
442 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
443 * @param Address: specifies the slave address which will be transmitted
444 * @param I2C_Direction: specifies whether the I2C device will be a Transmitter
445 * or a Receiver.
446 * This parameter can be one of the following values
447 * @arg I2C_Direction_Transmitter: Transmitter mode
448 * @arg I2C_Direction_Receiver: Receiver mode
449 * @retval None.
451 void I2C_Send7bitAddress(I2C_TypeDef* I2Cx, uint8_t Address, uint8_t I2C_Direction)
453 /* Check the parameters */
454 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
455 assert_param(IS_I2C_DIRECTION(I2C_Direction));
456 /* Test on the direction to set/reset the read/write bit */
457 if (I2C_Direction != I2C_Direction_Transmitter)
459 /* Set the address bit0 for read */
460 Address |= I2C_OAR1_ADD0;
462 else
464 /* Reset the address bit0 for write */
465 Address &= (uint8_t)~((uint8_t)I2C_OAR1_ADD0);
467 /* Send the address */
468 I2Cx->DR = Address;
472 * @brief Enables or disables the specified I2C acknowledge feature.
473 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
474 * @param NewState: new state of the I2C Acknowledgement.
475 * This parameter can be: ENABLE or DISABLE.
476 * @retval None.
478 void I2C_AcknowledgeConfig(I2C_TypeDef* I2Cx, FunctionalState NewState)
480 /* Check the parameters */
481 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
482 assert_param(IS_FUNCTIONAL_STATE(NewState));
483 if (NewState != DISABLE)
485 /* Enable the acknowledgement */
486 I2Cx->CR1 |= I2C_CR1_ACK;
488 else
490 /* Disable the acknowledgement */
491 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ACK);
496 * @brief Configures the specified I2C own address2.
497 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
498 * @param Address: specifies the 7bit I2C own address2.
499 * @retval None.
501 void I2C_OwnAddress2Config(I2C_TypeDef* I2Cx, uint8_t Address)
503 uint16_t tmpreg = 0;
505 /* Check the parameters */
506 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
508 /* Get the old register value */
509 tmpreg = I2Cx->OAR2;
511 /* Reset I2Cx Own address2 bit [7:1] */
512 tmpreg &= (uint16_t)~((uint16_t)I2C_OAR2_ADD2);
514 /* Set I2Cx Own address2 */
515 tmpreg |= (uint16_t)((uint16_t)Address & (uint16_t)0x00FE);
517 /* Store the new register value */
518 I2Cx->OAR2 = tmpreg;
522 * @brief Enables or disables the specified I2C dual addressing mode.
523 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
524 * @param NewState: new state of the I2C dual addressing mode.
525 * This parameter can be: ENABLE or DISABLE.
526 * @retval None
528 void I2C_DualAddressCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
530 /* Check the parameters */
531 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
532 assert_param(IS_FUNCTIONAL_STATE(NewState));
533 if (NewState != DISABLE)
535 /* Enable dual addressing mode */
536 I2Cx->OAR2 |= I2C_OAR2_ENDUAL;
538 else
540 /* Disable dual addressing mode */
541 I2Cx->OAR2 &= (uint16_t)~((uint16_t)I2C_OAR2_ENDUAL);
546 * @brief Enables or disables the specified I2C general call feature.
547 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
548 * @param NewState: new state of the I2C General call.
549 * This parameter can be: ENABLE or DISABLE.
550 * @retval None
552 void I2C_GeneralCallCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
554 /* Check the parameters */
555 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
556 assert_param(IS_FUNCTIONAL_STATE(NewState));
557 if (NewState != DISABLE)
559 /* Enable general call */
560 I2Cx->CR1 |= I2C_CR1_ENGC;
562 else
564 /* Disable general call */
565 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ENGC);
570 * @brief Enables or disables the specified I2C software reset.
571 * @note When software reset is enabled, the I2C IOs are released (this can
572 * be useful to recover from bus errors).
573 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
574 * @param NewState: new state of the I2C software reset.
575 * This parameter can be: ENABLE or DISABLE.
576 * @retval None
578 void I2C_SoftwareResetCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
580 /* Check the parameters */
581 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
582 assert_param(IS_FUNCTIONAL_STATE(NewState));
583 if (NewState != DISABLE)
585 /* Peripheral under reset */
586 I2Cx->CR1 |= I2C_CR1_SWRST;
588 else
590 /* Peripheral not under reset */
591 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_SWRST);
596 * @brief Enables or disables the specified I2C Clock stretching.
597 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
598 * @param NewState: new state of the I2Cx Clock stretching.
599 * This parameter can be: ENABLE or DISABLE.
600 * @retval None
602 void I2C_StretchClockCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
604 /* Check the parameters */
605 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
606 assert_param(IS_FUNCTIONAL_STATE(NewState));
607 if (NewState == DISABLE)
609 /* Enable the selected I2C Clock stretching */
610 I2Cx->CR1 |= I2C_CR1_NOSTRETCH;
612 else
614 /* Disable the selected I2C Clock stretching */
615 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_NOSTRETCH);
620 * @brief Selects the specified I2C fast mode duty cycle.
621 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
622 * @param I2C_DutyCycle: specifies the fast mode duty cycle.
623 * This parameter can be one of the following values:
624 * @arg I2C_DutyCycle_2: I2C fast mode Tlow/Thigh = 2
625 * @arg I2C_DutyCycle_16_9: I2C fast mode Tlow/Thigh = 16/9
626 * @retval None
628 void I2C_FastModeDutyCycleConfig(I2C_TypeDef* I2Cx, uint16_t I2C_DutyCycle)
630 /* Check the parameters */
631 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
632 assert_param(IS_I2C_DUTY_CYCLE(I2C_DutyCycle));
633 if (I2C_DutyCycle != I2C_DutyCycle_16_9)
635 /* I2C fast mode Tlow/Thigh=2 */
636 I2Cx->CCR &= I2C_DutyCycle_2;
638 else
640 /* I2C fast mode Tlow/Thigh=16/9 */
641 I2Cx->CCR |= I2C_DutyCycle_16_9;
646 * @brief Selects the specified I2C NACK position in master receiver mode.
647 * @note This function is useful in I2C Master Receiver mode when the number
648 * of data to be received is equal to 2. In this case, this function
649 * should be called (with parameter I2C_NACKPosition_Next) before data
650 * reception starts,as described in the 2-byte reception procedure
651 * recommended in Reference Manual in Section: Master receiver.
652 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
653 * @param I2C_NACKPosition: specifies the NACK position.
654 * This parameter can be one of the following values:
655 * @arg I2C_NACKPosition_Next: indicates that the next byte will be the last
656 * received byte.
657 * @arg I2C_NACKPosition_Current: indicates that current byte is the last
658 * received byte.
660 * @note This function configures the same bit (POS) as I2C_PECPositionConfig()
661 * but is intended to be used in I2C mode while I2C_PECPositionConfig()
662 * is intended to used in SMBUS mode.
664 * @retval None
666 void I2C_NACKPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_NACKPosition)
668 /* Check the parameters */
669 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
670 assert_param(IS_I2C_NACK_POSITION(I2C_NACKPosition));
672 /* Check the input parameter */
673 if (I2C_NACKPosition == I2C_NACKPosition_Next)
675 /* Next byte in shift register is the last received byte */
676 I2Cx->CR1 |= I2C_NACKPosition_Next;
678 else
680 /* Current byte in shift register is the last received byte */
681 I2Cx->CR1 &= I2C_NACKPosition_Current;
686 * @brief Drives the SMBusAlert pin high or low for the specified I2C.
687 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
688 * @param I2C_SMBusAlert: specifies SMBAlert pin level.
689 * This parameter can be one of the following values:
690 * @arg I2C_SMBusAlert_Low: SMBAlert pin driven low
691 * @arg I2C_SMBusAlert_High: SMBAlert pin driven high
692 * @retval None
694 void I2C_SMBusAlertConfig(I2C_TypeDef* I2Cx, uint16_t I2C_SMBusAlert)
696 /* Check the parameters */
697 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
698 assert_param(IS_I2C_SMBUS_ALERT(I2C_SMBusAlert));
699 if (I2C_SMBusAlert == I2C_SMBusAlert_Low)
701 /* Drive the SMBusAlert pin Low */
702 I2Cx->CR1 |= I2C_SMBusAlert_Low;
704 else
706 /* Drive the SMBusAlert pin High */
707 I2Cx->CR1 &= I2C_SMBusAlert_High;
712 * @brief Enables or disables the specified I2C ARP.
713 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
714 * @param NewState: new state of the I2Cx ARP.
715 * This parameter can be: ENABLE or DISABLE.
716 * @retval None
718 void I2C_ARPCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
720 /* Check the parameters */
721 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
722 assert_param(IS_FUNCTIONAL_STATE(NewState));
723 if (NewState != DISABLE)
725 /* Enable the selected I2C ARP */
726 I2Cx->CR1 |= I2C_CR1_ENARP;
728 else
730 /* Disable the selected I2C ARP */
731 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ENARP);
735 * @}
738 /** @defgroup I2C_Group2 Data transfers functions
739 * @brief Data transfers functions
741 @verbatim
742 ===============================================================================
743 ##### Data transfers functions #####
744 ===============================================================================
746 @endverbatim
747 * @{
751 * @brief Sends a data byte through the I2Cx peripheral.
752 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
753 * @param Data: Byte to be transmitted..
754 * @retval None
756 void I2C_SendData(I2C_TypeDef* I2Cx, uint8_t Data)
758 /* Check the parameters */
759 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
760 /* Write in the DR register the data to be sent */
761 I2Cx->DR = Data;
765 * @brief Returns the most recent received data by the I2Cx peripheral.
766 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
767 * @retval The value of the received data.
769 uint8_t I2C_ReceiveData(I2C_TypeDef* I2Cx)
771 /* Check the parameters */
772 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
773 /* Return the data in the DR register */
774 return (uint8_t)I2Cx->DR;
778 * @}
781 /** @defgroup I2C_Group3 PEC management functions
782 * @brief PEC management functions
784 @verbatim
785 ===============================================================================
786 ##### PEC management functions #####
787 ===============================================================================
789 @endverbatim
790 * @{
794 * @brief Enables or disables the specified I2C PEC transfer.
795 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
796 * @param NewState: new state of the I2C PEC transmission.
797 * This parameter can be: ENABLE or DISABLE.
798 * @retval None
800 void I2C_TransmitPEC(I2C_TypeDef* I2Cx, FunctionalState NewState)
802 /* Check the parameters */
803 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
804 assert_param(IS_FUNCTIONAL_STATE(NewState));
805 if (NewState != DISABLE)
807 /* Enable the selected I2C PEC transmission */
808 I2Cx->CR1 |= I2C_CR1_PEC;
810 else
812 /* Disable the selected I2C PEC transmission */
813 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_PEC);
818 * @brief Selects the specified I2C PEC position.
819 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
820 * @param I2C_PECPosition: specifies the PEC position.
821 * This parameter can be one of the following values:
822 * @arg I2C_PECPosition_Next: indicates that the next byte is PEC
823 * @arg I2C_PECPosition_Current: indicates that current byte is PEC
825 * @note This function configures the same bit (POS) as I2C_NACKPositionConfig()
826 * but is intended to be used in SMBUS mode while I2C_NACKPositionConfig()
827 * is intended to used in I2C mode.
829 * @retval None
831 void I2C_PECPositionConfig(I2C_TypeDef* I2Cx, uint16_t I2C_PECPosition)
833 /* Check the parameters */
834 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
835 assert_param(IS_I2C_PEC_POSITION(I2C_PECPosition));
836 if (I2C_PECPosition == I2C_PECPosition_Next)
838 /* Next byte in shift register is PEC */
839 I2Cx->CR1 |= I2C_PECPosition_Next;
841 else
843 /* Current byte in shift register is PEC */
844 I2Cx->CR1 &= I2C_PECPosition_Current;
849 * @brief Enables or disables the PEC value calculation of the transferred bytes.
850 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
851 * @param NewState: new state of the I2Cx PEC value calculation.
852 * This parameter can be: ENABLE or DISABLE.
853 * @retval None
855 void I2C_CalculatePEC(I2C_TypeDef* I2Cx, FunctionalState NewState)
857 /* Check the parameters */
858 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
859 assert_param(IS_FUNCTIONAL_STATE(NewState));
860 if (NewState != DISABLE)
862 /* Enable the selected I2C PEC calculation */
863 I2Cx->CR1 |= I2C_CR1_ENPEC;
865 else
867 /* Disable the selected I2C PEC calculation */
868 I2Cx->CR1 &= (uint16_t)~((uint16_t)I2C_CR1_ENPEC);
873 * @brief Returns the PEC value for the specified I2C.
874 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
875 * @retval The PEC value.
877 uint8_t I2C_GetPEC(I2C_TypeDef* I2Cx)
879 /* Check the parameters */
880 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
881 /* Return the selected I2C PEC value */
882 return ((I2Cx->SR2) >> 8);
886 * @}
889 /** @defgroup I2C_Group4 DMA transfers management functions
890 * @brief DMA transfers management functions
892 @verbatim
893 ===============================================================================
894 ##### DMA transfers management functions #####
895 ===============================================================================
896 This section provides functions allowing to configure the I2C DMA channels
897 requests.
899 @endverbatim
900 * @{
904 * @brief Enables or disables the specified I2C DMA requests.
905 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
906 * @param NewState: new state of the I2C DMA transfer.
907 * This parameter can be: ENABLE or DISABLE.
908 * @retval None
910 void I2C_DMACmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
912 /* Check the parameters */
913 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
914 assert_param(IS_FUNCTIONAL_STATE(NewState));
915 if (NewState != DISABLE)
917 /* Enable the selected I2C DMA requests */
918 I2Cx->CR2 |= I2C_CR2_DMAEN;
920 else
922 /* Disable the selected I2C DMA requests */
923 I2Cx->CR2 &= (uint16_t)~((uint16_t)I2C_CR2_DMAEN);
928 * @brief Specifies that the next DMA transfer is the last one.
929 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
930 * @param NewState: new state of the I2C DMA last transfer.
931 * This parameter can be: ENABLE or DISABLE.
932 * @retval None
934 void I2C_DMALastTransferCmd(I2C_TypeDef* I2Cx, FunctionalState NewState)
936 /* Check the parameters */
937 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
938 assert_param(IS_FUNCTIONAL_STATE(NewState));
939 if (NewState != DISABLE)
941 /* Next DMA transfer is the last transfer */
942 I2Cx->CR2 |= I2C_CR2_LAST;
944 else
946 /* Next DMA transfer is not the last transfer */
947 I2Cx->CR2 &= (uint16_t)~((uint16_t)I2C_CR2_LAST);
952 * @}
955 /** @defgroup I2C_Group5 Interrupts events and flags management functions
956 * @brief Interrupts, events and flags management functions
958 @verbatim
959 ===============================================================================
960 ##### Interrupts, events and flags management functions #####
961 ===============================================================================
962 [..]
963 This section provides functions allowing to configure the I2C Interrupts
964 sources and check or clear the flags or pending bits status.
965 The user should identify which mode will be used in his application to manage
966 the communication: Polling mode, Interrupt mode or DMA mode.
969 ##### I2C State Monitoring Functions #####
970 ===============================================================================
971 [..]
972 This I2C driver provides three different ways for I2C state monitoring
973 depending on the application requirements and constraints:
976 (#) Basic state monitoring (Using I2C_CheckEvent() function)
978 It compares the status registers (SR1 and SR2) content to a given event
979 (can be the combination of one or more flags).
980 It returns SUCCESS if the current status includes the given flags
981 and returns ERROR if one or more flags are missing in the current status.
983 (++) When to use
984 (+++) This function is suitable for most applications as well as for startup
985 activity since the events are fully described in the product reference
986 manual (RM0090).
987 (+++) It is also suitable for users who need to define their own events.
989 (++) Limitations
990 If an error occurs (ie. error flags are set besides to the monitored
991 flags), the I2C_CheckEvent() function may return SUCCESS despite
992 the communication hold or corrupted real state.
993 In this case, it is advised to use error interrupts to monitor
994 the error events and handle them in the interrupt IRQ handler.
996 -@@- For error management, it is advised to use the following functions:
997 (+@@) I2C_ITConfig() to configure and enable the error interrupts (I2C_IT_ERR).
998 (+@@) I2Cx_ER_IRQHandler() which is called when the error interrupt occurs.
999 Where x is the peripheral instance (I2C1, I2C2 ...)
1000 (+@@) I2C_GetFlagStatus() or I2C_GetITStatus() to be called into the
1001 I2Cx_ER_IRQHandler() function in order to determine which error occurred.
1002 (+@@) I2C_ClearFlag() or I2C_ClearITPendingBit() and/or I2C_SoftwareResetCmd()
1003 and/or I2C_GenerateStop() in order to clear the error flag and source
1004 and return to correct communication status.
1007 (#) Advanced state monitoring (Using the function I2C_GetLastEvent())
1009 Using the function I2C_GetLastEvent() which returns the image of both status
1010 registers in a single word (uint32_t) (Status Register 2 value is shifted left
1011 by 16 bits and concatenated to Status Register 1).
1013 (++) When to use
1014 (+++) This function is suitable for the same applications above but it
1015 allows to overcome the mentioned limitation of I2C_GetFlagStatus()
1016 function.
1017 (+++) The returned value could be compared to events already defined in
1018 the library (stm32f4xx_i2c.h) or to custom values defined by user.
1019 This function is suitable when multiple flags are monitored at the
1020 same time.
1021 (+++) At the opposite of I2C_CheckEvent() function, this function allows
1022 user to choose when an event is accepted (when all events flags are
1023 set and no other flags are set or just when the needed flags are set
1024 like I2C_CheckEvent() function.
1026 (++) Limitations
1027 (+++) User may need to define his own events.
1028 (+++) Same remark concerning the error management is applicable for this
1029 function if user decides to check only regular communication flags
1030 (and ignores error flags).
1033 (#) Flag-based state monitoring (Using the function I2C_GetFlagStatus())
1035 Using the function I2C_GetFlagStatus() which simply returns the status of
1036 one single flag (ie. I2C_FLAG_RXNE ...).
1038 (++) When to use
1039 (+++) This function could be used for specific applications or in debug
1040 phase.
1041 (+++) It is suitable when only one flag checking is needed (most I2C
1042 events are monitored through multiple flags).
1043 (++) Limitations:
1044 (+++) When calling this function, the Status register is accessed.
1045 Some flags are cleared when the status register is accessed.
1046 So checking the status of one Flag, may clear other ones.
1047 (+++) Function may need to be called twice or more in order to monitor
1048 one single event.
1050 For detailed description of Events, please refer to section I2C_Events in
1051 stm32f4xx_i2c.h file.
1053 @endverbatim
1054 * @{
1058 * @brief Reads the specified I2C register and returns its value.
1059 * @param I2C_Register: specifies the register to read.
1060 * This parameter can be one of the following values:
1061 * @arg I2C_Register_CR1: CR1 register.
1062 * @arg I2C_Register_CR2: CR2 register.
1063 * @arg I2C_Register_OAR1: OAR1 register.
1064 * @arg I2C_Register_OAR2: OAR2 register.
1065 * @arg I2C_Register_DR: DR register.
1066 * @arg I2C_Register_SR1: SR1 register.
1067 * @arg I2C_Register_SR2: SR2 register.
1068 * @arg I2C_Register_CCR: CCR register.
1069 * @arg I2C_Register_TRISE: TRISE register.
1070 * @retval The value of the read register.
1072 uint16_t I2C_ReadRegister(I2C_TypeDef* I2Cx, uint8_t I2C_Register)
1074 __IO uint32_t tmp = 0;
1076 /* Check the parameters */
1077 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1078 assert_param(IS_I2C_REGISTER(I2C_Register));
1080 tmp = (uint32_t) I2Cx;
1081 tmp += I2C_Register;
1083 /* Return the selected register value */
1084 return (*(__IO uint16_t *) tmp);
1088 * @brief Enables or disables the specified I2C interrupts.
1089 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1090 * @param I2C_IT: specifies the I2C interrupts sources to be enabled or disabled.
1091 * This parameter can be any combination of the following values:
1092 * @arg I2C_IT_BUF: Buffer interrupt mask
1093 * @arg I2C_IT_EVT: Event interrupt mask
1094 * @arg I2C_IT_ERR: Error interrupt mask
1095 * @param NewState: new state of the specified I2C interrupts.
1096 * This parameter can be: ENABLE or DISABLE.
1097 * @retval None
1099 void I2C_ITConfig(I2C_TypeDef* I2Cx, uint16_t I2C_IT, FunctionalState NewState)
1101 /* Check the parameters */
1102 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1103 assert_param(IS_FUNCTIONAL_STATE(NewState));
1104 assert_param(IS_I2C_CONFIG_IT(I2C_IT));
1106 if (NewState != DISABLE)
1108 /* Enable the selected I2C interrupts */
1109 I2Cx->CR2 |= I2C_IT;
1111 else
1113 /* Disable the selected I2C interrupts */
1114 I2Cx->CR2 &= (uint16_t)~I2C_IT;
1119 ===============================================================================
1120 1. Basic state monitoring
1121 ===============================================================================
1125 * @brief Checks whether the last I2Cx Event is equal to the one passed
1126 * as parameter.
1127 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1128 * @param I2C_EVENT: specifies the event to be checked.
1129 * This parameter can be one of the following values:
1130 * @arg I2C_EVENT_SLAVE_TRANSMITTER_ADDRESS_MATCHED: EV1
1131 * @arg I2C_EVENT_SLAVE_RECEIVER_ADDRESS_MATCHED: EV1
1132 * @arg I2C_EVENT_SLAVE_TRANSMITTER_SECONDADDRESS_MATCHED: EV1
1133 * @arg I2C_EVENT_SLAVE_RECEIVER_SECONDADDRESS_MATCHED: EV1
1134 * @arg I2C_EVENT_SLAVE_GENERALCALLADDRESS_MATCHED: EV1
1135 * @arg I2C_EVENT_SLAVE_BYTE_RECEIVED: EV2
1136 * @arg (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_DUALF): EV2
1137 * @arg (I2C_EVENT_SLAVE_BYTE_RECEIVED | I2C_FLAG_GENCALL): EV2
1138 * @arg I2C_EVENT_SLAVE_BYTE_TRANSMITTED: EV3
1139 * @arg (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_DUALF): EV3
1140 * @arg (I2C_EVENT_SLAVE_BYTE_TRANSMITTED | I2C_FLAG_GENCALL): EV3
1141 * @arg I2C_EVENT_SLAVE_ACK_FAILURE: EV3_2
1142 * @arg I2C_EVENT_SLAVE_STOP_DETECTED: EV4
1143 * @arg I2C_EVENT_MASTER_MODE_SELECT: EV5
1144 * @arg I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED: EV6
1145 * @arg I2C_EVENT_MASTER_RECEIVER_MODE_SELECTED: EV6
1146 * @arg I2C_EVENT_MASTER_BYTE_RECEIVED: EV7
1147 * @arg I2C_EVENT_MASTER_BYTE_TRANSMITTING: EV8
1148 * @arg I2C_EVENT_MASTER_BYTE_TRANSMITTED: EV8_2
1149 * @arg I2C_EVENT_MASTER_MODE_ADDRESS10: EV9
1151 * @note For detailed description of Events, please refer to section I2C_Events
1152 * in stm32f4xx_i2c.h file.
1154 * @retval An ErrorStatus enumeration value:
1155 * - SUCCESS: Last event is equal to the I2C_EVENT
1156 * - ERROR: Last event is different from the I2C_EVENT
1158 ErrorStatus I2C_CheckEvent(I2C_TypeDef* I2Cx, uint32_t I2C_EVENT)
1160 uint32_t lastevent = 0;
1161 uint32_t flag1 = 0, flag2 = 0;
1162 ErrorStatus status = ERROR;
1164 /* Check the parameters */
1165 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1166 assert_param(IS_I2C_EVENT(I2C_EVENT));
1168 /* Read the I2Cx status register */
1169 flag1 = I2Cx->SR1;
1170 flag2 = I2Cx->SR2;
1171 flag2 = flag2 << 16;
1173 /* Get the last event value from I2C status register */
1174 lastevent = (flag1 | flag2) & FLAG_MASK;
1176 /* Check whether the last event contains the I2C_EVENT */
1177 if ((lastevent & I2C_EVENT) == I2C_EVENT)
1179 /* SUCCESS: last event is equal to I2C_EVENT */
1180 status = SUCCESS;
1182 else
1184 /* ERROR: last event is different from I2C_EVENT */
1185 status = ERROR;
1187 /* Return status */
1188 return status;
1192 ===============================================================================
1193 2. Advanced state monitoring
1194 ===============================================================================
1198 * @brief Returns the last I2Cx Event.
1199 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1201 * @note For detailed description of Events, please refer to section I2C_Events
1202 * in stm32f4xx_i2c.h file.
1204 * @retval The last event
1206 uint32_t I2C_GetLastEvent(I2C_TypeDef* I2Cx)
1208 uint32_t lastevent = 0;
1209 uint32_t flag1 = 0, flag2 = 0;
1211 /* Check the parameters */
1212 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1214 /* Read the I2Cx status register */
1215 flag1 = I2Cx->SR1;
1216 flag2 = I2Cx->SR2;
1217 flag2 = flag2 << 16;
1219 /* Get the last event value from I2C status register */
1220 lastevent = (flag1 | flag2) & FLAG_MASK;
1222 /* Return status */
1223 return lastevent;
1227 ===============================================================================
1228 3. Flag-based state monitoring
1229 ===============================================================================
1233 * @brief Checks whether the specified I2C flag is set or not.
1234 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1235 * @param I2C_FLAG: specifies the flag to check.
1236 * This parameter can be one of the following values:
1237 * @arg I2C_FLAG_DUALF: Dual flag (Slave mode)
1238 * @arg I2C_FLAG_SMBHOST: SMBus host header (Slave mode)
1239 * @arg I2C_FLAG_SMBDEFAULT: SMBus default header (Slave mode)
1240 * @arg I2C_FLAG_GENCALL: General call header flag (Slave mode)
1241 * @arg I2C_FLAG_TRA: Transmitter/Receiver flag
1242 * @arg I2C_FLAG_BUSY: Bus busy flag
1243 * @arg I2C_FLAG_MSL: Master/Slave flag
1244 * @arg I2C_FLAG_SMBALERT: SMBus Alert flag
1245 * @arg I2C_FLAG_TIMEOUT: Timeout or Tlow error flag
1246 * @arg I2C_FLAG_PECERR: PEC error in reception flag
1247 * @arg I2C_FLAG_OVR: Overrun/Underrun flag (Slave mode)
1248 * @arg I2C_FLAG_AF: Acknowledge failure flag
1249 * @arg I2C_FLAG_ARLO: Arbitration lost flag (Master mode)
1250 * @arg I2C_FLAG_BERR: Bus error flag
1251 * @arg I2C_FLAG_TXE: Data register empty flag (Transmitter)
1252 * @arg I2C_FLAG_RXNE: Data register not empty (Receiver) flag
1253 * @arg I2C_FLAG_STOPF: Stop detection flag (Slave mode)
1254 * @arg I2C_FLAG_ADD10: 10-bit header sent flag (Master mode)
1255 * @arg I2C_FLAG_BTF: Byte transfer finished flag
1256 * @arg I2C_FLAG_ADDR: Address sent flag (Master mode) "ADSL"
1257 * Address matched flag (Slave mode)"ENDAD"
1258 * @arg I2C_FLAG_SB: Start bit flag (Master mode)
1259 * @retval The new state of I2C_FLAG (SET or RESET).
1261 FlagStatus I2C_GetFlagStatus(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG)
1263 FlagStatus bitstatus = RESET;
1264 __IO uint32_t i2creg = 0, i2cxbase = 0;
1266 /* Check the parameters */
1267 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1268 assert_param(IS_I2C_GET_FLAG(I2C_FLAG));
1270 /* Get the I2Cx peripheral base address */
1271 i2cxbase = (uint32_t)I2Cx;
1273 /* Read flag register index */
1274 i2creg = I2C_FLAG >> 28;
1276 /* Get bit[23:0] of the flag */
1277 I2C_FLAG &= FLAG_MASK;
1279 if(i2creg != 0)
1281 /* Get the I2Cx SR1 register address */
1282 i2cxbase += 0x14;
1284 else
1286 /* Flag in I2Cx SR2 Register */
1287 I2C_FLAG = (uint32_t)(I2C_FLAG >> 16);
1288 /* Get the I2Cx SR2 register address */
1289 i2cxbase += 0x18;
1292 if(((*(__IO uint32_t *)i2cxbase) & I2C_FLAG) != (uint32_t)RESET)
1294 /* I2C_FLAG is set */
1295 bitstatus = SET;
1297 else
1299 /* I2C_FLAG is reset */
1300 bitstatus = RESET;
1303 /* Return the I2C_FLAG status */
1304 return bitstatus;
1308 * @brief Clears the I2Cx's pending flags.
1309 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1310 * @param I2C_FLAG: specifies the flag to clear.
1311 * This parameter can be any combination of the following values:
1312 * @arg I2C_FLAG_SMBALERT: SMBus Alert flag
1313 * @arg I2C_FLAG_TIMEOUT: Timeout or Tlow error flag
1314 * @arg I2C_FLAG_PECERR: PEC error in reception flag
1315 * @arg I2C_FLAG_OVR: Overrun/Underrun flag (Slave mode)
1316 * @arg I2C_FLAG_AF: Acknowledge failure flag
1317 * @arg I2C_FLAG_ARLO: Arbitration lost flag (Master mode)
1318 * @arg I2C_FLAG_BERR: Bus error flag
1320 * @note STOPF (STOP detection) is cleared by software sequence: a read operation
1321 * to I2C_SR1 register (I2C_GetFlagStatus()) followed by a write operation
1322 * to I2C_CR1 register (I2C_Cmd() to re-enable the I2C peripheral).
1323 * @note ADD10 (10-bit header sent) is cleared by software sequence: a read
1324 * operation to I2C_SR1 (I2C_GetFlagStatus()) followed by writing the
1325 * second byte of the address in DR register.
1326 * @note BTF (Byte Transfer Finished) is cleared by software sequence: a read
1327 * operation to I2C_SR1 register (I2C_GetFlagStatus()) followed by a
1328 * read/write to I2C_DR register (I2C_SendData()).
1329 * @note ADDR (Address sent) is cleared by software sequence: a read operation to
1330 * I2C_SR1 register (I2C_GetFlagStatus()) followed by a read operation to
1331 * I2C_SR2 register ((void)(I2Cx->SR2)).
1332 * @note SB (Start Bit) is cleared software sequence: a read operation to I2C_SR1
1333 * register (I2C_GetFlagStatus()) followed by a write operation to I2C_DR
1334 * register (I2C_SendData()).
1336 * @retval None
1338 void I2C_ClearFlag(I2C_TypeDef* I2Cx, uint32_t I2C_FLAG)
1340 uint32_t flagpos = 0;
1341 /* Check the parameters */
1342 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1343 assert_param(IS_I2C_CLEAR_FLAG(I2C_FLAG));
1344 /* Get the I2C flag position */
1345 flagpos = I2C_FLAG & FLAG_MASK;
1346 /* Clear the selected I2C flag */
1347 I2Cx->SR1 = (uint16_t)~flagpos;
1351 * @brief Checks whether the specified I2C interrupt has occurred or not.
1352 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1353 * @param I2C_IT: specifies the interrupt source to check.
1354 * This parameter can be one of the following values:
1355 * @arg I2C_IT_SMBALERT: SMBus Alert flag
1356 * @arg I2C_IT_TIMEOUT: Timeout or Tlow error flag
1357 * @arg I2C_IT_PECERR: PEC error in reception flag
1358 * @arg I2C_IT_OVR: Overrun/Underrun flag (Slave mode)
1359 * @arg I2C_IT_AF: Acknowledge failure flag
1360 * @arg I2C_IT_ARLO: Arbitration lost flag (Master mode)
1361 * @arg I2C_IT_BERR: Bus error flag
1362 * @arg I2C_IT_TXE: Data register empty flag (Transmitter)
1363 * @arg I2C_IT_RXNE: Data register not empty (Receiver) flag
1364 * @arg I2C_IT_STOPF: Stop detection flag (Slave mode)
1365 * @arg I2C_IT_ADD10: 10-bit header sent flag (Master mode)
1366 * @arg I2C_IT_BTF: Byte transfer finished flag
1367 * @arg I2C_IT_ADDR: Address sent flag (Master mode) "ADSL"
1368 * Address matched flag (Slave mode)"ENDAD"
1369 * @arg I2C_IT_SB: Start bit flag (Master mode)
1370 * @retval The new state of I2C_IT (SET or RESET).
1372 ITStatus I2C_GetITStatus(I2C_TypeDef* I2Cx, uint32_t I2C_IT)
1374 ITStatus bitstatus = RESET;
1375 uint32_t enablestatus = 0;
1377 /* Check the parameters */
1378 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1379 assert_param(IS_I2C_GET_IT(I2C_IT));
1381 /* Check if the interrupt source is enabled or not */
1382 enablestatus = (uint32_t)(((I2C_IT & ITEN_MASK) >> 16) & (I2Cx->CR2)) ;
1384 /* Get bit[23:0] of the flag */
1385 I2C_IT &= FLAG_MASK;
1387 /* Check the status of the specified I2C flag */
1388 if (((I2Cx->SR1 & I2C_IT) != (uint32_t)RESET) && enablestatus)
1390 /* I2C_IT is set */
1391 bitstatus = SET;
1393 else
1395 /* I2C_IT is reset */
1396 bitstatus = RESET;
1398 /* Return the I2C_IT status */
1399 return bitstatus;
1403 * @brief Clears the I2Cx's interrupt pending bits.
1404 * @param I2Cx: where x can be 1, 2 or 3 to select the I2C peripheral.
1405 * @param I2C_IT: specifies the interrupt pending bit to clear.
1406 * This parameter can be any combination of the following values:
1407 * @arg I2C_IT_SMBALERT: SMBus Alert interrupt
1408 * @arg I2C_IT_TIMEOUT: Timeout or Tlow error interrupt
1409 * @arg I2C_IT_PECERR: PEC error in reception interrupt
1410 * @arg I2C_IT_OVR: Overrun/Underrun interrupt (Slave mode)
1411 * @arg I2C_IT_AF: Acknowledge failure interrupt
1412 * @arg I2C_IT_ARLO: Arbitration lost interrupt (Master mode)
1413 * @arg I2C_IT_BERR: Bus error interrupt
1415 * @note STOPF (STOP detection) is cleared by software sequence: a read operation
1416 * to I2C_SR1 register (I2C_GetITStatus()) followed by a write operation to
1417 * I2C_CR1 register (I2C_Cmd() to re-enable the I2C peripheral).
1418 * @note ADD10 (10-bit header sent) is cleared by software sequence: a read
1419 * operation to I2C_SR1 (I2C_GetITStatus()) followed by writing the second
1420 * byte of the address in I2C_DR register.
1421 * @note BTF (Byte Transfer Finished) is cleared by software sequence: a read
1422 * operation to I2C_SR1 register (I2C_GetITStatus()) followed by a
1423 * read/write to I2C_DR register (I2C_SendData()).
1424 * @note ADDR (Address sent) is cleared by software sequence: a read operation to
1425 * I2C_SR1 register (I2C_GetITStatus()) followed by a read operation to
1426 * I2C_SR2 register ((void)(I2Cx->SR2)).
1427 * @note SB (Start Bit) is cleared by software sequence: a read operation to
1428 * I2C_SR1 register (I2C_GetITStatus()) followed by a write operation to
1429 * I2C_DR register (I2C_SendData()).
1430 * @retval None
1432 void I2C_ClearITPendingBit(I2C_TypeDef* I2Cx, uint32_t I2C_IT)
1434 uint32_t flagpos = 0;
1435 /* Check the parameters */
1436 assert_param(IS_I2C_ALL_PERIPH(I2Cx));
1437 assert_param(IS_I2C_CLEAR_IT(I2C_IT));
1439 /* Get the I2C flag position */
1440 flagpos = I2C_IT & FLAG_MASK;
1442 /* Clear the selected I2C flag */
1443 I2Cx->SR1 = (uint16_t)~flagpos;
1447 * @}
1451 * @}
1455 * @}
1459 * @}
1462 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/