mbed library sources

Fork of mbed-src by mbed official

Committer:
mbed_official
Date:
Thu Oct 09 08:15:07 2014 +0100
Revision:
340:28d1f895c6fe
Synchronized with git revision b5a4c8e80393336b2656fb29ab46d405d3068602

Full URL: https://github.com/mbedmicro/mbed/commit/b5a4c8e80393336b2656fb29ab46d405d3068602/

HAL: nrf51822 - Few fixes for PWM and Serial

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 340:28d1f895c6fe 5 * @version V1.1.0
mbed_official 340:28d1f895c6fe 6 * @date 03-Oct-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_Error_Code_structure_definition I2C Error Code structure definition
mbed_official 340:28d1f895c6fe 125 * @brief I2C Error Code structure definition
mbed_official 340:28d1f895c6fe 126 * @{
mbed_official 340:28d1f895c6fe 127 */
mbed_official 340:28d1f895c6fe 128
mbed_official 340:28d1f895c6fe 129 typedef enum
mbed_official 340:28d1f895c6fe 130 {
mbed_official 340:28d1f895c6fe 131 HAL_I2C_ERROR_NONE = 0x00, /*!< No error */
mbed_official 340:28d1f895c6fe 132 HAL_I2C_ERROR_BERR = 0x01, /*!< BERR error */
mbed_official 340:28d1f895c6fe 133 HAL_I2C_ERROR_ARLO = 0x02, /*!< ARLO error */
mbed_official 340:28d1f895c6fe 134 HAL_I2C_ERROR_AF = 0x04, /*!< AF error */
mbed_official 340:28d1f895c6fe 135 HAL_I2C_ERROR_OVR = 0x08, /*!< OVR error */
mbed_official 340:28d1f895c6fe 136 HAL_I2C_ERROR_DMA = 0x10, /*!< DMA transfer error */
mbed_official 340:28d1f895c6fe 137 HAL_I2C_ERROR_TIMEOUT = 0x20, /*!< Timeout error */
mbed_official 340:28d1f895c6fe 138 HAL_I2C_ERROR_SIZE = 0x40 /*!< Size Management error */
mbed_official 340:28d1f895c6fe 139 }HAL_I2C_ErrorTypeDef;
mbed_official 340:28d1f895c6fe 140
mbed_official 340:28d1f895c6fe 141 /**
mbed_official 340:28d1f895c6fe 142 * @}
mbed_official 340:28d1f895c6fe 143 */
mbed_official 340:28d1f895c6fe 144
mbed_official 340:28d1f895c6fe 145 /** @defgroup I2C_handle_Structure_definition I2C handle Structure definition
mbed_official 340:28d1f895c6fe 146 * @brief I2C handle Structure definition
mbed_official 340:28d1f895c6fe 147 * @{
mbed_official 340:28d1f895c6fe 148 */
mbed_official 340:28d1f895c6fe 149
mbed_official 340:28d1f895c6fe 150 typedef struct
mbed_official 340:28d1f895c6fe 151 {
mbed_official 340:28d1f895c6fe 152 I2C_TypeDef *Instance; /*!< I2C registers base address */
mbed_official 340:28d1f895c6fe 153
mbed_official 340:28d1f895c6fe 154 I2C_InitTypeDef Init; /*!< I2C communication parameters */
mbed_official 340:28d1f895c6fe 155
mbed_official 340:28d1f895c6fe 156 uint8_t *pBuffPtr; /*!< Pointer to I2C transfer buffer */
mbed_official 340:28d1f895c6fe 157
mbed_official 340:28d1f895c6fe 158 uint16_t XferSize; /*!< I2C transfer size */
mbed_official 340:28d1f895c6fe 159
mbed_official 340:28d1f895c6fe 160 __IO uint16_t XferCount; /*!< I2C transfer counter */
mbed_official 340:28d1f895c6fe 161
mbed_official 340:28d1f895c6fe 162 DMA_HandleTypeDef *hdmatx; /*!< I2C Tx DMA handle parameters */
mbed_official 340:28d1f895c6fe 163
mbed_official 340:28d1f895c6fe 164 DMA_HandleTypeDef *hdmarx; /*!< I2C Rx DMA handle parameters */
mbed_official 340:28d1f895c6fe 165
mbed_official 340:28d1f895c6fe 166 HAL_LockTypeDef Lock; /*!< I2C locking object */
mbed_official 340:28d1f895c6fe 167
mbed_official 340:28d1f895c6fe 168 __IO HAL_I2C_StateTypeDef State; /*!< I2C communication state */
mbed_official 340:28d1f895c6fe 169
mbed_official 340:28d1f895c6fe 170 __IO HAL_I2C_ErrorTypeDef ErrorCode; /* I2C Error code */
mbed_official 340:28d1f895c6fe 171
mbed_official 340:28d1f895c6fe 172 }I2C_HandleTypeDef;
mbed_official 340:28d1f895c6fe 173 /**
mbed_official 340:28d1f895c6fe 174 * @}
mbed_official 340:28d1f895c6fe 175 */
mbed_official 340:28d1f895c6fe 176
mbed_official 340:28d1f895c6fe 177 /**
mbed_official 340:28d1f895c6fe 178 * @}
mbed_official 340:28d1f895c6fe 179 */
mbed_official 340:28d1f895c6fe 180 /* Exported constants --------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 181
mbed_official 340:28d1f895c6fe 182 /** @defgroup I2C_Exported_Constants I2C Exported Constants
mbed_official 340:28d1f895c6fe 183 * @{
mbed_official 340:28d1f895c6fe 184 */
mbed_official 340:28d1f895c6fe 185
mbed_official 340:28d1f895c6fe 186 /** @defgroup I2C_addressing_mode I2C addressing mode
mbed_official 340:28d1f895c6fe 187 * @{
mbed_official 340:28d1f895c6fe 188 */
mbed_official 340:28d1f895c6fe 189 #define I2C_ADDRESSINGMODE_7BIT ((uint32_t)0x00000001)
mbed_official 340:28d1f895c6fe 190 #define I2C_ADDRESSINGMODE_10BIT ((uint32_t)0x00000002)
mbed_official 340:28d1f895c6fe 191
mbed_official 340:28d1f895c6fe 192 #define IS_I2C_ADDRESSING_MODE(MODE) (((MODE) == I2C_ADDRESSINGMODE_7BIT) || \
mbed_official 340:28d1f895c6fe 193 ((MODE) == I2C_ADDRESSINGMODE_10BIT))
mbed_official 340:28d1f895c6fe 194 /**
mbed_official 340:28d1f895c6fe 195 * @}
mbed_official 340:28d1f895c6fe 196 */
mbed_official 340:28d1f895c6fe 197
mbed_official 340:28d1f895c6fe 198 /** @defgroup I2C_dual_addressing_mode I2C dual addressing mode
mbed_official 340:28d1f895c6fe 199 * @{
mbed_official 340:28d1f895c6fe 200 */
mbed_official 340:28d1f895c6fe 201
mbed_official 340:28d1f895c6fe 202 #define I2C_DUALADDRESS_DISABLED ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 203 #define I2C_DUALADDRESS_ENABLED I2C_OAR2_OA2EN
mbed_official 340:28d1f895c6fe 204
mbed_official 340:28d1f895c6fe 205 #define IS_I2C_DUAL_ADDRESS(ADDRESS) (((ADDRESS) == I2C_DUALADDRESS_DISABLED) || \
mbed_official 340:28d1f895c6fe 206 ((ADDRESS) == I2C_DUALADDRESS_ENABLED))
mbed_official 340:28d1f895c6fe 207 /**
mbed_official 340:28d1f895c6fe 208 * @}
mbed_official 340:28d1f895c6fe 209 */
mbed_official 340:28d1f895c6fe 210
mbed_official 340:28d1f895c6fe 211 /** @defgroup I2C_own_address2_masks I2C own address2 masks
mbed_official 340:28d1f895c6fe 212 * @{
mbed_official 340:28d1f895c6fe 213 */
mbed_official 340:28d1f895c6fe 214
mbed_official 340:28d1f895c6fe 215 #define I2C_OA2_NOMASK ((uint8_t)0x00)
mbed_official 340:28d1f895c6fe 216 #define I2C_OA2_MASK01 ((uint8_t)0x01)
mbed_official 340:28d1f895c6fe 217 #define I2C_OA2_MASK02 ((uint8_t)0x02)
mbed_official 340:28d1f895c6fe 218 #define I2C_OA2_MASK03 ((uint8_t)0x03)
mbed_official 340:28d1f895c6fe 219 #define I2C_OA2_MASK04 ((uint8_t)0x04)
mbed_official 340:28d1f895c6fe 220 #define I2C_OA2_MASK05 ((uint8_t)0x05)
mbed_official 340:28d1f895c6fe 221 #define I2C_OA2_MASK06 ((uint8_t)0x06)
mbed_official 340:28d1f895c6fe 222 #define I2C_OA2_MASK07 ((uint8_t)0x07)
mbed_official 340:28d1f895c6fe 223
mbed_official 340:28d1f895c6fe 224 #define IS_I2C_OWN_ADDRESS2_MASK(MASK) (((MASK) == I2C_OA2_NOMASK) || \
mbed_official 340:28d1f895c6fe 225 ((MASK) == I2C_OA2_MASK01) || \
mbed_official 340:28d1f895c6fe 226 ((MASK) == I2C_OA2_MASK02) || \
mbed_official 340:28d1f895c6fe 227 ((MASK) == I2C_OA2_MASK03) || \
mbed_official 340:28d1f895c6fe 228 ((MASK) == I2C_OA2_MASK04) || \
mbed_official 340:28d1f895c6fe 229 ((MASK) == I2C_OA2_MASK05) || \
mbed_official 340:28d1f895c6fe 230 ((MASK) == I2C_OA2_MASK06) || \
mbed_official 340:28d1f895c6fe 231 ((MASK) == I2C_OA2_MASK07))
mbed_official 340:28d1f895c6fe 232 /**
mbed_official 340:28d1f895c6fe 233 * @}
mbed_official 340:28d1f895c6fe 234 */
mbed_official 340:28d1f895c6fe 235
mbed_official 340:28d1f895c6fe 236 /** @defgroup I2C_general_call_addressing_mode I2C general call addressing mode
mbed_official 340:28d1f895c6fe 237 * @{
mbed_official 340:28d1f895c6fe 238 */
mbed_official 340:28d1f895c6fe 239 #define I2C_GENERALCALL_DISABLED ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 240 #define I2C_GENERALCALL_ENABLED I2C_CR1_GCEN
mbed_official 340:28d1f895c6fe 241
mbed_official 340:28d1f895c6fe 242 #define IS_I2C_GENERAL_CALL(CALL) (((CALL) == I2C_GENERALCALL_DISABLED) || \
mbed_official 340:28d1f895c6fe 243 ((CALL) == I2C_GENERALCALL_ENABLED))
mbed_official 340:28d1f895c6fe 244 /**
mbed_official 340:28d1f895c6fe 245 * @}
mbed_official 340:28d1f895c6fe 246 */
mbed_official 340:28d1f895c6fe 247
mbed_official 340:28d1f895c6fe 248 /** @defgroup I2C_nostretch_mode I2C nostretch mode
mbed_official 340:28d1f895c6fe 249 * @{
mbed_official 340:28d1f895c6fe 250 */
mbed_official 340:28d1f895c6fe 251 #define I2C_NOSTRETCH_DISABLED ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 252 #define I2C_NOSTRETCH_ENABLED I2C_CR1_NOSTRETCH
mbed_official 340:28d1f895c6fe 253
mbed_official 340:28d1f895c6fe 254 #define IS_I2C_NO_STRETCH(STRETCH) (((STRETCH) == I2C_NOSTRETCH_DISABLED) || \
mbed_official 340:28d1f895c6fe 255 ((STRETCH) == I2C_NOSTRETCH_ENABLED))
mbed_official 340:28d1f895c6fe 256 /**
mbed_official 340:28d1f895c6fe 257 * @}
mbed_official 340:28d1f895c6fe 258 */
mbed_official 340:28d1f895c6fe 259
mbed_official 340:28d1f895c6fe 260 /** @defgroup I2C_Memory_Address_Size I2C Memory Address Size
mbed_official 340:28d1f895c6fe 261 * @{
mbed_official 340:28d1f895c6fe 262 */
mbed_official 340:28d1f895c6fe 263 #define I2C_MEMADD_SIZE_8BIT ((uint32_t)0x00000001)
mbed_official 340:28d1f895c6fe 264 #define I2C_MEMADD_SIZE_16BIT ((uint32_t)0x00000002)
mbed_official 340:28d1f895c6fe 265
mbed_official 340:28d1f895c6fe 266 #define IS_I2C_MEMADD_SIZE(SIZE) (((SIZE) == I2C_MEMADD_SIZE_8BIT) || \
mbed_official 340:28d1f895c6fe 267 ((SIZE) == I2C_MEMADD_SIZE_16BIT))
mbed_official 340:28d1f895c6fe 268 /**
mbed_official 340:28d1f895c6fe 269 * @}
mbed_official 340:28d1f895c6fe 270 */
mbed_official 340:28d1f895c6fe 271
mbed_official 340:28d1f895c6fe 272 /** @defgroup I2C_ReloadEndMode_definition I2C ReloadEndMode definition
mbed_official 340:28d1f895c6fe 273 * @{
mbed_official 340:28d1f895c6fe 274 */
mbed_official 340:28d1f895c6fe 275
mbed_official 340:28d1f895c6fe 276 #define I2C_RELOAD_MODE I2C_CR2_RELOAD
mbed_official 340:28d1f895c6fe 277 #define I2C_AUTOEND_MODE I2C_CR2_AUTOEND
mbed_official 340:28d1f895c6fe 278 #define I2C_SOFTEND_MODE ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 279
mbed_official 340:28d1f895c6fe 280 #define IS_TRANSFER_MODE(MODE) (((MODE) == I2C_RELOAD_MODE) || \
mbed_official 340:28d1f895c6fe 281 ((MODE) == I2C_AUTOEND_MODE) || \
mbed_official 340:28d1f895c6fe 282 ((MODE) == I2C_SOFTEND_MODE))
mbed_official 340:28d1f895c6fe 283 /**
mbed_official 340:28d1f895c6fe 284 * @}
mbed_official 340:28d1f895c6fe 285 */
mbed_official 340:28d1f895c6fe 286
mbed_official 340:28d1f895c6fe 287 /** @defgroup I2C_StartStopMode_definition I2C StartStopMode definition
mbed_official 340:28d1f895c6fe 288 * @{
mbed_official 340:28d1f895c6fe 289 */
mbed_official 340:28d1f895c6fe 290
mbed_official 340:28d1f895c6fe 291 #define I2C_NO_STARTSTOP ((uint32_t)0x00000000)
mbed_official 340:28d1f895c6fe 292 #define I2C_GENERATE_STOP I2C_CR2_STOP
mbed_official 340:28d1f895c6fe 293 #define I2C_GENERATE_START_READ (uint32_t)(I2C_CR2_START | I2C_CR2_RD_WRN)
mbed_official 340:28d1f895c6fe 294 #define I2C_GENERATE_START_WRITE I2C_CR2_START
mbed_official 340:28d1f895c6fe 295
mbed_official 340:28d1f895c6fe 296 #define IS_TRANSFER_REQUEST(REQUEST) (((REQUEST) == I2C_GENERATE_STOP) || \
mbed_official 340:28d1f895c6fe 297 ((REQUEST) == I2C_GENERATE_START_READ) || \
mbed_official 340:28d1f895c6fe 298 ((REQUEST) == I2C_GENERATE_START_WRITE) || \
mbed_official 340:28d1f895c6fe 299 ((REQUEST) == I2C_NO_STARTSTOP))
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
mbed_official 340:28d1f895c6fe 305 /** @defgroup I2C_Interrupt_configuration_definition I2C Interrupt configuration definition
mbed_official 340:28d1f895c6fe 306 * @brief I2C Interrupt definition
mbed_official 340:28d1f895c6fe 307 * Elements values convention: 0xXXXXXXXX
mbed_official 340:28d1f895c6fe 308 * - XXXXXXXX : Interrupt control mask
mbed_official 340:28d1f895c6fe 309 * @{
mbed_official 340:28d1f895c6fe 310 */
mbed_official 340:28d1f895c6fe 311 #define I2C_IT_ERRI I2C_CR1_ERRIE
mbed_official 340:28d1f895c6fe 312 #define I2C_IT_TCI I2C_CR1_TCIE
mbed_official 340:28d1f895c6fe 313 #define I2C_IT_STOPI I2C_CR1_STOPIE
mbed_official 340:28d1f895c6fe 314 #define I2C_IT_NACKI I2C_CR1_NACKIE
mbed_official 340:28d1f895c6fe 315 #define I2C_IT_ADDRI I2C_CR1_ADDRIE
mbed_official 340:28d1f895c6fe 316 #define I2C_IT_RXI I2C_CR1_RXIE
mbed_official 340:28d1f895c6fe 317 #define I2C_IT_TXI I2C_CR1_TXIE
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
mbed_official 340:28d1f895c6fe 324 /** @defgroup I2C_Flag_definition I2C Flag definition
mbed_official 340:28d1f895c6fe 325 * @{
mbed_official 340:28d1f895c6fe 326 */
mbed_official 340:28d1f895c6fe 327
mbed_official 340:28d1f895c6fe 328 #define I2C_FLAG_TXE I2C_ISR_TXE
mbed_official 340:28d1f895c6fe 329 #define I2C_FLAG_TXIS I2C_ISR_TXIS
mbed_official 340:28d1f895c6fe 330 #define I2C_FLAG_RXNE I2C_ISR_RXNE
mbed_official 340:28d1f895c6fe 331 #define I2C_FLAG_ADDR I2C_ISR_ADDR
mbed_official 340:28d1f895c6fe 332 #define I2C_FLAG_AF I2C_ISR_NACKF
mbed_official 340:28d1f895c6fe 333 #define I2C_FLAG_STOPF I2C_ISR_STOPF
mbed_official 340:28d1f895c6fe 334 #define I2C_FLAG_TC I2C_ISR_TC
mbed_official 340:28d1f895c6fe 335 #define I2C_FLAG_TCR I2C_ISR_TCR
mbed_official 340:28d1f895c6fe 336 #define I2C_FLAG_BERR I2C_ISR_BERR
mbed_official 340:28d1f895c6fe 337 #define I2C_FLAG_ARLO I2C_ISR_ARLO
mbed_official 340:28d1f895c6fe 338 #define I2C_FLAG_OVR I2C_ISR_OVR
mbed_official 340:28d1f895c6fe 339 #define I2C_FLAG_PECERR I2C_ISR_PECERR
mbed_official 340:28d1f895c6fe 340 #define I2C_FLAG_TIMEOUT I2C_ISR_TIMEOUT
mbed_official 340:28d1f895c6fe 341 #define I2C_FLAG_ALERT I2C_ISR_ALERT
mbed_official 340:28d1f895c6fe 342 #define I2C_FLAG_BUSY I2C_ISR_BUSY
mbed_official 340:28d1f895c6fe 343 #define I2C_FLAG_DIR I2C_ISR_DIR
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
mbed_official 340:28d1f895c6fe 352 /* Exported macros -----------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 353
mbed_official 340:28d1f895c6fe 354 /** @defgroup I2C_Exported_Macros I2C Exported Macros
mbed_official 340:28d1f895c6fe 355 * @{
mbed_official 340:28d1f895c6fe 356 */
mbed_official 340:28d1f895c6fe 357
mbed_official 340:28d1f895c6fe 358 /** @brief Reset I2C handle state
mbed_official 340:28d1f895c6fe 359 * @param __HANDLE__: I2C handle.
mbed_official 340:28d1f895c6fe 360 * @retval None
mbed_official 340:28d1f895c6fe 361 */
mbed_official 340:28d1f895c6fe 362 #define __HAL_I2C_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_I2C_STATE_RESET)
mbed_official 340:28d1f895c6fe 363
mbed_official 340:28d1f895c6fe 364 /** @brief Enables or disables the specified I2C interrupts.
mbed_official 340:28d1f895c6fe 365 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 366 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 367 * @param __INTERRUPT__: specifies the interrupt source to enable or disable.
mbed_official 340:28d1f895c6fe 368 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 369 * @arg I2C_IT_ERRI: Errors interrupt enable
mbed_official 340:28d1f895c6fe 370 * @arg I2C_IT_TCI: Transfer complete interrupt enable
mbed_official 340:28d1f895c6fe 371 * @arg I2C_IT_STOPI: STOP detection interrupt enable
mbed_official 340:28d1f895c6fe 372 * @arg I2C_IT_NACKI: NACK received interrupt enable
mbed_official 340:28d1f895c6fe 373 * @arg I2C_IT_ADDRI: Address match interrupt enable
mbed_official 340:28d1f895c6fe 374 * @arg I2C_IT_RXI: RX interrupt enable
mbed_official 340:28d1f895c6fe 375 * @arg I2C_IT_TXI: TX interrupt enable
mbed_official 340:28d1f895c6fe 376 *
mbed_official 340:28d1f895c6fe 377 * @retval None
mbed_official 340:28d1f895c6fe 378 */
mbed_official 340:28d1f895c6fe 379
mbed_official 340:28d1f895c6fe 380 #define __HAL_I2C_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 |= (__INTERRUPT__))
mbed_official 340:28d1f895c6fe 381 #define __HAL_I2C_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 &= (~(__INTERRUPT__)))
mbed_official 340:28d1f895c6fe 382
mbed_official 340:28d1f895c6fe 383 /** @brief Checks if the specified I2C interrupt source is enabled or disabled.
mbed_official 340:28d1f895c6fe 384 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 385 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 386 * @param __INTERRUPT__: specifies the I2C interrupt source to check.
mbed_official 340:28d1f895c6fe 387 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 388 * @arg I2C_IT_ERRI: Errors interrupt enable
mbed_official 340:28d1f895c6fe 389 * @arg I2C_IT_TCI: Transfer complete interrupt enable
mbed_official 340:28d1f895c6fe 390 * @arg I2C_IT_STOPI: STOP detection interrupt enable
mbed_official 340:28d1f895c6fe 391 * @arg I2C_IT_NACKI: NACK received interrupt enable
mbed_official 340:28d1f895c6fe 392 * @arg I2C_IT_ADDRI: Address match interrupt enable
mbed_official 340:28d1f895c6fe 393 * @arg I2C_IT_RXI: RX interrupt enable
mbed_official 340:28d1f895c6fe 394 * @arg I2C_IT_TXI: TX interrupt enable
mbed_official 340:28d1f895c6fe 395 *
mbed_official 340:28d1f895c6fe 396 * @retval The new state of __IT__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 397 */
mbed_official 340:28d1f895c6fe 398 #define __HAL_I2C_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->CR1 & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
mbed_official 340:28d1f895c6fe 399
mbed_official 340:28d1f895c6fe 400 /** @brief Checks whether the specified I2C flag is set or not.
mbed_official 340:28d1f895c6fe 401 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 402 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 403 * @param __FLAG__: specifies the flag to check.
mbed_official 340:28d1f895c6fe 404 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 405 * @arg I2C_FLAG_TXE: Transmit data register empty
mbed_official 340:28d1f895c6fe 406 * @arg I2C_FLAG_TXIS: Transmit interrupt status
mbed_official 340:28d1f895c6fe 407 * @arg I2C_FLAG_RXNE: Receive data register not empty
mbed_official 340:28d1f895c6fe 408 * @arg I2C_FLAG_ADDR: Address matched (slave mode)
mbed_official 340:28d1f895c6fe 409 * @arg I2C_FLAG_AF: Acknowledge failure received flag
mbed_official 340:28d1f895c6fe 410 * @arg I2C_FLAG_STOPF: STOP detection flag
mbed_official 340:28d1f895c6fe 411 * @arg I2C_FLAG_TC: Transfer complete (master mode)
mbed_official 340:28d1f895c6fe 412 * @arg I2C_FLAG_TCR: Transfer complete reload
mbed_official 340:28d1f895c6fe 413 * @arg I2C_FLAG_BERR: Bus error
mbed_official 340:28d1f895c6fe 414 * @arg I2C_FLAG_ARLO: Arbitration lost
mbed_official 340:28d1f895c6fe 415 * @arg I2C_FLAG_OVR: Overrun/Underrun
mbed_official 340:28d1f895c6fe 416 * @arg I2C_FLAG_PECERR: PEC error in reception
mbed_official 340:28d1f895c6fe 417 * @arg I2C_FLAG_TIMEOUT: Timeout or Tlow detection flag
mbed_official 340:28d1f895c6fe 418 * @arg I2C_FLAG_ALERT: SMBus alert
mbed_official 340:28d1f895c6fe 419 * @arg I2C_FLAG_BUSY: Bus busy
mbed_official 340:28d1f895c6fe 420 * @arg I2C_FLAG_DIR: Transfer direction (slave mode)
mbed_official 340:28d1f895c6fe 421 *
mbed_official 340:28d1f895c6fe 422 * @retval The new state of __FLAG__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 423 */
mbed_official 340:28d1f895c6fe 424 #define __HAL_I2C_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->ISR) & (__FLAG__)) == (__FLAG__))
mbed_official 340:28d1f895c6fe 425
mbed_official 340:28d1f895c6fe 426 /** @brief Clears the I2C pending flags which are cleared by writing 1 in a specific bit.
mbed_official 340:28d1f895c6fe 427 * @param __HANDLE__: specifies the I2C Handle.
mbed_official 340:28d1f895c6fe 428 * This parameter can be I2Cx where x: 1 or 2 to select the I2C peripheral.
mbed_official 340:28d1f895c6fe 429 * @param __FLAG__: specifies the flag to clear.
mbed_official 340:28d1f895c6fe 430 * This parameter can be any combination of the following values:
mbed_official 340:28d1f895c6fe 431 * @arg I2C_FLAG_ADDR: Address matched (slave mode)
mbed_official 340:28d1f895c6fe 432 * @arg I2C_FLAG_AF: Acknowledge failure flag
mbed_official 340:28d1f895c6fe 433 * @arg I2C_FLAG_STOPF: STOP detection flag
mbed_official 340:28d1f895c6fe 434 * @arg I2C_FLAG_BERR: Bus error
mbed_official 340:28d1f895c6fe 435 * @arg I2C_FLAG_ARLO: Arbitration lost
mbed_official 340:28d1f895c6fe 436 * @arg I2C_FLAG_OVR: Overrun/Underrun
mbed_official 340:28d1f895c6fe 437 * @arg I2C_FLAG_PECERR: PEC error in reception
mbed_official 340:28d1f895c6fe 438 * @arg I2C_FLAG_TIMEOUT: Timeout or Tlow detection flag
mbed_official 340:28d1f895c6fe 439 * @arg I2C_FLAG_ALERT: SMBus alert
mbed_official 340:28d1f895c6fe 440 *
mbed_official 340:28d1f895c6fe 441 * @retval None
mbed_official 340:28d1f895c6fe 442 */
mbed_official 340:28d1f895c6fe 443 #define __HAL_I2C_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__))
mbed_official 340:28d1f895c6fe 444
mbed_official 340:28d1f895c6fe 445
mbed_official 340:28d1f895c6fe 446 #define __HAL_I2C_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= I2C_CR1_PE)
mbed_official 340:28d1f895c6fe 447 #define __HAL_I2C_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~I2C_CR1_PE)
mbed_official 340:28d1f895c6fe 448
mbed_official 340:28d1f895c6fe 449 #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 450
mbed_official 340:28d1f895c6fe 451 #define __HAL_I2C_MEM_ADD_MSB(__ADDRESS__) ((uint8_t)((uint16_t)(((uint16_t)((__ADDRESS__) & (uint16_t)(0xFF00))) >> 8)))
mbed_official 340:28d1f895c6fe 452 #define __HAL_I2C_MEM_ADD_LSB(__ADDRESS__) ((uint8_t)((uint16_t)((__ADDRESS__) & (uint16_t)(0x00FF))))
mbed_official 340:28d1f895c6fe 453
mbed_official 340:28d1f895c6fe 454 #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 455 (uint32_t)((((uint32_t)(__ADDRESS__) & (I2C_CR2_SADD)) | (I2C_CR2_ADD10) | (I2C_CR2_START)) & (~I2C_CR2_RD_WRN)))
mbed_official 340:28d1f895c6fe 456
mbed_official 340:28d1f895c6fe 457 #define IS_I2C_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= (uint32_t)0x000003FF)
mbed_official 340:28d1f895c6fe 458 #define IS_I2C_OWN_ADDRESS2(ADDRESS2) ((ADDRESS2) <= (uint16_t)0x00FF)
mbed_official 340:28d1f895c6fe 459 /**
mbed_official 340:28d1f895c6fe 460 * @}
mbed_official 340:28d1f895c6fe 461 */
mbed_official 340:28d1f895c6fe 462
mbed_official 340:28d1f895c6fe 463 /* Include I2C HAL Extended module */
mbed_official 340:28d1f895c6fe 464 #include "stm32f0xx_hal_i2c_ex.h"
mbed_official 340:28d1f895c6fe 465
mbed_official 340:28d1f895c6fe 466 /* Exported functions --------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 467 /** @addtogroup I2C_Exported_Functions
mbed_official 340:28d1f895c6fe 468 * @{
mbed_official 340:28d1f895c6fe 469 */
mbed_official 340:28d1f895c6fe 470
mbed_official 340:28d1f895c6fe 471 /** @addtogroup I2C_Exported_Functions_Group1 Initialization and de-initialization functions
mbed_official 340:28d1f895c6fe 472 * @{
mbed_official 340:28d1f895c6fe 473 */
mbed_official 340:28d1f895c6fe 474
mbed_official 340:28d1f895c6fe 475 /* Initialization/de-initialization functions **********************************/
mbed_official 340:28d1f895c6fe 476 HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 477 HAL_StatusTypeDef HAL_I2C_DeInit (I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 478 void HAL_I2C_MspInit(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 479 void HAL_I2C_MspDeInit(I2C_HandleTypeDef *hi2c);
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
mbed_official 340:28d1f895c6fe 485 /** @addtogroup I2C_Exported_Functions_Group2 Input and Output operation functions
mbed_official 340:28d1f895c6fe 486 * @{
mbed_official 340:28d1f895c6fe 487 */
mbed_official 340:28d1f895c6fe 488
mbed_official 340:28d1f895c6fe 489 /* IO operation functions *****************************************************/
mbed_official 340:28d1f895c6fe 490
mbed_official 340:28d1f895c6fe 491 /******* Blocking mode: Polling */
mbed_official 340:28d1f895c6fe 492 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 493 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 494 HAL_StatusTypeDef HAL_I2C_Slave_Transmit(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 495 HAL_StatusTypeDef HAL_I2C_Slave_Receive(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 496 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 497 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 498 HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint32_t Trials, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 499
mbed_official 340:28d1f895c6fe 500 /******* Non-Blocking mode: Interrupt */
mbed_official 340:28d1f895c6fe 501 HAL_StatusTypeDef HAL_I2C_Master_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 502 HAL_StatusTypeDef HAL_I2C_Master_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 503 HAL_StatusTypeDef HAL_I2C_Slave_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 504 HAL_StatusTypeDef HAL_I2C_Slave_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 505 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 506 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 507
mbed_official 340:28d1f895c6fe 508 /******* Non-Blocking mode: DMA */
mbed_official 340:28d1f895c6fe 509 HAL_StatusTypeDef HAL_I2C_Master_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 510 HAL_StatusTypeDef HAL_I2C_Master_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 511 HAL_StatusTypeDef HAL_I2C_Slave_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 512 HAL_StatusTypeDef HAL_I2C_Slave_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 513 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 514 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 515
mbed_official 340:28d1f895c6fe 516 /******* I2C IRQHandler and Callbacks used in non blocking modes (Interrupt and DMA) */
mbed_official 340:28d1f895c6fe 517 void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 518 void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 519 void HAL_I2C_MasterTxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 520 void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 521 void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 522 void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 523 void HAL_I2C_MemTxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 524 void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 525 void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c);
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
mbed_official 340:28d1f895c6fe 531 /** @addtogroup I2C_Exported_Functions_Group3 Peripheral State and Errors functions
mbed_official 340:28d1f895c6fe 532 * @{
mbed_official 340:28d1f895c6fe 533 */
mbed_official 340:28d1f895c6fe 534
mbed_official 340:28d1f895c6fe 535 /* Peripheral State and Errors functions **************************************/
mbed_official 340:28d1f895c6fe 536 HAL_I2C_StateTypeDef HAL_I2C_GetState(I2C_HandleTypeDef *hi2c);
mbed_official 340:28d1f895c6fe 537 uint32_t HAL_I2C_GetError(I2C_HandleTypeDef *hi2c);
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
mbed_official 340:28d1f895c6fe 555 #ifdef __cplusplus
mbed_official 340:28d1f895c6fe 556 }
mbed_official 340:28d1f895c6fe 557 #endif
mbed_official 340:28d1f895c6fe 558
mbed_official 340:28d1f895c6fe 559
mbed_official 340:28d1f895c6fe 560 #endif /* __STM32F0xx_HAL_I2C_H */
mbed_official 340:28d1f895c6fe 561
mbed_official 340:28d1f895c6fe 562 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
mbed_official 340:28d1f895c6fe 563