diff options
Diffstat (limited to 'stmhal/hal/src/stm32f4xx_hal_i2c.c')
| -rw-r--r-- | stmhal/hal/src/stm32f4xx_hal_i2c.c | 345 | 
1 files changed, 130 insertions, 215 deletions
| diff --git a/stmhal/hal/src/stm32f4xx_hal_i2c.c b/stmhal/hal/src/stm32f4xx_hal_i2c.c index b48590636..1c1a0d76d 100644 --- a/stmhal/hal/src/stm32f4xx_hal_i2c.c +++ b/stmhal/hal/src/stm32f4xx_hal_i2c.c @@ -2,8 +2,8 @@    ******************************************************************************
    * @file    stm32f4xx_hal_i2c.c
    * @author  MCD Application Team
 -  * @version V1.0.0
 -  * @date    18-February-2014
 +  * @version V1.1.0
 +  * @date    19-June-2014
    * @brief   I2C HAL module driver.
    *          This file provides firmware functions to manage the following
    *          functionalities of the Inter Integrated Circuit (I2C) peripheral:
 @@ -36,18 +36,18 @@              (+++) Configure the DMA handle parameters
              (+++) Configure the DMA Tx or Rx Stream
              (+++) Associate the initilalized DMA handle to the hi2c DMA Tx or Rx handle
 -            (+++) Configure the priority and enable the NVIC for the transfer complete interrupt on the DMA Tx or Rx Stream
 +            (+++) Configure the priority and enable the NVIC for the transfer complete interrupt on 
 +                  the DMA Tx or Rx Stream
      (#) Configure the Communication Speed, Duty cycle, Addressing mode, Own Address1,
          Dual Addressing mode, Own Address2, General call and Nostretch mode in the hi2c Init structure.
 -    (#) Initialize the I2C registers by calling the HAL_I2C_Init() API:
 -        (+++) These API's configures also the low level Hardware GPIO, CLOCK, CORTEX...etc)
 -            by calling the customed HAL_I2C_MspInit(&hi2c) API.
 +    (#) Initialize the I2C registers by calling the HAL_I2C_Init(), configures also the low level Hardware 
 +        (GPIO, CLOCK, NVIC...etc) by calling the customed HAL_I2C_MspInit(&hi2c) API.
      (#) To check if target device is ready for communication, use the function HAL_I2C_IsDeviceReady()
 -    (#) For I2C IO and IO MEM operations, three mode of operations are available within this driver :
 +    (#) For I2C IO and IO MEM operations, three operation modes are available within this driver :
      *** Polling mode IO operation ***
      =================================
 @@ -141,9 +141,9 @@        (+) __HAL_I2C_ENABLE: Enable the I2C peripheral
        (+) __HAL_I2C_DISABLE: Disable the I2C peripheral
        (+) __HAL_I2C_GET_FLAG : Checks whether the specified I2C flag is set or not
 -      (+) __HAL_I2C_CLEAR_FLAG : Clears the specified I2C pending flag
 -      (+) __HAL_I2C_ENABLE_IT: Enables the specified I2C interrupt
 -      (+) __HAL_I2C_DISABLE_IT: Disables the specified I2C interrupt
 +      (+) __HAL_I2C_CLEAR_FLAG : Clear the specified I2C pending flag
 +      (+) __HAL_I2C_ENABLE_IT: Enable the specified I2C interrupt
 +      (+) __HAL_I2C_DISABLE_IT: Disable the specified I2C interrupt
       [..]
         (@) You can refer to the I2C HAL driver header file for more useful macros
 @@ -270,8 +270,8 @@ static HAL_StatusTypeDef I2C_Slave_AF(I2C_HandleTypeDef *hi2c);  /**
    * @brief  Initializes the I2C according to the specified parameters
    *         in the I2C_InitTypeDef and create the associated handle.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c)
 @@ -348,8 +348,8 @@ HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c)  /**
    * @brief  DeInitializes the I2C peripheral.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c)
 @@ -383,8 +383,8 @@ HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c)  /**
    * @brief I2C MSP Init.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
   __weak void HAL_I2C_MspInit(I2C_HandleTypeDef *hi2c)
 @@ -396,8 +396,8 @@ HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c)  /**
    * @brief I2C MSP DeInit
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
   __weak void HAL_I2C_MspDeInit(I2C_HandleTypeDef *hi2c)
 @@ -422,7 +422,7 @@ HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c)      This subsection provides a set of functions allowing to manage the I2C data
      transfers.
 -    (#) There is two mode of transfer:
 +    (#) There are two modes of transfer:
         (++) Blocking mode : The communication is performed in the polling mode.
              The status of all data processing is returned by the same function
              after finishing transfer.
 @@ -457,7 +457,7 @@ HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c)          (++) HAL_I2C_Mem_Write_DMA()
          (++) HAL_I2C_Mem_Read_DMA()
 -    (#) A set of Transfer Complete Callbacks are provided in No_Blocking mode:
 +    (#) A set of Transfer Complete Callbacks are provided in non Blocking mode:
          (++) HAL_I2C_MemTxCpltCallback()
          (++) HAL_I2C_MemRxCpltCallback()
          (++) HAL_I2C_MasterTxCpltCallback()
 @@ -472,8 +472,8 @@ HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Transmits in master mode an amount of data in blocking mode.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
 @@ -570,8 +570,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Transmit(I2C_HandleTypeDef *hi2c, uint16_t DevA  /**
    * @brief  Receives in master mode an amount of data in blocking mode.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
 @@ -762,8 +762,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAd  /**
    * @brief  Transmits in slave mode an amount of data in blocking mode.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
    * @param  Timeout: Timeout duration
 @@ -867,8 +867,8 @@ HAL_StatusTypeDef HAL_I2C_Slave_Transmit(I2C_HandleTypeDef *hi2c, uint8_t *pData  /**
    * @brief  Receive in slave mode an amount of data in blocking mode
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
    * @param  Timeout: Timeout duration
 @@ -959,8 +959,8 @@ HAL_StatusTypeDef HAL_I2C_Slave_Receive(I2C_HandleTypeDef *hi2c, uint8_t *pData,  /**
    * @brief  Transmit in master mode an amount of data in no-blocking mode with Interrupt
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
 @@ -1030,8 +1030,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t D  /**
    * @brief  Receive in master mode an amount of data in no-blocking mode with Interrupt
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
 @@ -1129,8 +1129,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t De  /**
    * @brief  Transmit in slave mode an amount of data in no-blocking mode with Interrupt
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
    * @retval HAL status
 @@ -1182,8 +1182,8 @@ HAL_StatusTypeDef HAL_I2C_Slave_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pD  /**
    * @brief  Receive in slave mode an amount of data in no-blocking mode with Interrupt
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
    * @retval HAL status
 @@ -1235,8 +1235,8 @@ HAL_StatusTypeDef HAL_I2C_Slave_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pDa  /**
    * @brief  Transmit in master mode an amount of data in no-blocking mode with DMA
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
 @@ -1311,8 +1311,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t  /**
    * @brief  Receive in master mode an amount of data in no-blocking mode with DMA
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
 @@ -1398,8 +1398,8 @@ HAL_StatusTypeDef HAL_I2C_Master_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t D  /**
    * @brief  Transmit in slave mode an amount of data in no-blocking mode with DMA
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
    * @retval HAL status
 @@ -1483,8 +1483,8 @@ HAL_StatusTypeDef HAL_I2C_Slave_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *p  /**
    * @brief  Receive in slave mode an amount of data in no-blocking mode with DMA
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  pData: Pointer to data buffer
    * @param  Size: Amount of data to be sent
    * @retval HAL status
 @@ -1549,8 +1549,8 @@ HAL_StatusTypeDef HAL_I2C_Slave_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pD  }
  /**
    * @brief  Write an amount of data in blocking mode to a specific memory address
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -1649,8 +1649,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Write(I2C_HandleTypeDef *hi2c, uint16_t DevAddress  /**
    * @brief  Read an amount of data in blocking mode from a specific memory address
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -1842,8 +1842,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress,  }
  /**
    * @brief  Write an amount of data in no-blocking mode with Interrupt to a specific memory address
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -1915,8 +1915,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Write_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddr  /**
    * @brief  Read an amount of data in no-blocking mode with Interrupt from a specific memory address
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -2018,8 +2018,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Read_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddre  }
  /**
    * @brief  Write an amount of data in no-blocking mode with DMA to a specific memory address
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -2096,8 +2096,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Write_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAdd  /**
    * @brief  Reads an amount of data in no-blocking mode with DMA from a specific memory address.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -2189,8 +2189,8 @@ HAL_StatusTypeDef HAL_I2C_Mem_Read_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddr  /**
    * @brief  Checks if target device is ready for communication.
    * @note   This function is used with Memory devices
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  Trials: Number of trials
    * @param  Timeout: Timeout duration
 @@ -2198,7 +2198,7 @@ HAL_StatusTypeDef HAL_I2C_Mem_Read_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddr    */
  HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint32_t Trials, uint32_t Timeout)
  {
 -  uint32_t timeout = 0, tmp1 = 0, tmp2 = 0, tmp3 = 0, I2C_Trials = 1;
 +  uint32_t tickstart = 0, tmp1 = 0, tmp2 = 0, tmp3 = 0, I2C_Trials = 1;
    if(hi2c->State == HAL_I2C_STATE_READY)
    {
 @@ -2228,14 +2228,15 @@ HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAdd        hi2c->Instance->DR = __HAL_I2C_7BIT_ADD_WRITE(DevAddress);
        /* Wait until ADDR or AF flag are set */
 -      timeout = HAL_GetTick() + Timeout;
 +      /* Get tick */
 +      tickstart = HAL_GetTick();
        tmp1 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_ADDR);
        tmp2 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF);
        tmp3 = hi2c->State;
        while((tmp1 == RESET) && (tmp2 == RESET) && (tmp3 != HAL_I2C_STATE_TIMEOUT))
        {
 -        if(HAL_GetTick() >= timeout)
 +        if((Timeout == 0)||((HAL_GetTick() - tickstart ) > Timeout))
          {
            hi2c->State = HAL_I2C_STATE_TIMEOUT;
          }
 @@ -2299,8 +2300,8 @@ HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAdd  /**
    * @brief  This function handles I2C event interrupt request.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c)
 @@ -2404,8 +2405,8 @@ void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c)  /**
    * @brief  This function handles I2C error interrupt request.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)
 @@ -2474,8 +2475,8 @@ void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Master Tx Transfer completed callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
   __weak void HAL_I2C_MasterTxCpltCallback(I2C_HandleTypeDef *hi2c)
 @@ -2487,8 +2488,8 @@ void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Master Rx Transfer completed callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
  __weak void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c)
 @@ -2499,8 +2500,8 @@ __weak void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c)  }
  /** @brief  Slave Tx Transfer completed callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
   __weak void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c)
 @@ -2512,8 +2513,8 @@ __weak void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Slave Rx Transfer completed callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
  __weak void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c)
 @@ -2525,8 +2526,8 @@ __weak void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Memory Tx Transfer completed callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
   __weak void HAL_I2C_MemTxCpltCallback(I2C_HandleTypeDef *hi2c)
 @@ -2538,8 +2539,8 @@ __weak void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Memory Rx Transfer completed callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
  __weak void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c)
 @@ -2551,8 +2552,8 @@ __weak void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c)  /**
    * @brief  I2C error callbacks.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval None
    */
   __weak void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c)
 @@ -2574,7 +2575,7 @@ __weak void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c)              ##### Peripheral State and Errors functions #####
   ===============================================================================
      [..]
 -    This subsection permit to get in run-time the status of the peripheral
 +    This subsection permits to get in run-time the status of the peripheral
      and the data flow.
  @endverbatim
 @@ -2583,7 +2584,8 @@ __weak void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Returns the I2C state.
 -  * @param  hi2c : I2C handle
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL state
    */
  HAL_I2C_StateTypeDef HAL_I2C_GetState(I2C_HandleTypeDef *hi2c)
 @@ -2608,15 +2610,12 @@ uint32_t HAL_I2C_GetError(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Handle TXE flag for Master
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_MasterTransmit_TXE(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    /* Write data to DR */
    hi2c->Instance->DR = (*hi2c->pBuffPtr++);
    hi2c->XferCount--;
 @@ -2627,31 +2626,22 @@ static HAL_StatusTypeDef I2C_MasterTransmit_TXE(I2C_HandleTypeDef *hi2c)      __HAL_I2C_DISABLE_IT(hi2c, I2C_IT_BUF);
    }
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
 -
    return HAL_OK;
  }
  /**
    * @brief  Handle BTF flag for Master transmitter
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_MasterTransmit_BTF(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    if(hi2c->XferCount != 0)
    {
      /* Write data to DR */
      hi2c->Instance->DR = (*hi2c->pBuffPtr++);
      hi2c->XferCount--;
 -
 -    /* Process Unlocked */
 -    __HAL_UNLOCK(hi2c);
    }
    else
    {
 @@ -2671,18 +2661,12 @@ static HAL_StatusTypeDef I2C_MasterTransmit_BTF(I2C_HandleTypeDef *hi2c)      {
        hi2c->State = HAL_I2C_STATE_READY;
 -      /* Process Unlocked */
 -      __HAL_UNLOCK(hi2c);
 -
        HAL_I2C_MemTxCpltCallback(hi2c);
      }
      else
      {
        hi2c->State = HAL_I2C_STATE_READY;
 -      /* Process Unlocked */
 -      __HAL_UNLOCK(hi2c);
 -
        HAL_I2C_MasterTxCpltCallback(hi2c);
      }
    }
 @@ -2691,34 +2675,25 @@ static HAL_StatusTypeDef I2C_MasterTransmit_BTF(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Handle RXNE flag for Master
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_MasterReceive_RXNE(I2C_HandleTypeDef *hi2c)
  {
    uint32_t tmp = 0;
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    tmp = hi2c->XferCount;
    if(tmp > 3)
    {
      /* Read data from DR */
      (*hi2c->pBuffPtr++) = hi2c->Instance->DR;
      hi2c->XferCount--;
 -
 -    /* Process Unlocked */
 -    __HAL_UNLOCK(hi2c);
    }
    else if((tmp == 2) || (tmp == 3))
    {
      /* Disable BUF interrupt */
      __HAL_I2C_DISABLE_IT(hi2c, I2C_IT_BUF);
 -
 -    /* Process Unlocked */
 -    __HAL_UNLOCK(hi2c);
    }
    else
    {
 @@ -2739,18 +2714,12 @@ static HAL_StatusTypeDef I2C_MasterReceive_RXNE(I2C_HandleTypeDef *hi2c)      {
        hi2c->State = HAL_I2C_STATE_READY;
 -      /* Process Unlocked */
 -      __HAL_UNLOCK(hi2c);
 -
        HAL_I2C_MemRxCpltCallback(hi2c);
      }
      else
      {
        hi2c->State = HAL_I2C_STATE_READY;
 -      /* Process Unlocked */
 -      __HAL_UNLOCK(hi2c);
 -
        HAL_I2C_MasterRxCpltCallback(hi2c);
      }
    }
 @@ -2759,15 +2728,12 @@ static HAL_StatusTypeDef I2C_MasterReceive_RXNE(I2C_HandleTypeDef *hi2c)  /**
    * @brief  Handle BTF flag for Master receiver
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_MasterReceive_BTF(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    if(hi2c->XferCount == 3)
    {
      /* Disable Acknowledge */
 @@ -2776,9 +2742,6 @@ static HAL_StatusTypeDef I2C_MasterReceive_BTF(I2C_HandleTypeDef *hi2c)      /* Read data from DR */
      (*hi2c->pBuffPtr++) = hi2c->Instance->DR;
      hi2c->XferCount--;
 -
 -    /* Process Unlocked */
 -    __HAL_UNLOCK(hi2c);
    }
    else if(hi2c->XferCount == 2)
    {
 @@ -2806,18 +2769,12 @@ static HAL_StatusTypeDef I2C_MasterReceive_BTF(I2C_HandleTypeDef *hi2c)      {
        hi2c->State = HAL_I2C_STATE_READY;
 -      /* Process Unlocked */
 -      __HAL_UNLOCK(hi2c);
 -
        HAL_I2C_MemRxCpltCallback(hi2c);
      }
      else
      {
        hi2c->State = HAL_I2C_STATE_READY;
 -      /* Process Unlocked */
 -      __HAL_UNLOCK(hi2c);
 -
        HAL_I2C_MasterRxCpltCallback(hi2c);
      }
    }
 @@ -2826,135 +2783,100 @@ static HAL_StatusTypeDef I2C_MasterReceive_BTF(I2C_HandleTypeDef *hi2c)      /* Read data from DR */
      (*hi2c->pBuffPtr++) = hi2c->Instance->DR;
      hi2c->XferCount--;
 -
 -    /* Process Unlocked */
 -    __HAL_UNLOCK(hi2c);
    }
    return HAL_OK;
  }
  /**
    * @brief  Handle TXE flag for Slave
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_SlaveTransmit_TXE(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
 -    if(hi2c->XferCount != 0)
 +  if(hi2c->XferCount != 0)
    {
      /* Write data to DR */
      hi2c->Instance->DR = (*hi2c->pBuffPtr++);
      hi2c->XferCount--;
    }
 -
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
    return HAL_OK;
  }
  /**
    * @brief  Handle BTF flag for Slave transmitter
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_SlaveTransmit_BTF(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
 -    if(hi2c->XferCount != 0)
 +  if(hi2c->XferCount != 0)
    {
      /* Write data to DR */
      hi2c->Instance->DR = (*hi2c->pBuffPtr++);
      hi2c->XferCount--;
    }
 -
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
    return HAL_OK;
  }
  /**
    * @brief  Handle RXNE flag for Slave
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_SlaveReceive_RXNE(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
 -    if(hi2c->XferCount != 0)
 +  if(hi2c->XferCount != 0)
    {
      /* Read data from DR */
      (*hi2c->pBuffPtr++) = hi2c->Instance->DR;
      hi2c->XferCount--;
    }
 -
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
    return HAL_OK;
  }
  /**
    * @brief  Handle BTF flag for Slave receiver
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_SlaveReceive_BTF(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
 -    if(hi2c->XferCount != 0)
 +  if(hi2c->XferCount != 0)
    {
      /* Read data from DR */
      (*hi2c->pBuffPtr++) = hi2c->Instance->DR;
      hi2c->XferCount--;
    }
 -
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
    return HAL_OK;
  }
  /**
    * @brief  Handle ADD flag for Slave
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_Slave_ADDR(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    /* Clear ADDR flag */
    __HAL_I2C_CLEAR_ADDRFLAG(hi2c);
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
    return HAL_OK;
  }
  /**
    * @brief  Handle STOPF flag for Slave
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_Slave_STOPF(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    /* Disable EVT, BUF and ERR interrupt */
    __HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
 @@ -2972,24 +2894,18 @@ static HAL_StatusTypeDef I2C_Slave_STOPF(I2C_HandleTypeDef *hi2c)    hi2c->State = HAL_I2C_STATE_READY;
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
 -
    HAL_I2C_SlaveRxCpltCallback(hi2c);
    return HAL_OK;
  }
  /**
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_Slave_AF(I2C_HandleTypeDef *hi2c)
  {
 -  /* Process Locked */
 -  __HAL_LOCK(hi2c);
 -
    /* Disable EVT, BUF and ERR interrupt */
    __HAL_I2C_DISABLE_IT(hi2c, I2C_IT_EVT | I2C_IT_BUF | I2C_IT_ERR);
 @@ -3007,17 +2923,14 @@ static HAL_StatusTypeDef I2C_Slave_AF(I2C_HandleTypeDef *hi2c)    hi2c->State = HAL_I2C_STATE_READY;
 -  /* Process Unlocked */
 -  __HAL_UNLOCK(hi2c);
 -
    HAL_I2C_SlaveTxCpltCallback(hi2c);
    return HAL_OK;
  }
  /**
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @retval HAL status
    */
 @@ -3077,8 +2990,8 @@ static HAL_StatusTypeDef I2C_MasterRequestWrite(I2C_HandleTypeDef *hi2c, uint16_  /**
    * @brief  Master sends target device address for read request.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @retval HAL status
    */
 @@ -3169,8 +3082,8 @@ static HAL_StatusTypeDef I2C_MasterRequestRead(I2C_HandleTypeDef *hi2c, uint16_t  /**
    * @brief  Master sends target device address followed by internal memory address for write request.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -3239,8 +3152,8 @@ static HAL_StatusTypeDef I2C_RequestMemoryWrite(I2C_HandleTypeDef *hi2c, uint16_  /**
    * @brief  Master sends target device address followed by internal memory address for read request.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  DevAddress: Target device address
    * @param  MemAddress: Internal memory address
    * @param  MemAddSize: Size of internal memory address
 @@ -3622,8 +3535,8 @@ static void I2C_DMAError(DMA_HandleTypeDef *hdma)  /**
    * @brief  This function handles I2C Communication Timeout.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  Flag: specifies the I2C flag to check.
    * @param  Status: The new Flag status (SET or RESET).
    * @param  Timeout: Timeout duration
 @@ -3631,9 +3544,10 @@ static void I2C_DMAError(DMA_HandleTypeDef *hdma)    */
  static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Flag, FlagStatus Status, uint32_t Timeout)
  {
 -  uint32_t timeout = 0;
 +  uint32_t tickstart = 0;
 -  timeout = HAL_GetTick() + Timeout;
 +  /* Get tick */
 +  tickstart = HAL_GetTick();
    /* Wait until flag is set */
    if(Status == RESET)
 @@ -3643,7 +3557,7 @@ static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uin        /* Check for the Timeout */
        if(Timeout != HAL_MAX_DELAY)
        {
 -        if(HAL_GetTick() >= timeout)
 +        if((Timeout == 0)||((HAL_GetTick() - tickstart ) > Timeout))
          {
            hi2c->State= HAL_I2C_STATE_READY;
 @@ -3662,7 +3576,7 @@ static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uin        /* Check for the Timeout */
        if(Timeout != HAL_MAX_DELAY)
        {
 -        if(HAL_GetTick() >= timeout)
 +        if((Timeout == 0)||((HAL_GetTick() - tickstart ) > Timeout))
          {
            hi2c->State= HAL_I2C_STATE_READY;
 @@ -3679,17 +3593,18 @@ static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uin  /**
    * @brief  This function handles I2C Communication Timeout for Master addressing phase.
 -  * @param  hi2c : Pointer to a I2C_HandleTypeDef structure that contains
 -  *                the configuration information for the specified I2C.
 +  * @param  hi2c: pointer to a I2C_HandleTypeDef structure that contains
 +  *         the configuration information for I2C module
    * @param  Flag: specifies the I2C flag to check.
    * @param  Timeout: Timeout duration
    * @retval HAL status
    */
  static HAL_StatusTypeDef I2C_WaitOnMasterAddressFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Flag, uint32_t Timeout)
  {
 -  uint32_t timeout = 0;
 +  uint32_t tickstart = 0;
 -  timeout = HAL_GetTick() + Timeout;
 +  /* Get tick */
 +  tickstart = HAL_GetTick();
    while(__HAL_I2C_GET_FLAG(hi2c, Flag) == RESET)
    {
 @@ -3713,7 +3628,7 @@ static HAL_StatusTypeDef I2C_WaitOnMasterAddressFlagUntilTimeout(I2C_HandleTypeD      /* Check for the Timeout */
      if(Timeout != HAL_MAX_DELAY)
      {
 -      if(HAL_GetTick() >= timeout)
 +      if((Timeout == 0)||((HAL_GetTick() - tickstart ) > Timeout))
        {
          hi2c->State= HAL_I2C_STATE_READY;
 | 
