mbed library sources

Fork of mbed-src by mbed official

Committer:
moirans2
Date:
Wed Jan 14 20:53:08 2015 +0000
Revision:
445:9a3ffe6cfa19
Parent:
441:d2c15dda23c1
internal clock stm32L051

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_official 340:28d1f895c6fe 1 /**
mbed_official 340:28d1f895c6fe 2 ******************************************************************************
mbed_official 340:28d1f895c6fe 3 * @file stm32f0xx_hal_i2c.h
mbed_official 340:28d1f895c6fe 4 * @author MCD Application Team
mbed_official 441:d2c15dda23c1 5 * @version V1.2.0
mbed_official 441:d2c15dda23c1 6 * @date 11-December-2014
mbed_official 340:28d1f895c6fe 7 * @brief Header file of I2C HAL module.
mbed_official 340:28d1f895c6fe 8 ******************************************************************************
mbed_official 340:28d1f895c6fe 9 * @attention
mbed_official 340:28d1f895c6fe 10 *
mbed_official 340:28d1f895c6fe 11 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
mbed_official 340:28d1f895c6fe 12 *
mbed_official 340:28d1f895c6fe 13 * Redistribution and use in source and binary forms, with or without modification,
mbed_official 340:28d1f895c6fe 14 * are permitted provided that the following conditions are met:
mbed_official 340:28d1f895c6fe 15 * 1. Redistributions of source code must retain the above copyright notice,
mbed_official 340:28d1f895c6fe 16 * this list of conditions and the following disclaimer.
mbed_official 340:28d1f895c6fe 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
mbed_official 340:28d1f895c6fe 18 * this list of conditions and the following disclaimer in the documentation
mbed_official 340:28d1f895c6fe 19 * and/or other materials provided with the distribution.
mbed_official 340:28d1f895c6fe 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
mbed_official 340:28d1f895c6fe 21 * may be used to endorse or promote products derived from this software
mbed_official 340:28d1f895c6fe 22 * without specific prior written permission.
mbed_official 340:28d1f895c6fe 23 *
mbed_official 340:28d1f895c6fe 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
mbed_official 340:28d1f895c6fe 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
mbed_official 340:28d1f895c6fe 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
mbed_official 340:28d1f895c6fe 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
mbed_official 340:28d1f895c6fe 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
mbed_official 340:28d1f895c6fe 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
mbed_official 340:28d1f895c6fe 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
mbed_official 340:28d1f895c6fe 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
mbed_official 340:28d1f895c6fe 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
mbed_official 340:28d1f895c6fe 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
mbed_official 340:28d1f895c6fe 34 *
mbed_official 340:28d1f895c6fe 35 ******************************************************************************
mbed_official 340:28d1f895c6fe 36 */
mbed_official 340:28d1f895c6fe 37
mbed_official 340:28d1f895c6fe 38 /* Define to prevent recursive inclusion -------------------------------------*/
mbed_official 340:28d1f895c6fe 39 #ifndef __STM32F0xx_HAL_I2C_H
mbed_official 340:28d1f895c6fe 40 #define __STM32F0xx_HAL_I2C_H
mbed_official 340:28d1f895c6fe 41
mbed_official 340:28d1f895c6fe 42 #ifdef __cplusplus
mbed_official 340:28d1f895c6fe 43 extern "C" {
mbed_official 340:28d1f895c6fe 44 #endif
mbed_official 340:28d1f895c6fe 45
mbed_official 340:28d1f895c6fe 46 /* Includes ------------------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 47 #include "stm32f0xx_hal_def.h"
mbed_official 340:28d1f895c6fe 48
mbed_official 340:28d1f895c6fe 49 /** @addtogroup STM32F0xx_HAL_Driver
mbed_official 340:28d1f895c6fe 50 * @{
mbed_official 340:28d1f895c6fe 51 */
mbed_official 340:28d1f895c6fe 52
mbed_official 340:28d1f895c6fe 53 /** @addtogroup I2C
mbed_official 340:28d1f895c6fe 54 * @{
mbed_official 340:28d1f895c6fe 55 */
mbed_official 340:28d1f895c6fe 56
mbed_official 340:28d1f895c6fe 57 /* Exported types ------------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 58 /** @defgroup I2C_Exported_Types I2C Exported Types
mbed_official 340:28d1f895c6fe 59 * @{
mbed_official 340:28d1f895c6fe 60 */
mbed_official 340:28d1f895c6fe 61
mbed_official 340:28d1f895c6fe 62 /** @defgroup I2C_Configuration_Structure_definition I2C Configuration Structure definition
mbed_official 340:28d1f895c6fe 63 * @brief I2C Configuration Structure definition
mbed_official 340:28d1f895c6fe 64 * @{
mbed_official 340:28d1f895c6fe 65 */
mbed_official 340:28d1f895c6fe 66 typedef struct
mbed_official 340:28d1f895c6fe 67 {
mbed_official 340:28d1f895c6fe 68 uint32_t Timing; /*!< Specifies the I2C_TIMINGR_register value.
mbed_official 340:28d1f895c6fe 69 This parameter calculated by referring to I2C initialization
mbed_official 340:28d1f895c6fe 70 section in Reference manual */
mbed_official 340:28d1f895c6fe 71
mbed_official 340:28d1f895c6fe 72 uint32_t OwnAddress1; /*!< Specifies the first device own address.
mbed_official 340:28d1f895c6fe 73 This parameter can be a 7-bit or 10-bit address. */
mbed_official 340:28d1f895c6fe 74
mbed_official 340:28d1f895c6fe 75 uint32_t AddressingMode; /*!< Specifies if 7-bit or 10-bit addressing mode is selected.
mbed_official 340:28d1f895c6fe 76 This parameter can be a value of @ref I2C_addressing_mode */
mbed_official 340:28d1f895c6fe 77
mbed_official 340:28d1f895c6fe 78 uint32_t DualAddressMode; /*!< Specifies if dual addressing mode is selected.
mbed_official 340:28d1f895c6fe 79 This parameter can be a value of @ref I2C_dual_addressing_mode */
mbed_official 340:28d1f895c6fe 80
mbed_official 340:28d1f895c6fe 81 uint32_t OwnAddress2; /*!< Specifies the second device own address if dual addressing mode is selected
mbed_official 340:28d1f895c6fe 82 This parameter can be a 7-bit address. */
mbed_official 340:28d1f895c6fe 83
mbed_official 340:28d1f895c6fe 84 uint32_t OwnAddress2Masks; /*!< Specifies the acknoledge mask address second device own address if dual addressing mode is selected
mbed_official 340:28d1f895c6fe 85 This parameter can be a value of @ref I2C_own_address2_masks. */
mbed_official 340:28d1f895c6fe 86
mbed_official 340:28d1f895c6fe 87 uint32_t GeneralCallMode; /*!< Specifies if general call mode is selected.
mbed_official 340:28d1f895c6fe 88 This parameter can be a value of @ref I2C_general_call_addressing_mode. */
mbed_official 340:28d1f895c6fe 89
mbed_official 340:28d1f895c6fe 90 uint32_t NoStretchMode; /*!< Specifies if nostretch mode is selected.
mbed_official 340:28d1f895c6fe 91 This parameter can be a value of @ref I2C_nostretch_mode */
mbed_official 340:28d1f895c6fe 92
mbed_official 340:28d1f895c6fe 93 }I2C_InitTypeDef;
mbed_official 340:28d1f895c6fe 94
mbed_official 340:28d1f895c6fe 95 /**
mbed_official 340:28d1f895c6fe 96 * @}
mbed_official 340:28d1f895c6fe 97 */
mbed_official 340:28d1f895c6fe 98
mbed_official 340:28d1f895c6fe 99 /** @defgroup HAL_state_structure_definition HAL state structure definition
mbed_official 340:28d1f895c6fe 100 * @brief HAL State structure definition
mbed_official 340:28d1f895c6fe 101 * @{
mbed_official 340:28d1f895c6fe 102 */
mbed_official 340:28d1f895c6fe 103
mbed_official 340:28d1f895c6fe 104 typedef enum
mbed_official 340:28d1f895c6fe 105 {
mbed_official 340:28d1f895c6fe 106 HAL_I2C_STATE_RESET = 0x00, /*!< I2C not yet initialized or disabled */
mbed_official 340:28d1f895c6fe 107 HAL_I2C_STATE_READY = 0x01, /*!< I2C initialized and ready for use */
mbed_official 340:28d1f895c6fe 108 HAL_I2C_STATE_BUSY = 0x02, /*!< I2C internal process is ongoing */
mbed_official 340:28d1f895c6fe 109 HAL_I2C_STATE_MASTER_BUSY_TX = 0x12, /*!< Master Data Transmission process is ongoing */
mbed_official 340:28d1f895c6fe 110 HAL_I2C_STATE_MASTER_BUSY_RX = 0x22, /*!< Master Data Reception process is ongoing */
mbed_official 340:28d1f895c6fe 111 HAL_I2C_STATE_SLAVE_BUSY_TX = 0x32, /*!< Slave Data Transmission process is ongoing */
mbed_official 340:28d1f895c6fe 112 HAL_I2C_STATE_SLAVE_BUSY_RX = 0x42, /*!< Slave Data Reception process is ongoing */
mbed_official 340:28d1f895c6fe 113 HAL_I2C_STATE_MEM_BUSY_TX = 0x52, /*!< Memory Data Transmission process is ongoing */
mbed_official 340:28d1f895c6fe 114 HAL_I2C_STATE_MEM_BUSY_RX = 0x62, /*!< Memory Data Reception process is ongoing */
mbed_official 340:28d1f895c6fe 115 HAL_I2C_STATE_TIMEOUT = 0x03, /*!< Timeout state */
mbed_official 340:28d1f895c6fe 116 HAL_I2C_STATE_ERROR = 0x04 /*!< Reception process is ongoing */
mbed_official 340:28d1f895c6fe 117
mbed_official 340:28d1f895c6fe 118 }HAL_I2C_StateTypeDef;
mbed_official 340:28d1f895c6fe 119
mbed_official 340:28d1f895c6fe 120 /**
mbed_official 340:28d1f895c6fe 121 * @}
mbed_official 340:28d1f895c6fe 122 */
mbed_official 340:28d1f895c6fe 123
mbed_official 340:28d1f895c6fe 124 /** @defgroup I2C_handle_Structure_definition I2C handle Structure definition
mbed_official 340:28d1f895c6fe 125 * @brief I2C handle Structure definition
mbed_official 340:28d1f895c6fe 126 * @{
mbed_official 340:28d1f895c6fe 127 */
mbed_official 340:28d1f895c6fe 128
mbed_official 340:28d1f895c6fe 129 typedef struct
mbed_official 340:28d1f895c6fe 130 {
mbed_official 340:28d1f895c6fe 131 I2C_TypeDef *Instance; /*!< I2C registers base address */
mbed_official 340:28d1f895c6fe 132
mbed_official 340:28d1f895c6fe 133 I2C_InitTypeDef Init; /*!< I2C communication parameters */
mbed_official 340:28d1f895c6fe 134
mbed_official 340:28d1f895c6fe 135 uint8_t *pBuffPtr; /*!< Pointer to I2C transfer buffer */
mbed_official 340:28d1f895c6fe 136
mbed_official 340:28d1f895c6fe 137 uint16_t XferSize; /*!< I2C transfer size */
mbed_official 340:28d1f895c6fe 138
mbed_official 340:28d1f895c6fe 139 __IO uint16_t XferCount; /*!< I2C transfer counter */
mbed_official 340:28d1f895c6fe 140
mbed_official 340:28d1f895c6fe 141 DMA_HandleTypeDef *hdmatx; /*!< I2C Tx DMA handle parameters */
mbed_official 340:28d1f895c6fe 142
mbed_official 340:28d1f895c6fe 143 DMA_HandleTypeDef *hdmarx; /*!< I2C Rx DMA handle parameters */
mbed_official 340:28d1f895c6fe 144
mbed_official 340:28d1f895c6fe 145 HAL_LockTypeDef Lock; /*!< I2C locking object */
mbed_official 340:28d1f895c6fe 146
mbed_official 340:28d1f895c6fe 147 __IO HAL_I2C_StateTypeDef State; /*!< I2C communication state */
mbed_official 340:28d1f895c6fe 148
mbed_official 441:d2c15dda23c1 149 __IO uint32_t ErrorCode; /*!< I2C Error code
mbed_official 441:d2c15dda23c1 150 This parameter can be a value of @ref I2C_Error */
mbed_official 340:28d1f895c6fe 151
mbed_official 340:28d1f895c6fe 152 }I2C_HandleTypeDef;
mbed_official 340:28d1f895c6fe 153 /**
mbed_official 340:28d1f895c6fe 154 * @}
mbed_official 340:28d1f895c6fe 155 */
mbed_official 340:28d1f895c6fe 156
mbed_official 340:28d1f895c6fe 157 /**
mbed_official 340:28d1f895c6fe 158 * @}
mbed_official 340:28d1f895c6fe 159 */
mbed_official 340:28d1f895c6fe 160 /* Exported constants --------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 161
mbed_official 340:28d1f895c6fe 162 /** @defgroup I2C_Exported_Constants I2C Exported Constants
mbed_official 340:28d1f895c6fe 163 * @{
mbed_official 340:28d1f895c6fe 164 */
mbed_official 340:28d1f895c6fe 165
mbed_official 441:d2c15dda23c1 166 /** @defgroup I2C_Error I2C Error
mbed_official 441:d2c15dda23c1 167 * @brief I2C Error
mbed_official 441:d2c15dda23c1 168 * @{
mbed_official 441:d2c15dda23c1 169 */
mbed_official 441:d2c15dda23c1 170
mbed_official 441:d2c15dda23c1 171 #define HAL_I2C_ERROR_NONE ((uint32_t)0x00000000) /*!< No error */
mbed_official 441:d2c15dda23c1 172 #define HAL_I2C_ERROR_BERR ((uint32_t)0x00000001) /*!< BERR error */
mbed_official 441:d2c15dda23c1 173 #define HAL_I2C_ERROR_ARLO ((uint32_t)0x00000002) /*!< ARLO error */
mbed_official 441:d2c15dda23c1 174 #define HAL_I2C_ERROR_AF ((uint32_t)0x00000004) /*!< AF error */
mbed_official 441:d2c15dda23c1 175 #define HAL_I2C_ERROR_OVR ((uint32_t)0x00000008) /*!< OVR error */
mbed_official 441:d2c15dda23c1 176 #define HAL_I2C_ERROR_DMA ((uint32_t)0x00000010) /*!< DMA transfer error */
mbed_official 441:d2c15dda23c1 177 #define HAL_I2C_ERROR_TIMEOUT ((uint32_t)0x00000020) /*!< Timeout error */
mbed_official 441:d2c15dda23c1 178 #define HAL_I2C_ERROR_SIZE ((uint32_t)0x00000040) /*!< Size Management error */
mbed_official 441:d2c15dda23c1 179
mbed_official 441:d2c15dda23c1 180 /**
mbed_official 441:d2c15dda23c1 181 * @}
mbed_official 441:d2c15dda23c1 182 */
mbed_official 441:d2c15dda23c1 183
mbed_official 441:d2c15dda23c1 184
mbed_official 340:28d1f895c6fe 185 /** @defgroup I2C_addressing_mode I2C addressing mode
mbed_official 340:28d1f895c6fe 186 * @{
mbed_official 340:28d1f895c6fe 187 */
mbed_official 340:28d1f895c6fe 188 #define I2C_ADDRESSINGMODE_7BIT ((uint32_t)0x00000001)
mbed_official 340:28d1f895c6fe 189 #define I2C_ADDRESSINGMODE_10BIT ((uint32_t)0x00000002)
mbed_official 340:28d1f895c6fe 190
mbed_official 340:28d1f895c6fe 191 #define IS_I2C_ADDRESSING_MODE(MODE) (((MODE) == I2C_ADDRESSINGMODE_7BIT) || \
mbed_official 340:28d1f895c6fe 192 ((MODE) == I2C_ADDRESSINGMODE_10BIT))
mbed_official 340:28d1f895c6fe 193 /**
mbed_official 340:28d1f895c6fe 194 * @}
mbed_official 340:28d1f895c6fe 195 */
mbed_official 340:28d1f895c6fe 196
mbed_official 340:28d1f895c6fe 197 /** @defgroup I2C_dual_addressing_mode I2C dual addressing mode
mbed_official 340:28d1f895c6fe 198 * @{
mbed_official 340:28d1f895c6fe 199 */
mbed_official 340:28d1f895c6fe 200
mbed_official 340:28d1f895c6fe 201 #define I2C_DUALADDRESS_DISABLED ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 202 #define I2C_DUALADDRESS_ENABLED I2C_OAR2_OA2EN
mbed_official 340:28d1f895c6fe 203
mbed_official 340:28d1f895c6fe 204 #define IS_I2C_DUAL_ADDRESS(ADDRESS) (((ADDRESS) == I2C_DUALADDRESS_DISABLED) || \
mbed_official 340:28d1f895c6fe 205 ((ADDRESS) == I2C_DUALADDRESS_ENABLED))
mbed_official 340:28d1f895c6fe 206 /**
mbed_official 340:28d1f895c6fe 207 * @}
mbed_official 340:28d1f895c6fe 208 */
mbed_official 340:28d1f895c6fe 209
mbed_official 340:28d1f895c6fe 210 /** @defgroup I2C_own_address2_masks I2C own address2 masks
mbed_official 340:28d1f895c6fe 211 * @{
mbed_official 340:28d1f895c6fe 212 */
mbed_official 340:28d1f895c6fe 213
mbed_official 340:28d1f895c6fe 214 #define I2C_OA2_NOMASK ((uint8_t)0x00)
mbed_official 340:28d1f895c6fe 215 #define I2C_OA2_MASK01 ((uint8_t)0x01)
mbed_official 340:28d1f895c6fe 216 #define I2C_OA2_MASK02 ((uint8_t)0x02)
mbed_official 340:28d1f895c6fe 217 #define I2C_OA2_MASK03 ((uint8_t)0x03)
mbed_official 340:28d1f895c6fe 218 #define I2C_OA2_MASK04 ((uint8_t)0x04)
mbed_official 340:28d1f895c6fe 219 #define I2C_OA2_MASK05 ((uint8_t)0x05)
mbed_official 340:28d1f895c6fe 220 #define I2C_OA2_MASK06 ((uint8_t)0x06)
mbed_official 340:28d1f895c6fe 221 #define I2C_OA2_MASK07 ((uint8_t)0x07)
mbed_official 340:28d1f895c6fe 222
mbed_official 340:28d1f895c6fe 223 #define IS_I2C_OWN_ADDRESS2_MASK(MASK) (((MASK) == I2C_OA2_NOMASK) || \
mbed_official 340:28d1f895c6fe 224 ((MASK) == I2C_OA2_MASK01) || \
mbed_official 340:28d1f895c6fe 225 ((MASK) == I2C_OA2_MASK02) || \
mbed_official 340:28d1f895c6fe 226 ((MASK) == I2C_OA2_MASK03) || \
mbed_official 340:28d1f895c6fe 227 ((MASK) == I2C_OA2_MASK04) || \
mbed_official 340:28d1f895c6fe 228 ((MASK) == I2C_OA2_MASK05) || \
mbed_official 340:28d1f895c6fe 229 ((MASK) == I2C_OA2_MASK06) || \
mbed_official 340:28d1f895c6fe 230 ((MASK) == I2C_OA2_MASK07))
mbed_official 340:28d1f895c6fe 231 /**
mbed_official 340:28d1f895c6fe 232 * @}
mbed_official 340:28d1f895c6fe 233 */
mbed_official 340:28d1f895c6fe 234
mbed_official 340:28d1f895c6fe 235 /** @defgroup I2C_general_call_addressing_mode I2C general call addressing mode
mbed_official 340:28d1f895c6fe 236 * @{
mbed_official 340:28d1f895c6fe 237 */
mbed_official 340:28d1f895c6fe 238 #define I2C_GENERALCALL_DISABLED ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 239 #define I2C_GENERALCALL_ENABLED I2C_CR1_GCEN
mbed_official 340:28d1f895c6fe 240
mbed_official 340:28d1f895c6fe 241 #define IS_I2C_GENERAL_CALL(CALL) (((CALL) == I2C_GENERALCALL_DISABLED) || \
mbed_official 340:28d1f895c6fe 242 ((CALL) == I2C_GENERALCALL_ENABLED))
mbed_official 340:28d1f895c6fe 243 /**
mbed_official 340:28d1f895c6fe 244 * @}
mbed_official 340:28d1f895c6fe 245 */
mbed_official 340:28d1f895c6fe 246
mbed_official 340:28d1f895c6fe 247 /** @defgroup I2C_nostretch_mode I2C nostretch mode
mbed_official 340:28d1f895c6fe 248 * @{
mbed_official 340:28d1f895c6fe 249 */
mbed_official 340:28d1f895c6fe 250 #define I2C_NOSTRETCH_DISABLED ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 251 #define I2C_NOSTRETCH_ENABLED I2C_CR1_NOSTRETCH
mbed_official 340:28d1f895c6fe 252
mbed_official 340:28d1f895c6fe 253 #define IS_I2C_NO_STRETCH(STRETCH) (((STRETCH) == I2C_NOSTRETCH_DISABLED) || \
mbed_official 340:28d1f895c6fe 254 ((STRETCH) == I2C_NOSTRETCH_ENABLED))
mbed_official 340:28d1f895c6fe 255 /**
mbed_official 340:28d1f895c6fe 256 * @}
mbed_official 340:28d1f895c6fe 257 */
mbed_official 340:28d1f895c6fe 258
mbed_official 340:28d1f895c6fe 259 /** @defgroup I2C_Memory_Address_Size I2C Memory Address Size
mbed_official 340:28d1f895c6fe 260 * @{
mbed_official 340:28d1f895c6fe 261 */
mbed_official 340:28d1f895c6fe 262 #define I2C_MEMADD_SIZE_8BIT ((uint32_t)0x00000001)
mbed_official 340:28d1f895c6fe 263 #define I2C_MEMADD_SIZE_16BIT ((uint32_t)0x00000002)
mbed_official 340:28d1f895c6fe 264
mbed_official 340:28d1f895c6fe 265 #define IS_I2C_MEMADD_SIZE(SIZE) (((SIZE) == I2C_MEMADD_SIZE_8BIT) || \
mbed_official 340:28d1f895c6fe 266 ((SIZE) == I2C_MEMADD_SIZE_16BIT))
mbed_official 340:28d1f895c6fe 267 /**
mbed_official 340:28d1f895c6fe 268 * @}
mbed_official 340:28d1f895c6fe 269 */
mbed_official 340:28d1f895c6fe 270
mbed_official 340:28d1f895c6fe 271 /** @defgroup I2C_ReloadEndMode_definition I2C ReloadEndMode definition
mbed_official 340:28d1f895c6fe 272 * @{
mbed_official 340:28d1f895c6fe 273 */
mbed_official 340:28d1f895c6fe 274
mbed_official 340:28d1f895c6fe 275 #define I2C_RELOAD_MODE I2C_CR2_RELOAD
mbed_official 340:28d1f895c6fe 276 #define I2C_AUTOEND_MODE I2C_CR2_AUTOEND
mbed_official 340:28d1f895c6fe 277 #define I2C_SOFTEND_MODE ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 278
mbed_official 340:28d1f895c6fe 279 #define IS_TRANSFER_MODE(MODE) (((MODE) == I2C_RELOAD_MODE) || \
mbed_official 340:28d1f895c6fe 280 ((MODE) == I2C_AUTOEND_MODE) || \
mbed_official 340:28d1f895c6fe 281 ((MODE) == I2C_SOFTEND_MODE))
mbed_official 340:28d1f895c6fe 282 /**
mbed_official 340:28d1f895c6fe 283 * @}
mbed_official 340:28d1f895c6fe 284 */
mbed_official 340:28d1f895c6fe 285
mbed_official 340:28d1f895c6fe 286 /** @defgroup I2C_StartStopMode_definition I2C StartStopMode definition
mbed_official 340:28d1f895c6fe 287 * @{
mbed_official 340:28d1f895c6fe 288 */
mbed_official 340:28d1f895c6fe 289
mbed_official 340:28d1f895c6fe 290 #define I2C_NO_STARTSTOP ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 291 #define I2C_GENERATE_STOP I2C_CR2_STOP
mbed_official 340:28d1f895c6fe 292 #define I2C_GENERATE_START_READ (uint32_t)(I2C_CR2_START | I2C_CR2_RD_WRN)
mbed_official 340:28d1f895c6fe 293 #define I2C_GENERATE_START_WRITE I2C_CR2_START
mbed_official 340:28d1f895c6fe 294
mbed_official 340:28d1f895c6fe 295 #define IS_TRANSFER_REQUEST(REQUEST) (((REQUEST) == I2C_GENERATE_STOP) || \
mbed_official 340:28d1f895c6fe 296 ((REQUEST) == I2C_GENERATE_START_READ) || \
mbed_official 340:28d1f895c6fe 297 ((REQUEST) == I2C_GENERATE_START_WRITE) || \
mbed_official 340:28d1f895c6fe 298 ((REQUEST) == I2C_NO_STARTSTOP))
mbed_official 340:28d1f895c6fe 299
mbed_official 340:28d1f895c6fe 300 /**
mbed_official 340:28d1f895c6fe 301 * @}
mbed_official 340:28d1f895c6fe 302 */
mbed_official 340:28d1f895c6fe 303
mbed_official 340:28d1f895c6fe 304 /** @defgroup I2C_Interrupt_configuration_definition I2C Interrupt configuration definition
mbed_official 340:28d1f895c6fe 305 * @brief I2C Interrupt definition
mbed_official 340:28d1f895c6fe 306 * Elements values convention: 0xXXXXXXXX
mbed_official 340:28d1f895c6fe 307 * - XXXXXXXX : Interrupt control mask
mbed_official 340:28d1f895c6fe 308 * @{
mbed_official 340:28d1f895c6fe 309 */
mbed_official 340:28d1f895c6fe 310 #define I2C_IT_ERRI I2C_CR1_ERRIE
mbed_official 340:28d1f895c6fe 311 #define I2C_IT_TCI I2C_CR1_TCIE
mbed_official 340:28d1f895c6fe 312 #define I2C_IT_STOPI I2C_CR1_STOPIE
mbed_official 340:28d1f895c6fe 313 #define I2C_IT_NACKI I2C_CR1_NACKIE
mbed_official 340:28d1f895c6fe 314 #define I2C_IT_ADDRI I2C_CR1_ADDRIE
mbed_official 340:28d1f895c6fe 315 #define I2C_IT_RXI I2C_CR1_RXIE
mbed_official 340:28d1f895c6fe 316 #define I2C_IT_TXI I2C_CR1_TXIE
mbed_official 340:28d1f895c6fe 317
mbed_official 340:28d1f895c6fe 318 /**
mbed_official 340:28d1f895c6fe 319 * @}
mbed_official 340:28d1f895c6fe 320 */
mbed_official 340:28d1f895c6fe 321
mbed_official 340:28d1f895c6fe 322
mbed_official 340:28d1f895c6fe 323 /** @defgroup I2C_Flag_definition I2C Flag definition
mbed_official 340:28d1f895c6fe 324 * @{
mbed_official 340:28d1f895c6fe 325 */
mbed_official 340:28d1f895c6fe 326
mbed_official 340:28d1f895c6fe 327 #define I2C_FLAG_TXE I2C_ISR_TXE
mbed_official 340:28d1f895c6fe 328 #define I2C_FLAG_TXIS I2C_ISR_TXIS
mbed_official 340:28d1f895c6fe 329 #define I2C_FLAG_RXNE I2C_ISR_RXNE
mbed_official 340:28d1f895c6fe 330 #define I2C_FLAG_ADDR I2C_ISR_ADDR
mbed_official 340:28d1f895c6fe 331 #define I2C_FLAG_AF I2C_ISR_NACKF
mbed_official 340:28d1f895c6fe 332 #define I2C_FLAG_STOPF I2C_ISR_STOPF
mbed_official 340:28d1f895c6fe 333 #define I2C_FLAG_TC I2C_ISR_TC
mbed_official 340:28d1f895c6fe 334 #define I2C_FLAG_TCR I2C_ISR_TCR
mbed_official 340:28d1f895c6fe 335 #define I2C_FLAG_BERR I2C_ISR_BERR
mbed_official 340:28d1f895c6fe 336 #define I2C_FLAG_ARLO I2C_ISR_ARLO
mbed_official 340:28d1f895c6fe 337 #define I2C_FLAG_OVR I2C_ISR_OVR
mbed_official 340:28d1f895c6fe 338 #define I2C_FLAG_PECERR I2C_ISR_PECERR
mbed_official 340:28d1f895c6fe 339 #define I2C_FLAG_TIMEOUT I2C_ISR_TIMEOUT
mbed_official 340:28d1f895c6fe 340 #define I2C_FLAG_ALERT I2C_ISR_ALERT
mbed_official 340:28d1f895c6fe 341 #define I2C_FLAG_BUSY I2C_ISR_BUSY
mbed_official 340:28d1f895c6fe 342 #define I2C_FLAG_DIR I2C_ISR_DIR
mbed_official 340:28d1f895c6fe 343 /**
mbed_official 340:28d1f895c6fe 344 * @}
mbed_official 340:28d1f895c6fe 345 */
mbed_official 340:28d1f895c6fe 346
mbed_official 340:28d1f895c6fe 347 /**
mbed_official 340:28d1f895c6fe 348 * @}
mbed_official 340:28d1f895c6fe 349 */
mbed_official 340:28d1f895c6fe 350
mbed_official 340:28d1f895c6fe 351 /* Exported macros -----------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 352
mbed_official 340:28d1f895c6fe 353 /** @defgroup I2C_Exported_Macros I2C Exported Macros
mbed_official 340:28d1f895c6fe 354 * @{
mbed_official 340:28d1f895c6fe 355 */
mbed_official 340:28d1f895c6fe 356
mbed_official 340:28d1f895c6fe 357 /** @brief Reset I2C handle state
mbed_official 340:28d1f895c6fe 358 * @param __HANDLE__: I2C handle.
mbed_official 340:28d1f895c6fe 359 * @retval None
mbed_official 340:28d1f895c6fe 360 */
mbed_official 340:28d1f895c6fe 361 #define __HAL_I2C_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_I2C_STATE_RESET)
mbed_official 340:28d1f895c6fe 362
mbed_official 340:28d1f895c6fe 363 /** @brief Enables or disables the specified I2C interrupts.
mbed_official 340:28d1f895c6fe 364 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 365 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 366 * @param __INTERRUPT__: specifies the interrupt source to enable or disable.
mbed_official 340:28d1f895c6fe 367 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 368 * @arg I2C_IT_ERRI: Errors interrupt enable
mbed_official 340:28d1f895c6fe 369 * @arg I2C_IT_TCI: Transfer complete interrupt enable
mbed_official 340:28d1f895c6fe 370 * @arg I2C_IT_STOPI: STOP detection interrupt enable
mbed_official 340:28d1f895c6fe 371 * @arg I2C_IT_NACKI: NACK received interrupt enable
mbed_official 340:28d1f895c6fe 372 * @arg I2C_IT_ADDRI: Address match interrupt enable
mbed_official 340:28d1f895c6fe 373 * @arg I2C_IT_RXI: RX interrupt enable
mbed_official 340:28d1f895c6fe 374 * @arg I2C_IT_TXI: TX interrupt enable
mbed_official 340:28d1f895c6fe 375 *
mbed_official 340:28d1f895c6fe 376 * @retval None
mbed_official 340:28d1f895c6fe 377 */
mbed_official 340:28d1f895c6fe 378
mbed_official 340:28d1f895c6fe 379 #define __HAL_I2C_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 |= (__INTERRUPT__))
mbed_official 340:28d1f895c6fe 380 #define __HAL_I2C_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 &= (~(__INTERRUPT__)))
mbed_official 340:28d1f895c6fe 381
mbed_official 340:28d1f895c6fe 382 /** @brief Checks if the specified I2C interrupt source is enabled or disabled.
mbed_official 340:28d1f895c6fe 383 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 384 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 385 * @param __INTERRUPT__: specifies the I2C interrupt source to check.
mbed_official 340:28d1f895c6fe 386 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 387 * @arg I2C_IT_ERRI: Errors interrupt enable
mbed_official 340:28d1f895c6fe 388 * @arg I2C_IT_TCI: Transfer complete interrupt enable
mbed_official 340:28d1f895c6fe 389 * @arg I2C_IT_STOPI: STOP detection interrupt enable
mbed_official 340:28d1f895c6fe 390 * @arg I2C_IT_NACKI: NACK received interrupt enable
mbed_official 340:28d1f895c6fe 391 * @arg I2C_IT_ADDRI: Address match interrupt enable
mbed_official 340:28d1f895c6fe 392 * @arg I2C_IT_RXI: RX interrupt enable
mbed_official 340:28d1f895c6fe 393 * @arg I2C_IT_TXI: TX interrupt enable
mbed_official 340:28d1f895c6fe 394 *
mbed_official 340:28d1f895c6fe 395 * @retval The new state of __IT__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 396 */
mbed_official 340:28d1f895c6fe 397 #define __HAL_I2C_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->CR1 & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
mbed_official 340:28d1f895c6fe 398
mbed_official 340:28d1f895c6fe 399 /** @brief Checks whether the specified I2C flag is set or not.
mbed_official 340:28d1f895c6fe 400 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 401 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 402 * @param __FLAG__: specifies the flag to check.
mbed_official 340:28d1f895c6fe 403 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 404 * @arg I2C_FLAG_TXE: Transmit data register empty
mbed_official 340:28d1f895c6fe 405 * @arg I2C_FLAG_TXIS: Transmit interrupt status
mbed_official 340:28d1f895c6fe 406 * @arg I2C_FLAG_RXNE: Receive data register not empty
mbed_official 340:28d1f895c6fe 407 * @arg I2C_FLAG_ADDR: Address matched (slave mode)
mbed_official 340:28d1f895c6fe 408 * @arg I2C_FLAG_AF: Acknowledge failure received flag
mbed_official 340:28d1f895c6fe 409 * @arg I2C_FLAG_STOPF: STOP detection flag
mbed_official 340:28d1f895c6fe 410 * @arg I2C_FLAG_TC: Transfer complete (master mode)
mbed_official 340:28d1f895c6fe 411 * @arg I2C_FLAG_TCR: Transfer complete reload
mbed_official 340:28d1f895c6fe 412 * @arg I2C_FLAG_BERR: Bus error
mbed_official 340:28d1f895c6fe 413 * @arg I2C_FLAG_ARLO: Arbitration lost
mbed_official 340:28d1f895c6fe 414 * @arg I2C_FLAG_OVR: Overrun/Underrun
mbed_official 340:28d1f895c6fe 415 * @arg I2C_FLAG_PECERR: PEC error in reception
mbed_official 340:28d1f895c6fe 416 * @arg I2C_FLAG_TIMEOUT: Timeout or Tlow detection flag
mbed_official 340:28d1f895c6fe 417 * @arg I2C_FLAG_ALERT: SMBus alert
mbed_official 340:28d1f895c6fe 418 * @arg I2C_FLAG_BUSY: Bus busy
mbed_official 340:28d1f895c6fe 419 * @arg I2C_FLAG_DIR: Transfer direction (slave mode)
mbed_official 340:28d1f895c6fe 420 *
mbed_official 340:28d1f895c6fe 421 * @retval The new state of __FLAG__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 422 */
mbed_official 340:28d1f895c6fe 423 #define __HAL_I2C_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->ISR) & (__FLAG__)) == (__FLAG__))
mbed_official 340:28d1f895c6fe 424
mbed_official 340:28d1f895c6fe 425 /** @brief Clears the I2C pending flags which are cleared by writing 1 in a specific bit.
mbed_official 340:28d1f895c6fe 426 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 427 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 428 * @param __FLAG__: specifies the flag to clear.
mbed_official 340:28d1f895c6fe 429 * This parameter can be any combination of the following values:
mbed_official 340:28d1f895c6fe 430 * @arg I2C_FLAG_ADDR: Address matched (slave mode)
mbed_official 340:28d1f895c6fe 431 * @arg I2C_FLAG_AF: Acknowledge failure flag
mbed_official 340:28d1f895c6fe 432 * @arg I2C_FLAG_STOPF: STOP detection flag
mbed_official 340:28d1f895c6fe 433 * @arg I2C_FLAG_BERR: Bus error
mbed_official 340:28d1f895c6fe 434 * @arg I2C_FLAG_ARLO: Arbitration lost
mbed_official 340:28d1f895c6fe 435 * @arg I2C_FLAG_OVR: Overrun/Underrun
mbed_official 340:28d1f895c6fe 436 * @arg I2C_FLAG_PECERR: PEC error in reception
mbed_official 340:28d1f895c6fe 437 * @arg I2C_FLAG_TIMEOUT: Timeout or Tlow detection flag
mbed_official 340:28d1f895c6fe 438 * @arg I2C_FLAG_ALERT: SMBus alert
mbed_official 340:28d1f895c6fe 439 *
mbed_official 340:28d1f895c6fe 440 * @retval None
mbed_official 340:28d1f895c6fe 441 */
mbed_official 340:28d1f895c6fe 442 #define __HAL_I2C_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__))
mbed_official 340:28d1f895c6fe 443
mbed_official 340:28d1f895c6fe 444
mbed_official 340:28d1f895c6fe 445 #define __HAL_I2C_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= I2C_CR1_PE)
mbed_official 340:28d1f895c6fe 446 #define __HAL_I2C_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~I2C_CR1_PE)
mbed_official 340:28d1f895c6fe 447
mbed_official 340:28d1f895c6fe 448 #define __HAL_I2C_RESET_CR2(__HANDLE__) ((__HANDLE__)->Instance->CR2 &= (uint32_t)~((uint32_t)(I2C_CR2_SADD | I2C_CR2_HEAD10R | I2C_CR2_NBYTES | I2C_CR2_RELOAD | I2C_CR2_RD_WRN)))
mbed_official 340:28d1f895c6fe 449
mbed_official 340:28d1f895c6fe 450 #define __HAL_I2C_MEM_ADD_MSB(__ADDRESS__) ((uint8_t)((uint16_t)(((uint16_t)((__ADDRESS__) & (uint16_t)(0xFF00))) >> 8)))
mbed_official 340:28d1f895c6fe 451 #define __HAL_I2C_MEM_ADD_LSB(__ADDRESS__) ((uint8_t)((uint16_t)((__ADDRESS__) & (uint16_t)(0x00FF))))
mbed_official 340:28d1f895c6fe 452
mbed_official 340:28d1f895c6fe 453 #define __HAL_I2C_GENERATE_START(__ADDMODE__,__ADDRESS__) (((__ADDMODE__) == I2C_ADDRESSINGMODE_7BIT) ? (uint32_t)((((uint32_t)(__ADDRESS__) & (I2C_CR2_SADD)) | (I2C_CR2_START) | (I2C_CR2_AUTOEND)) & (~I2C_CR2_RD_WRN)) : \
mbed_official 340:28d1f895c6fe 454 (uint32_t)((((uint32_t)(__ADDRESS__) & (I2C_CR2_SADD)) | (I2C_CR2_ADD10) | (I2C_CR2_START)) & (~I2C_CR2_RD_WRN)))
mbed_official 340:28d1f895c6fe 455
mbed_official 340:28d1f895c6fe 456 #define IS_I2C_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= (uint32_t)0x000003FF)
mbed_official 340:28d1f895c6fe 457 #define IS_I2C_OWN_ADDRESS2(ADDRESS2) ((ADDRESS2) <= (uint16_t)0x00FF)
mbed_official 340:28d1f895c6fe 458 /**
mbed_official 340:28d1f895c6fe 459 * @}
mbed_official 340:28d1f895c6fe 460 */
mbed_official 340:28d1f895c6fe 461
mbed_official 340:28d1f895c6fe 462 /* Include I2C HAL Extended module */
mbed_official 340:28d1f895c6fe 463 #include "stm32f0xx_hal_i2c_ex.h"
mbed_official 340:28d1f895c6fe 464
mbed_official 340:28d1f895c6fe 465 /* Exported functions --------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 466 /** @addtogroup I2C_Exported_Functions
mbed_official 340:28d1f895c6fe 467 * @{
mbed_official 340:28d1f895c6fe 468 */
mbed_official 340:28d1f895c6fe 469
mbed_official 340:28d1f895c6fe 470 /** @addtogroup I2C_Exported_Functions_Group1 Initialization and de-initialization functions
mbed_official 340:28d1f895c6fe 471 * @{
mbed_official 340:28d1f895c6fe 472 */
mbed_official 340:28d1f895c6fe 473
mbed_official 340:28d1f895c6fe 474 /* Initialization/de-initialization functions **********************************/
mbed_official 340:28d1f895c6fe 475 HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 476 HAL_StatusTypeDef HAL_I2C_DeInit (I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 477 void HAL_I2C_MspInit(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 478 void HAL_I2C_MspDeInit(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 479
mbed_official 340:28d1f895c6fe 480 /**
mbed_official 340:28d1f895c6fe 481 * @}
mbed_official 340:28d1f895c6fe 482 */
mbed_official 340:28d1f895c6fe 483
mbed_official 340:28d1f895c6fe 484 /** @addtogroup I2C_Exported_Functions_Group2 Input and Output operation functions
mbed_official 340:28d1f895c6fe 485 * @{
mbed_official 340:28d1f895c6fe 486 */
mbed_official 340:28d1f895c6fe 487
mbed_official 340:28d1f895c6fe 488 /* IO operation functions *****************************************************/
mbed_official 340:28d1f895c6fe 489
mbed_official 340:28d1f895c6fe 490 /******* Blocking mode: Polling */
mbed_official 340:28d1f895c6fe 491 HAL_StatusTypeDef HAL_I2C_Master_Transmit(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 492 HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 493 HAL_StatusTypeDef HAL_I2C_Slave_Transmit(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 494 HAL_StatusTypeDef HAL_I2C_Slave_Receive(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 495 HAL_StatusTypeDef HAL_I2C_Mem_Write(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 496 HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 497 HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint32_t Trials, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 498
mbed_official 340:28d1f895c6fe 499 /******* Non-Blocking mode: Interrupt */
mbed_official 340:28d1f895c6fe 500 HAL_StatusTypeDef HAL_I2C_Master_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 501 HAL_StatusTypeDef HAL_I2C_Master_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 502 HAL_StatusTypeDef HAL_I2C_Slave_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 503 HAL_StatusTypeDef HAL_I2C_Slave_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 504 HAL_StatusTypeDef HAL_I2C_Mem_Write_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 505 HAL_StatusTypeDef HAL_I2C_Mem_Read_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 506
mbed_official 340:28d1f895c6fe 507 /******* Non-Blocking mode: DMA */
mbed_official 340:28d1f895c6fe 508 HAL_StatusTypeDef HAL_I2C_Master_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 509 HAL_StatusTypeDef HAL_I2C_Master_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 510 HAL_StatusTypeDef HAL_I2C_Slave_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 511 HAL_StatusTypeDef HAL_I2C_Slave_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 512 HAL_StatusTypeDef HAL_I2C_Mem_Write_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 513 HAL_StatusTypeDef HAL_I2C_Mem_Read_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, uint16_t MemAddSize, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 514
mbed_official 340:28d1f895c6fe 515 /******* I2C IRQHandler and Callbacks used in non blocking modes (Interrupt and DMA) */
mbed_official 340:28d1f895c6fe 516 void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 517 void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 518 void HAL_I2C_MasterTxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 519 void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 520 void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 521 void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 522 void HAL_I2C_MemTxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 523 void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 524 void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 525
mbed_official 340:28d1f895c6fe 526 /**
mbed_official 340:28d1f895c6fe 527 * @}
mbed_official 340:28d1f895c6fe 528 */
mbed_official 340:28d1f895c6fe 529
mbed_official 340:28d1f895c6fe 530 /** @addtogroup I2C_Exported_Functions_Group3 Peripheral State and Errors functions
mbed_official 340:28d1f895c6fe 531 * @{
mbed_official 340:28d1f895c6fe 532 */
mbed_official 340:28d1f895c6fe 533
mbed_official 340:28d1f895c6fe 534 /* Peripheral State and Errors functions **************************************/
mbed_official 340:28d1f895c6fe 535 HAL_I2C_StateTypeDef HAL_I2C_GetState(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 536 uint32_t HAL_I2C_GetError(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 537
mbed_official 340:28d1f895c6fe 538 /**
mbed_official 340:28d1f895c6fe 539 * @}
mbed_official 340:28d1f895c6fe 540 */
mbed_official 340:28d1f895c6fe 541
mbed_official 340:28d1f895c6fe 542 /**
mbed_official 340:28d1f895c6fe 543 * @}
mbed_official 340:28d1f895c6fe 544 */
mbed_official 340:28d1f895c6fe 545
mbed_official 340:28d1f895c6fe 546 /**
mbed_official 340:28d1f895c6fe 547 * @}
mbed_official 340:28d1f895c6fe 548 */
mbed_official 340:28d1f895c6fe 549
mbed_official 340:28d1f895c6fe 550 /**
mbed_official 340:28d1f895c6fe 551 * @}
mbed_official 340:28d1f895c6fe 552 */
mbed_official 340:28d1f895c6fe 553
mbed_official 340:28d1f895c6fe 554 #ifdef __cplusplus
mbed_official 340:28d1f895c6fe 555 }
mbed_official 340:28d1f895c6fe 556 #endif
mbed_official 340:28d1f895c6fe 557
mbed_official 340:28d1f895c6fe 558
mbed_official 340:28d1f895c6fe 559 #endif /* __STM32F0xx_HAL_I2C_H */
mbed_official 340:28d1f895c6fe 560
mbed_official 340:28d1f895c6fe 561 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
mbed_official 340:28d1f895c6fe 562