TUKS MCU Introductory course / TUKS-COURSE-TIMER
Committer:
elmot
Date:
Fri Feb 24 21:13:56 2017 +0000
Revision:
1:d0dfbce63a89
Ready-to-copy

Who changed what in which revision?

UserRevisionLine numberNew contents of line
elmot 1:d0dfbce63a89 1 /**
elmot 1:d0dfbce63a89 2 ******************************************************************************
elmot 1:d0dfbce63a89 3 * @file stm32l4xx_hal_irda.h
elmot 1:d0dfbce63a89 4 * @author MCD Application Team
elmot 1:d0dfbce63a89 5 * @version V1.5.1
elmot 1:d0dfbce63a89 6 * @date 31-May-2016
elmot 1:d0dfbce63a89 7 * @brief Header file of IRDA HAL module.
elmot 1:d0dfbce63a89 8 ******************************************************************************
elmot 1:d0dfbce63a89 9 * @attention
elmot 1:d0dfbce63a89 10 *
elmot 1:d0dfbce63a89 11 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
elmot 1:d0dfbce63a89 12 *
elmot 1:d0dfbce63a89 13 * Redistribution and use in source and binary forms, with or without modification,
elmot 1:d0dfbce63a89 14 * are permitted provided that the following conditions are met:
elmot 1:d0dfbce63a89 15 * 1. Redistributions of source code must retain the above copyright notice,
elmot 1:d0dfbce63a89 16 * this list of conditions and the following disclaimer.
elmot 1:d0dfbce63a89 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
elmot 1:d0dfbce63a89 18 * this list of conditions and the following disclaimer in the documentation
elmot 1:d0dfbce63a89 19 * and/or other materials provided with the distribution.
elmot 1:d0dfbce63a89 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
elmot 1:d0dfbce63a89 21 * may be used to endorse or promote products derived from this software
elmot 1:d0dfbce63a89 22 * without specific prior written permission.
elmot 1:d0dfbce63a89 23 *
elmot 1:d0dfbce63a89 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
elmot 1:d0dfbce63a89 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
elmot 1:d0dfbce63a89 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
elmot 1:d0dfbce63a89 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
elmot 1:d0dfbce63a89 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
elmot 1:d0dfbce63a89 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
elmot 1:d0dfbce63a89 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
elmot 1:d0dfbce63a89 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
elmot 1:d0dfbce63a89 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
elmot 1:d0dfbce63a89 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
elmot 1:d0dfbce63a89 34 *
elmot 1:d0dfbce63a89 35 ******************************************************************************
elmot 1:d0dfbce63a89 36 */
elmot 1:d0dfbce63a89 37
elmot 1:d0dfbce63a89 38 /* Define to prevent recursive inclusion -------------------------------------*/
elmot 1:d0dfbce63a89 39 #ifndef __STM32L4xx_HAL_IRDA_H
elmot 1:d0dfbce63a89 40 #define __STM32L4xx_HAL_IRDA_H
elmot 1:d0dfbce63a89 41
elmot 1:d0dfbce63a89 42 #ifdef __cplusplus
elmot 1:d0dfbce63a89 43 extern "C" {
elmot 1:d0dfbce63a89 44 #endif
elmot 1:d0dfbce63a89 45
elmot 1:d0dfbce63a89 46 /* Includes ------------------------------------------------------------------*/
elmot 1:d0dfbce63a89 47 #include "stm32l4xx_hal_def.h"
elmot 1:d0dfbce63a89 48
elmot 1:d0dfbce63a89 49 /** @addtogroup STM32L4xx_HAL_Driver
elmot 1:d0dfbce63a89 50 * @{
elmot 1:d0dfbce63a89 51 */
elmot 1:d0dfbce63a89 52
elmot 1:d0dfbce63a89 53 /** @addtogroup IRDA
elmot 1:d0dfbce63a89 54 * @{
elmot 1:d0dfbce63a89 55 */
elmot 1:d0dfbce63a89 56
elmot 1:d0dfbce63a89 57 /* Exported types ------------------------------------------------------------*/
elmot 1:d0dfbce63a89 58 /** @defgroup IRDA_Exported_Types IRDA Exported Types
elmot 1:d0dfbce63a89 59 * @{
elmot 1:d0dfbce63a89 60 */
elmot 1:d0dfbce63a89 61
elmot 1:d0dfbce63a89 62 /**
elmot 1:d0dfbce63a89 63 * @brief IRDA Init Structure definition
elmot 1:d0dfbce63a89 64 */
elmot 1:d0dfbce63a89 65 typedef struct
elmot 1:d0dfbce63a89 66 {
elmot 1:d0dfbce63a89 67 uint32_t BaudRate; /*!< This member configures the IRDA communication baud rate.
elmot 1:d0dfbce63a89 68 The baud rate register is computed using the following formula:
elmot 1:d0dfbce63a89 69 Baud Rate Register = ((PCLKx) / ((hirda->Init.BaudRate))) */
elmot 1:d0dfbce63a89 70
elmot 1:d0dfbce63a89 71 uint32_t WordLength; /*!< Specifies the number of data bits transmitted or received in a frame.
elmot 1:d0dfbce63a89 72 This parameter can be a value of @ref IRDA_Word_Length */
elmot 1:d0dfbce63a89 73
elmot 1:d0dfbce63a89 74 uint32_t Parity; /*!< Specifies the parity mode.
elmot 1:d0dfbce63a89 75 This parameter can be a value of @ref IRDA_Parity
elmot 1:d0dfbce63a89 76 @note When parity is enabled, the computed parity is inserted
elmot 1:d0dfbce63a89 77 at the MSB position of the transmitted data (9th bit when
elmot 1:d0dfbce63a89 78 the word length is set to 9 data bits; 8th bit when the
elmot 1:d0dfbce63a89 79 word length is set to 8 data bits). */
elmot 1:d0dfbce63a89 80
elmot 1:d0dfbce63a89 81 uint32_t Mode; /*!< Specifies whether the Receive or Transmit mode is enabled or disabled.
elmot 1:d0dfbce63a89 82 This parameter can be a value of @ref IRDA_Transfer_Mode */
elmot 1:d0dfbce63a89 83
elmot 1:d0dfbce63a89 84 uint8_t Prescaler; /*!< Specifies the Prescaler value for dividing the UART/USART source clock
elmot 1:d0dfbce63a89 85 to achieve low-power frequency.
elmot 1:d0dfbce63a89 86 @note Prescaler value 0 is forbidden */
elmot 1:d0dfbce63a89 87
elmot 1:d0dfbce63a89 88 uint16_t PowerMode; /*!< Specifies the IRDA power mode.
elmot 1:d0dfbce63a89 89 This parameter can be a value of @ref IRDA_Low_Power */
elmot 1:d0dfbce63a89 90 }IRDA_InitTypeDef;
elmot 1:d0dfbce63a89 91
elmot 1:d0dfbce63a89 92 /**
elmot 1:d0dfbce63a89 93 * @brief HAL IRDA State structures definition
elmot 1:d0dfbce63a89 94 * @note HAL IRDA State value is a combination of 2 different substates: gState and RxState.
elmot 1:d0dfbce63a89 95 * - gState contains IRDA state information related to global Handle management
elmot 1:d0dfbce63a89 96 * and also information related to Tx operations.
elmot 1:d0dfbce63a89 97 * gState value coding follow below described bitmap :
elmot 1:d0dfbce63a89 98 * b7-b6 Error information
elmot 1:d0dfbce63a89 99 * 00 : No Error
elmot 1:d0dfbce63a89 100 * 01 : (Not Used)
elmot 1:d0dfbce63a89 101 * 10 : Timeout
elmot 1:d0dfbce63a89 102 * 11 : Error
elmot 1:d0dfbce63a89 103 * b5 IP initilisation status
elmot 1:d0dfbce63a89 104 * 0 : Reset (IP not initialized)
elmot 1:d0dfbce63a89 105 * 1 : Init done (IP not initialized. HAL IRDA Init function already called)
elmot 1:d0dfbce63a89 106 * b4-b3 (not used)
elmot 1:d0dfbce63a89 107 * xx : Should be set to 00
elmot 1:d0dfbce63a89 108 * b2 Intrinsic process state
elmot 1:d0dfbce63a89 109 * 0 : Ready
elmot 1:d0dfbce63a89 110 * 1 : Busy (IP busy with some configuration or internal operations)
elmot 1:d0dfbce63a89 111 * b1 (not used)
elmot 1:d0dfbce63a89 112 * x : Should be set to 0
elmot 1:d0dfbce63a89 113 * b0 Tx state
elmot 1:d0dfbce63a89 114 * 0 : Ready (no Tx operation ongoing)
elmot 1:d0dfbce63a89 115 * 1 : Busy (Tx operation ongoing)
elmot 1:d0dfbce63a89 116 * - RxState contains information related to Rx operations.
elmot 1:d0dfbce63a89 117 * RxState value coding follow below described bitmap :
elmot 1:d0dfbce63a89 118 * b7-b6 (not used)
elmot 1:d0dfbce63a89 119 * xx : Should be set to 00
elmot 1:d0dfbce63a89 120 * b5 IP initilisation status
elmot 1:d0dfbce63a89 121 * 0 : Reset (IP not initialized)
elmot 1:d0dfbce63a89 122 * 1 : Init done (IP not initialized)
elmot 1:d0dfbce63a89 123 * b4-b2 (not used)
elmot 1:d0dfbce63a89 124 * xxx : Should be set to 000
elmot 1:d0dfbce63a89 125 * b1 Rx state
elmot 1:d0dfbce63a89 126 * 0 : Ready (no Rx operation ongoing)
elmot 1:d0dfbce63a89 127 * 1 : Busy (Rx operation ongoing)
elmot 1:d0dfbce63a89 128 * b0 (not used)
elmot 1:d0dfbce63a89 129 * x : Should be set to 0.
elmot 1:d0dfbce63a89 130 */
elmot 1:d0dfbce63a89 131 typedef enum
elmot 1:d0dfbce63a89 132 {
elmot 1:d0dfbce63a89 133 HAL_IRDA_STATE_RESET = 0x00U, /*!< Peripheral is not initialized
elmot 1:d0dfbce63a89 134 Value is allowed for gState and RxState */
elmot 1:d0dfbce63a89 135 HAL_IRDA_STATE_READY = 0x20U, /*!< Peripheral Initialized and ready for use
elmot 1:d0dfbce63a89 136 Value is allowed for gState and RxState */
elmot 1:d0dfbce63a89 137 HAL_IRDA_STATE_BUSY = 0x24U, /*!< an internal process is ongoing
elmot 1:d0dfbce63a89 138 Value is allowed for gState only */
elmot 1:d0dfbce63a89 139 HAL_IRDA_STATE_BUSY_TX = 0x21U, /*!< Data Transmission process is ongoing
elmot 1:d0dfbce63a89 140 Value is allowed for gState only */
elmot 1:d0dfbce63a89 141 HAL_IRDA_STATE_BUSY_RX = 0x22U, /*!< Data Reception process is ongoing
elmot 1:d0dfbce63a89 142 Value is allowed for RxState only */
elmot 1:d0dfbce63a89 143 HAL_IRDA_STATE_BUSY_TX_RX = 0x23U, /*!< Data Transmission and Reception process is ongoing
elmot 1:d0dfbce63a89 144 Not to be used for neither gState nor RxState.
elmot 1:d0dfbce63a89 145 Value is result of combination (Or) between gState and RxState values */
elmot 1:d0dfbce63a89 146 HAL_IRDA_STATE_TIMEOUT = 0xA0U, /*!< Timeout state
elmot 1:d0dfbce63a89 147 Value is allowed for gState only */
elmot 1:d0dfbce63a89 148 HAL_IRDA_STATE_ERROR = 0xE0U /*!< Error
elmot 1:d0dfbce63a89 149 Value is allowed for gState only */
elmot 1:d0dfbce63a89 150 }HAL_IRDA_StateTypeDef;
elmot 1:d0dfbce63a89 151
elmot 1:d0dfbce63a89 152 /**
elmot 1:d0dfbce63a89 153 * @brief HAL IRDA Error Code structure definition
elmot 1:d0dfbce63a89 154 */
elmot 1:d0dfbce63a89 155 typedef enum
elmot 1:d0dfbce63a89 156 {
elmot 1:d0dfbce63a89 157 HAL_IRDA_ERROR_NONE = 0x00, /*!< No error */
elmot 1:d0dfbce63a89 158 HAL_IRDA_ERROR_PE = 0x01, /*!< Parity error */
elmot 1:d0dfbce63a89 159 HAL_IRDA_ERROR_NE = 0x02, /*!< Noise error */
elmot 1:d0dfbce63a89 160 HAL_IRDA_ERROR_FE = 0x04, /*!< frame error */
elmot 1:d0dfbce63a89 161 HAL_IRDA_ERROR_ORE = 0x08, /*!< Overrun error */
elmot 1:d0dfbce63a89 162 HAL_IRDA_ERROR_DMA = 0x10 /*!< DMA transfer error */
elmot 1:d0dfbce63a89 163 }HAL_IRDA_ErrorTypeDef;
elmot 1:d0dfbce63a89 164
elmot 1:d0dfbce63a89 165 /**
elmot 1:d0dfbce63a89 166 * @brief IRDA clock sources definition
elmot 1:d0dfbce63a89 167 */
elmot 1:d0dfbce63a89 168 typedef enum
elmot 1:d0dfbce63a89 169 {
elmot 1:d0dfbce63a89 170 IRDA_CLOCKSOURCE_PCLK1 = 0x00, /*!< PCLK1 clock source */
elmot 1:d0dfbce63a89 171 IRDA_CLOCKSOURCE_PCLK2 = 0x01, /*!< PCLK2 clock source */
elmot 1:d0dfbce63a89 172 IRDA_CLOCKSOURCE_HSI = 0x02, /*!< HSI clock source */
elmot 1:d0dfbce63a89 173 IRDA_CLOCKSOURCE_SYSCLK = 0x04, /*!< SYSCLK clock source */
elmot 1:d0dfbce63a89 174 IRDA_CLOCKSOURCE_LSE = 0x08, /*!< LSE clock source */
elmot 1:d0dfbce63a89 175 IRDA_CLOCKSOURCE_UNDEFINED = 0x10 /*!< Undefined clock source */
elmot 1:d0dfbce63a89 176 }IRDA_ClockSourceTypeDef;
elmot 1:d0dfbce63a89 177
elmot 1:d0dfbce63a89 178 /**
elmot 1:d0dfbce63a89 179 * @brief IRDA handle Structure definition
elmot 1:d0dfbce63a89 180 */
elmot 1:d0dfbce63a89 181 typedef struct
elmot 1:d0dfbce63a89 182 {
elmot 1:d0dfbce63a89 183 USART_TypeDef *Instance; /*!< USART registers base address */
elmot 1:d0dfbce63a89 184
elmot 1:d0dfbce63a89 185 IRDA_InitTypeDef Init; /*!< IRDA communication parameters */
elmot 1:d0dfbce63a89 186
elmot 1:d0dfbce63a89 187 uint8_t *pTxBuffPtr; /*!< Pointer to IRDA Tx transfer Buffer */
elmot 1:d0dfbce63a89 188
elmot 1:d0dfbce63a89 189 uint16_t TxXferSize; /*!< IRDA Tx Transfer size */
elmot 1:d0dfbce63a89 190
elmot 1:d0dfbce63a89 191 uint16_t TxXferCount; /* !<IRDA Tx Transfer Counter */
elmot 1:d0dfbce63a89 192
elmot 1:d0dfbce63a89 193 uint8_t *pRxBuffPtr; /*!< Pointer to IRDA Rx transfer Buffer */
elmot 1:d0dfbce63a89 194
elmot 1:d0dfbce63a89 195 uint16_t RxXferSize; /*!< IRDA Rx Transfer size */
elmot 1:d0dfbce63a89 196
elmot 1:d0dfbce63a89 197 uint16_t RxXferCount; /*!< IRDA Rx Transfer Counter */
elmot 1:d0dfbce63a89 198
elmot 1:d0dfbce63a89 199 uint16_t Mask; /*!< USART RX RDR register mask */
elmot 1:d0dfbce63a89 200
elmot 1:d0dfbce63a89 201 DMA_HandleTypeDef *hdmatx; /*!< IRDA Tx DMA Handle parameters */
elmot 1:d0dfbce63a89 202
elmot 1:d0dfbce63a89 203 DMA_HandleTypeDef *hdmarx; /*!< IRDA Rx DMA Handle parameters */
elmot 1:d0dfbce63a89 204
elmot 1:d0dfbce63a89 205 HAL_LockTypeDef Lock; /*!< Locking object */
elmot 1:d0dfbce63a89 206
elmot 1:d0dfbce63a89 207 __IO HAL_IRDA_StateTypeDef gState; /*!< IRDA state information related to global Handle management
elmot 1:d0dfbce63a89 208 and also related to Tx operations.
elmot 1:d0dfbce63a89 209 This parameter can be a value of @ref HAL_IRDA_StateTypeDef */
elmot 1:d0dfbce63a89 210
elmot 1:d0dfbce63a89 211 __IO HAL_IRDA_StateTypeDef RxState; /*!< IRDA state information related to Rx operations.
elmot 1:d0dfbce63a89 212 This parameter can be a value of @ref HAL_IRDA_StateTypeDef */
elmot 1:d0dfbce63a89 213
elmot 1:d0dfbce63a89 214 uint32_t ErrorCode; /*!< IRDA Error code */
elmot 1:d0dfbce63a89 215
elmot 1:d0dfbce63a89 216 }IRDA_HandleTypeDef;
elmot 1:d0dfbce63a89 217
elmot 1:d0dfbce63a89 218 /**
elmot 1:d0dfbce63a89 219 * @brief IRDA Configuration enumeration values definition
elmot 1:d0dfbce63a89 220 */
elmot 1:d0dfbce63a89 221 typedef enum
elmot 1:d0dfbce63a89 222 {
elmot 1:d0dfbce63a89 223 IRDA_BAUDRATE = 0x00, /*!< IRDA Baud rate */
elmot 1:d0dfbce63a89 224 IRDA_PARITY = 0x01, /*!< IRDA frame parity */
elmot 1:d0dfbce63a89 225 IRDA_WORDLENGTH = 0x02, /*!< IRDA frame length */
elmot 1:d0dfbce63a89 226 IRDA_MODE = 0x03, /*!< IRDA communication mode */
elmot 1:d0dfbce63a89 227 IRDA_PRESCALER = 0x04, /*!< IRDA prescaling */
elmot 1:d0dfbce63a89 228 IRDA_POWERMODE = 0x05 /*!< IRDA power mode */
elmot 1:d0dfbce63a89 229 }IRDA_ControlTypeDef;
elmot 1:d0dfbce63a89 230
elmot 1:d0dfbce63a89 231 /**
elmot 1:d0dfbce63a89 232 * @}
elmot 1:d0dfbce63a89 233 */
elmot 1:d0dfbce63a89 234
elmot 1:d0dfbce63a89 235 /* Exported constants --------------------------------------------------------*/
elmot 1:d0dfbce63a89 236 /** @defgroup IRDA_Exported_Constants IRDA Exported Constants
elmot 1:d0dfbce63a89 237 * @{
elmot 1:d0dfbce63a89 238 */
elmot 1:d0dfbce63a89 239
elmot 1:d0dfbce63a89 240 /** @defgroup IRDA_Word_Length IRDA Word Length
elmot 1:d0dfbce63a89 241 * @{
elmot 1:d0dfbce63a89 242 */
elmot 1:d0dfbce63a89 243 #define IRDA_WORDLENGTH_7B ((uint32_t)USART_CR1_M1) /*!< 7-bit long frame */
elmot 1:d0dfbce63a89 244 #define IRDA_WORDLENGTH_8B ((uint32_t)0x00000000) /*!< 8-bit long frame */
elmot 1:d0dfbce63a89 245 #define IRDA_WORDLENGTH_9B ((uint32_t)USART_CR1_M0) /*!< 9-bit long frame */
elmot 1:d0dfbce63a89 246 /**
elmot 1:d0dfbce63a89 247 * @}
elmot 1:d0dfbce63a89 248 */
elmot 1:d0dfbce63a89 249
elmot 1:d0dfbce63a89 250 /** @defgroup IRDA_Parity IRDA Parity
elmot 1:d0dfbce63a89 251 * @{
elmot 1:d0dfbce63a89 252 */
elmot 1:d0dfbce63a89 253 #define IRDA_PARITY_NONE ((uint32_t)0x00000000) /*!< No parity */
elmot 1:d0dfbce63a89 254 #define IRDA_PARITY_EVEN ((uint32_t)USART_CR1_PCE) /*!< Even parity */
elmot 1:d0dfbce63a89 255 #define IRDA_PARITY_ODD ((uint32_t)(USART_CR1_PCE | USART_CR1_PS)) /*!< Odd parity */
elmot 1:d0dfbce63a89 256 /**
elmot 1:d0dfbce63a89 257 * @}
elmot 1:d0dfbce63a89 258 */
elmot 1:d0dfbce63a89 259
elmot 1:d0dfbce63a89 260 /** @defgroup IRDA_Transfer_Mode IRDA Transfer Mode
elmot 1:d0dfbce63a89 261 * @{
elmot 1:d0dfbce63a89 262 */
elmot 1:d0dfbce63a89 263 #define IRDA_MODE_RX ((uint32_t)USART_CR1_RE) /*!< RX mode */
elmot 1:d0dfbce63a89 264 #define IRDA_MODE_TX ((uint32_t)USART_CR1_TE) /*!< TX mode */
elmot 1:d0dfbce63a89 265 #define IRDA_MODE_TX_RX ((uint32_t)(USART_CR1_TE |USART_CR1_RE)) /*!< RX and TX mode */
elmot 1:d0dfbce63a89 266 /**
elmot 1:d0dfbce63a89 267 * @}
elmot 1:d0dfbce63a89 268 */
elmot 1:d0dfbce63a89 269
elmot 1:d0dfbce63a89 270 /** @defgroup IRDA_Low_Power IRDA Low Power
elmot 1:d0dfbce63a89 271 * @{
elmot 1:d0dfbce63a89 272 */
elmot 1:d0dfbce63a89 273 #define IRDA_POWERMODE_NORMAL ((uint32_t)0x00000000) /*!< IRDA normal power mode */
elmot 1:d0dfbce63a89 274 #define IRDA_POWERMODE_LOWPOWER ((uint32_t)USART_CR3_IRLP) /*!< IRDA low power mode */
elmot 1:d0dfbce63a89 275 /**
elmot 1:d0dfbce63a89 276 * @}
elmot 1:d0dfbce63a89 277 */
elmot 1:d0dfbce63a89 278
elmot 1:d0dfbce63a89 279 /** @defgroup IRDA_State IRDA State
elmot 1:d0dfbce63a89 280 * @{
elmot 1:d0dfbce63a89 281 */
elmot 1:d0dfbce63a89 282 #define IRDA_STATE_DISABLE ((uint32_t)0x00000000) /*!< IRDA disabled */
elmot 1:d0dfbce63a89 283 #define IRDA_STATE_ENABLE ((uint32_t)USART_CR1_UE) /*!< IRDA enabled */
elmot 1:d0dfbce63a89 284 /**
elmot 1:d0dfbce63a89 285 * @}
elmot 1:d0dfbce63a89 286 */
elmot 1:d0dfbce63a89 287
elmot 1:d0dfbce63a89 288 /** @defgroup IRDA_Mode IRDA Mode
elmot 1:d0dfbce63a89 289 * @{
elmot 1:d0dfbce63a89 290 */
elmot 1:d0dfbce63a89 291 #define IRDA_MODE_DISABLE ((uint32_t)0x00000000) /*!< Associated UART disabled in IRDA mode */
elmot 1:d0dfbce63a89 292 #define IRDA_MODE_ENABLE ((uint32_t)USART_CR3_IREN) /*!< Associated UART enabled in IRDA mode */
elmot 1:d0dfbce63a89 293 /**
elmot 1:d0dfbce63a89 294 * @}
elmot 1:d0dfbce63a89 295 */
elmot 1:d0dfbce63a89 296
elmot 1:d0dfbce63a89 297 /** @defgroup IRDA_One_Bit IRDA One Bit Sampling
elmot 1:d0dfbce63a89 298 * @{
elmot 1:d0dfbce63a89 299 */
elmot 1:d0dfbce63a89 300 #define IRDA_ONE_BIT_SAMPLE_DISABLE ((uint32_t)0x00000000) /*!< One-bit sampling disabled */
elmot 1:d0dfbce63a89 301 #define IRDA_ONE_BIT_SAMPLE_ENABLE ((uint32_t)USART_CR3_ONEBIT) /*!< One-bit sampling enabled */
elmot 1:d0dfbce63a89 302 /**
elmot 1:d0dfbce63a89 303 * @}
elmot 1:d0dfbce63a89 304 */
elmot 1:d0dfbce63a89 305
elmot 1:d0dfbce63a89 306 /** @defgroup IRDA_DMA_Tx IRDA DMA Tx
elmot 1:d0dfbce63a89 307 * @{
elmot 1:d0dfbce63a89 308 */
elmot 1:d0dfbce63a89 309 #define IRDA_DMA_TX_DISABLE ((uint32_t)0x00000000) /*!< IRDA DMA TX disabled */
elmot 1:d0dfbce63a89 310 #define IRDA_DMA_TX_ENABLE ((uint32_t)USART_CR3_DMAT) /*!< IRDA DMA TX enabled */
elmot 1:d0dfbce63a89 311 /**
elmot 1:d0dfbce63a89 312 * @}
elmot 1:d0dfbce63a89 313 */
elmot 1:d0dfbce63a89 314
elmot 1:d0dfbce63a89 315 /** @defgroup IRDA_DMA_Rx IRDA DMA Rx
elmot 1:d0dfbce63a89 316 * @{
elmot 1:d0dfbce63a89 317 */
elmot 1:d0dfbce63a89 318 #define IRDA_DMA_RX_DISABLE ((uint32_t)0x00000000) /*!< IRDA DMA RX disabled */
elmot 1:d0dfbce63a89 319 #define IRDA_DMA_RX_ENABLE ((uint32_t)USART_CR3_DMAR) /*!< IRDA DMA RX enabled */
elmot 1:d0dfbce63a89 320 /**
elmot 1:d0dfbce63a89 321 * @}
elmot 1:d0dfbce63a89 322 */
elmot 1:d0dfbce63a89 323
elmot 1:d0dfbce63a89 324 /** @defgroup IRDA_Request_Parameters IRDA Request Parameters
elmot 1:d0dfbce63a89 325 * @{
elmot 1:d0dfbce63a89 326 */
elmot 1:d0dfbce63a89 327 #define IRDA_AUTOBAUD_REQUEST ((uint16_t)USART_RQR_ABRRQ) /*!< Auto-Baud Rate Request */
elmot 1:d0dfbce63a89 328 #define IRDA_RXDATA_FLUSH_REQUEST ((uint16_t)USART_RQR_RXFRQ) /*!< Receive Data flush Request */
elmot 1:d0dfbce63a89 329 #define IRDA_TXDATA_FLUSH_REQUEST ((uint16_t)USART_RQR_TXFRQ) /*!< Transmit data flush Request */
elmot 1:d0dfbce63a89 330 /**
elmot 1:d0dfbce63a89 331 * @}
elmot 1:d0dfbce63a89 332 */
elmot 1:d0dfbce63a89 333
elmot 1:d0dfbce63a89 334 /** @defgroup IRDA_Flags IRDA Flags
elmot 1:d0dfbce63a89 335 * Elements values convention: 0xXXXX
elmot 1:d0dfbce63a89 336 * - 0xXXXX : Flag mask in the ISR register
elmot 1:d0dfbce63a89 337 * @{
elmot 1:d0dfbce63a89 338 */
elmot 1:d0dfbce63a89 339 #define IRDA_FLAG_REACK ((uint32_t)0x00400000) /*!< IRDA Receive enable acknowledge flag */
elmot 1:d0dfbce63a89 340 #define IRDA_FLAG_TEACK ((uint32_t)0x00200000) /*!< IRDA Transmit enable acknowledge flag */
elmot 1:d0dfbce63a89 341 #define IRDA_FLAG_BUSY ((uint32_t)0x00010000) /*!< IRDA Busy flag */
elmot 1:d0dfbce63a89 342 #define IRDA_FLAG_ABRF ((uint32_t)0x00008000) /*!< IRDA Auto baud rate flag */
elmot 1:d0dfbce63a89 343 #define IRDA_FLAG_ABRE ((uint32_t)0x00004000) /*!< IRDA Auto baud rate error */
elmot 1:d0dfbce63a89 344 #define IRDA_FLAG_TXE ((uint32_t)0x00000080) /*!< IRDA Transmit data register empty */
elmot 1:d0dfbce63a89 345 #define IRDA_FLAG_TC ((uint32_t)0x00000040) /*!< IRDA Transmission complete */
elmot 1:d0dfbce63a89 346 #define IRDA_FLAG_RXNE ((uint32_t)0x00000020) /*!< IRDA Read data register not empty */
elmot 1:d0dfbce63a89 347 #define IRDA_FLAG_ORE ((uint32_t)0x00000008) /*!< IRDA Overrun error */
elmot 1:d0dfbce63a89 348 #define IRDA_FLAG_NE ((uint32_t)0x00000004) /*!< IRDA Noise error */
elmot 1:d0dfbce63a89 349 #define IRDA_FLAG_FE ((uint32_t)0x00000002) /*!< IRDA Noise error */
elmot 1:d0dfbce63a89 350 #define IRDA_FLAG_PE ((uint32_t)0x00000001) /*!< IRDA Parity error */
elmot 1:d0dfbce63a89 351 /**
elmot 1:d0dfbce63a89 352 * @}
elmot 1:d0dfbce63a89 353 */
elmot 1:d0dfbce63a89 354
elmot 1:d0dfbce63a89 355 /** @defgroup IRDA_Interrupt_definition IRDA Interrupts Definition
elmot 1:d0dfbce63a89 356 * Elements values convention: 0000ZZZZ0XXYYYYYb
elmot 1:d0dfbce63a89 357 * - YYYYY : Interrupt source position in the XX register (5bits)
elmot 1:d0dfbce63a89 358 * - XX : Interrupt source register (2bits)
elmot 1:d0dfbce63a89 359 * - 01: CR1 register
elmot 1:d0dfbce63a89 360 * - 10: CR2 register
elmot 1:d0dfbce63a89 361 * - 11: CR3 register
elmot 1:d0dfbce63a89 362 * - ZZZZ : Flag position in the ISR register(4bits)
elmot 1:d0dfbce63a89 363 * @{
elmot 1:d0dfbce63a89 364 */
elmot 1:d0dfbce63a89 365 #define IRDA_IT_PE ((uint16_t)0x0028) /*!< IRDA Parity error interruption */
elmot 1:d0dfbce63a89 366 #define IRDA_IT_TXE ((uint16_t)0x0727) /*!< IRDA Transmit data register empty interruption */
elmot 1:d0dfbce63a89 367 #define IRDA_IT_TC ((uint16_t)0x0626) /*!< IRDA Transmission complete interruption */
elmot 1:d0dfbce63a89 368 #define IRDA_IT_RXNE ((uint16_t)0x0525) /*!< IRDA Read data register not empty interruption */
elmot 1:d0dfbce63a89 369 #define IRDA_IT_IDLE ((uint16_t)0x0424) /*!< IRDA Idle interruption */
elmot 1:d0dfbce63a89 370
elmot 1:d0dfbce63a89 371 /* Elements values convention: 000000000XXYYYYYb
elmot 1:d0dfbce63a89 372 - YYYYY : Interrupt source position in the XX register (5bits)
elmot 1:d0dfbce63a89 373 - XX : Interrupt source register (2bits)
elmot 1:d0dfbce63a89 374 - 01: CR1 register
elmot 1:d0dfbce63a89 375 - 10: CR2 register
elmot 1:d0dfbce63a89 376 - 11: CR3 register */
elmot 1:d0dfbce63a89 377 #define IRDA_IT_ERR ((uint16_t)0x0060) /*!< IRDA Error interruption */
elmot 1:d0dfbce63a89 378
elmot 1:d0dfbce63a89 379 /* Elements values convention: 0000ZZZZ00000000b
elmot 1:d0dfbce63a89 380 - ZZZZ : Flag position in the ISR register(4bits) */
elmot 1:d0dfbce63a89 381 #define IRDA_IT_ORE ((uint16_t)0x0300) /*!< IRDA Overrun error interruption */
elmot 1:d0dfbce63a89 382 #define IRDA_IT_NE ((uint16_t)0x0200) /*!< IRDA Noise error interruption */
elmot 1:d0dfbce63a89 383 #define IRDA_IT_FE ((uint16_t)0x0100) /*!< IRDA Frame error interruption */
elmot 1:d0dfbce63a89 384 /**
elmot 1:d0dfbce63a89 385 * @}
elmot 1:d0dfbce63a89 386 */
elmot 1:d0dfbce63a89 387
elmot 1:d0dfbce63a89 388 /** @defgroup IRDA_IT_CLEAR_Flags IRDA Interruption Clear Flags
elmot 1:d0dfbce63a89 389 * @{
elmot 1:d0dfbce63a89 390 */
elmot 1:d0dfbce63a89 391 #define IRDA_CLEAR_PEF USART_ICR_PECF /*!< Parity Error Clear Flag */
elmot 1:d0dfbce63a89 392 #define IRDA_CLEAR_FEF USART_ICR_FECF /*!< Framing Error Clear Flag */
elmot 1:d0dfbce63a89 393 #define IRDA_CLEAR_NEF USART_ICR_NCF /*!< Noise detected Clear Flag */
elmot 1:d0dfbce63a89 394 #define IRDA_CLEAR_OREF USART_ICR_ORECF /*!< OverRun Error Clear Flag */
elmot 1:d0dfbce63a89 395 #define IRDA_CLEAR_IDLEF USART_ICR_IDLECF /*!< IDLE line detected Clear Flag */
elmot 1:d0dfbce63a89 396 #define IRDA_CLEAR_TCF USART_ICR_TCCF /*!< Transmission Complete Clear Flag */
elmot 1:d0dfbce63a89 397 /**
elmot 1:d0dfbce63a89 398 * @}
elmot 1:d0dfbce63a89 399 */
elmot 1:d0dfbce63a89 400
elmot 1:d0dfbce63a89 401 /** @defgroup IRDA_Interruption_Mask IRDA interruptions flags mask
elmot 1:d0dfbce63a89 402 * @{
elmot 1:d0dfbce63a89 403 */
elmot 1:d0dfbce63a89 404 #define IRDA_IT_MASK ((uint16_t)0x001F) /*!< IRDA Interruptions flags mask */
elmot 1:d0dfbce63a89 405 /**
elmot 1:d0dfbce63a89 406 * @}
elmot 1:d0dfbce63a89 407 */
elmot 1:d0dfbce63a89 408
elmot 1:d0dfbce63a89 409 /**
elmot 1:d0dfbce63a89 410 * @}
elmot 1:d0dfbce63a89 411 */
elmot 1:d0dfbce63a89 412
elmot 1:d0dfbce63a89 413
elmot 1:d0dfbce63a89 414 /* Exported macros -----------------------------------------------------------*/
elmot 1:d0dfbce63a89 415 /** @defgroup IRDA_Exported_Macros IRDA Exported Macros
elmot 1:d0dfbce63a89 416 * @{
elmot 1:d0dfbce63a89 417 */
elmot 1:d0dfbce63a89 418
elmot 1:d0dfbce63a89 419 /** @brief Reset IRDA handle state.
elmot 1:d0dfbce63a89 420 * @param __HANDLE__: IRDA handle.
elmot 1:d0dfbce63a89 421 * @retval None
elmot 1:d0dfbce63a89 422 */
elmot 1:d0dfbce63a89 423 #define __HAL_IRDA_RESET_HANDLE_STATE(__HANDLE__) do{ \
elmot 1:d0dfbce63a89 424 (__HANDLE__)->gState = HAL_IRDA_STATE_RESET; \
elmot 1:d0dfbce63a89 425 (__HANDLE__)->RxState = HAL_IRDA_STATE_RESET; \
elmot 1:d0dfbce63a89 426 } while(0)
elmot 1:d0dfbce63a89 427
elmot 1:d0dfbce63a89 428 /** @brief Flush the IRDA DR register.
elmot 1:d0dfbce63a89 429 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 430 * @retval None
elmot 1:d0dfbce63a89 431 */
elmot 1:d0dfbce63a89 432 #define __HAL_IRDA_FLUSH_DRREGISTER(__HANDLE__) \
elmot 1:d0dfbce63a89 433 do{ \
elmot 1:d0dfbce63a89 434 SET_BIT((__HANDLE__)->Instance->RQR, IRDA_RXDATA_FLUSH_REQUEST); \
elmot 1:d0dfbce63a89 435 SET_BIT((__HANDLE__)->Instance->RQR, IRDA_TXDATA_FLUSH_REQUEST); \
elmot 1:d0dfbce63a89 436 } while(0)
elmot 1:d0dfbce63a89 437
elmot 1:d0dfbce63a89 438 /** @brief Clear the specified IRDA pending flag.
elmot 1:d0dfbce63a89 439 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 440 * @param __FLAG__: specifies the flag to check.
elmot 1:d0dfbce63a89 441 * This parameter can be any combination of the following values:
elmot 1:d0dfbce63a89 442 * @arg @ref IRDA_CLEAR_PEF
elmot 1:d0dfbce63a89 443 * @arg @ref IRDA_CLEAR_FEF
elmot 1:d0dfbce63a89 444 * @arg @ref IRDA_CLEAR_NEF
elmot 1:d0dfbce63a89 445 * @arg @ref IRDA_CLEAR_OREF
elmot 1:d0dfbce63a89 446 * @arg @ref IRDA_CLEAR_TCF
elmot 1:d0dfbce63a89 447 * @arg @ref IRDA_CLEAR_IDLEF
elmot 1:d0dfbce63a89 448 * @retval None
elmot 1:d0dfbce63a89 449 */
elmot 1:d0dfbce63a89 450 #define __HAL_IRDA_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__))
elmot 1:d0dfbce63a89 451
elmot 1:d0dfbce63a89 452 /** @brief Clear the IRDA PE pending flag.
elmot 1:d0dfbce63a89 453 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 454 * @retval None
elmot 1:d0dfbce63a89 455 */
elmot 1:d0dfbce63a89 456 #define __HAL_IRDA_CLEAR_PEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_PEF)
elmot 1:d0dfbce63a89 457
elmot 1:d0dfbce63a89 458
elmot 1:d0dfbce63a89 459 /** @brief Clear the IRDA FE pending flag.
elmot 1:d0dfbce63a89 460 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 461 * @retval None
elmot 1:d0dfbce63a89 462 */
elmot 1:d0dfbce63a89 463 #define __HAL_IRDA_CLEAR_FEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_FEF)
elmot 1:d0dfbce63a89 464
elmot 1:d0dfbce63a89 465 /** @brief Clear the IRDA NE pending flag.
elmot 1:d0dfbce63a89 466 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 467 * @retval None
elmot 1:d0dfbce63a89 468 */
elmot 1:d0dfbce63a89 469 #define __HAL_IRDA_CLEAR_NEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_NEF)
elmot 1:d0dfbce63a89 470
elmot 1:d0dfbce63a89 471 /** @brief Clear the IRDA ORE pending flag.
elmot 1:d0dfbce63a89 472 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 473 * @retval None
elmot 1:d0dfbce63a89 474 */
elmot 1:d0dfbce63a89 475 #define __HAL_IRDA_CLEAR_OREFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_OREF)
elmot 1:d0dfbce63a89 476
elmot 1:d0dfbce63a89 477 /** @brief Clear the IRDA IDLE pending flag.
elmot 1:d0dfbce63a89 478 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 479 * @retval None
elmot 1:d0dfbce63a89 480 */
elmot 1:d0dfbce63a89 481 #define __HAL_IRDA_CLEAR_IDLEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_IDLEF)
elmot 1:d0dfbce63a89 482
elmot 1:d0dfbce63a89 483 /** @brief Check whether the specified IRDA flag is set or not.
elmot 1:d0dfbce63a89 484 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 485 * @param __FLAG__: specifies the flag to check.
elmot 1:d0dfbce63a89 486 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 487 * @arg @ref IRDA_FLAG_REACK Receive enable acknowledge flag
elmot 1:d0dfbce63a89 488 * @arg @ref IRDA_FLAG_TEACK Transmit enable acknowledge flag
elmot 1:d0dfbce63a89 489 * @arg @ref IRDA_FLAG_BUSY Busy flag
elmot 1:d0dfbce63a89 490 * @arg @ref IRDA_FLAG_ABRF Auto Baud rate detection flag
elmot 1:d0dfbce63a89 491 * @arg @ref IRDA_FLAG_ABRE Auto Baud rate detection error flag
elmot 1:d0dfbce63a89 492 * @arg @ref IRDA_FLAG_TXE Transmit data register empty flag
elmot 1:d0dfbce63a89 493 * @arg @ref IRDA_FLAG_TC Transmission Complete flag
elmot 1:d0dfbce63a89 494 * @arg @ref IRDA_FLAG_RXNE Receive data register not empty flag
elmot 1:d0dfbce63a89 495 * @arg @ref IRDA_FLAG_ORE OverRun Error flag
elmot 1:d0dfbce63a89 496 * @arg @ref IRDA_FLAG_NE Noise Error flag
elmot 1:d0dfbce63a89 497 * @arg @ref IRDA_FLAG_FE Framing Error flag
elmot 1:d0dfbce63a89 498 * @arg @ref IRDA_FLAG_PE Parity Error flag
elmot 1:d0dfbce63a89 499 * @retval The new state of __FLAG__ (TRUE or FALSE).
elmot 1:d0dfbce63a89 500 */
elmot 1:d0dfbce63a89 501 #define __HAL_IRDA_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__))
elmot 1:d0dfbce63a89 502
elmot 1:d0dfbce63a89 503
elmot 1:d0dfbce63a89 504 /** @brief Enable the specified IRDA interrupt.
elmot 1:d0dfbce63a89 505 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 506 * @param __INTERRUPT__: specifies the IRDA interrupt source to enable.
elmot 1:d0dfbce63a89 507 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 508 * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt
elmot 1:d0dfbce63a89 509 * @arg @ref IRDA_IT_TC Transmission complete interrupt
elmot 1:d0dfbce63a89 510 * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt
elmot 1:d0dfbce63a89 511 * @arg @ref IRDA_IT_IDLE Idle line detection interrupt
elmot 1:d0dfbce63a89 512 * @arg @ref IRDA_IT_PE Parity Error interrupt
elmot 1:d0dfbce63a89 513 * @arg @ref IRDA_IT_ERR Error interrupt(Frame error, noise error, overrun error)
elmot 1:d0dfbce63a89 514 * @retval None
elmot 1:d0dfbce63a89 515 */
elmot 1:d0dfbce63a89 516 #define __HAL_IRDA_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((((uint8_t)(__INTERRUPT__)) >> 5U) == 1)? ((__HANDLE__)->Instance->CR1 |= (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
elmot 1:d0dfbce63a89 517 ((((uint8_t)(__INTERRUPT__)) >> 5U) == 2)? ((__HANDLE__)->Instance->CR2 |= (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
elmot 1:d0dfbce63a89 518 ((__HANDLE__)->Instance->CR3 |= (1U << ((__INTERRUPT__) & IRDA_IT_MASK))))
elmot 1:d0dfbce63a89 519
elmot 1:d0dfbce63a89 520 /** @brief Disable the specified IRDA interrupt.
elmot 1:d0dfbce63a89 521 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 522 * @param __INTERRUPT__: specifies the IRDA interrupt source to disable.
elmot 1:d0dfbce63a89 523 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 524 * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt
elmot 1:d0dfbce63a89 525 * @arg @ref IRDA_IT_TC Transmission complete interrupt
elmot 1:d0dfbce63a89 526 * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt
elmot 1:d0dfbce63a89 527 * @arg @ref IRDA_IT_IDLE Idle line detection interrupt
elmot 1:d0dfbce63a89 528 * @arg @ref IRDA_IT_PE Parity Error interrupt
elmot 1:d0dfbce63a89 529 * @arg @ref IRDA_IT_ERR Error interrupt(Frame error, noise error, overrun error)
elmot 1:d0dfbce63a89 530 * @retval None
elmot 1:d0dfbce63a89 531 */
elmot 1:d0dfbce63a89 532 #define __HAL_IRDA_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((((uint8_t)(__INTERRUPT__)) >> 5U) == 1)? ((__HANDLE__)->Instance->CR1 &= ~ (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
elmot 1:d0dfbce63a89 533 ((((uint8_t)(__INTERRUPT__)) >> 5U) == 2)? ((__HANDLE__)->Instance->CR2 &= ~ (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
elmot 1:d0dfbce63a89 534 ((__HANDLE__)->Instance->CR3 &= ~ (1U << ((__INTERRUPT__) & IRDA_IT_MASK))))
elmot 1:d0dfbce63a89 535
elmot 1:d0dfbce63a89 536
elmot 1:d0dfbce63a89 537 /** @brief Check whether the specified IRDA interrupt has occurred or not.
elmot 1:d0dfbce63a89 538 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 539 * @param __IT__: specifies the IRDA interrupt source to check.
elmot 1:d0dfbce63a89 540 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 541 * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt
elmot 1:d0dfbce63a89 542 * @arg @ref IRDA_IT_TC Transmission complete interrupt
elmot 1:d0dfbce63a89 543 * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt
elmot 1:d0dfbce63a89 544 * @arg @ref IRDA_IT_IDLE Idle line detection interrupt
elmot 1:d0dfbce63a89 545 * @arg @ref IRDA_IT_ORE OverRun Error interrupt
elmot 1:d0dfbce63a89 546 * @arg @ref IRDA_IT_NE Noise Error interrupt
elmot 1:d0dfbce63a89 547 * @arg @ref IRDA_IT_FE Framing Error interrupt
elmot 1:d0dfbce63a89 548 * @arg @ref IRDA_IT_PE Parity Error interrupt
elmot 1:d0dfbce63a89 549 * @retval The new state of __IT__ (TRUE or FALSE).
elmot 1:d0dfbce63a89 550 */
elmot 1:d0dfbce63a89 551 #define __HAL_IRDA_GET_IT(__HANDLE__, __IT__) ((__HANDLE__)->Instance->ISR & ((uint32_t)1U << ((__IT__)>> 0x08)))
elmot 1:d0dfbce63a89 552
elmot 1:d0dfbce63a89 553 /** @brief Check whether the specified IRDA interrupt source is enabled or not.
elmot 1:d0dfbce63a89 554 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 555 * @param __IT__: specifies the IRDA interrupt source to check.
elmot 1:d0dfbce63a89 556 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 557 * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt
elmot 1:d0dfbce63a89 558 * @arg @ref IRDA_IT_TC Transmission complete interrupt
elmot 1:d0dfbce63a89 559 * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt
elmot 1:d0dfbce63a89 560 * @arg @ref IRDA_IT_IDLE Idle line detection interrupt
elmot 1:d0dfbce63a89 561 * @arg @ref IRDA_IT_ERR Framing, overrun or noise error interrupt
elmot 1:d0dfbce63a89 562 * @arg @ref IRDA_IT_PE Parity Error interrupt
elmot 1:d0dfbce63a89 563 * @retval The new state of __IT__ (TRUE or FALSE).
elmot 1:d0dfbce63a89 564 */
elmot 1:d0dfbce63a89 565 #define __HAL_IRDA_GET_IT_SOURCE(__HANDLE__, __IT__) ((((((uint8_t)(__IT__)) >> 5U) == 1)? (__HANDLE__)->Instance->CR1:(((((uint8_t)(__IT__)) >> 5U) == 2)? \
elmot 1:d0dfbce63a89 566 (__HANDLE__)->Instance->CR2 : (__HANDLE__)->Instance->CR3)) & ((uint32_t)1 << (((uint16_t)(__IT__)) & IRDA_IT_MASK)))
elmot 1:d0dfbce63a89 567
elmot 1:d0dfbce63a89 568
elmot 1:d0dfbce63a89 569 /** @brief Clear the specified IRDA ISR flag, in setting the proper ICR register flag.
elmot 1:d0dfbce63a89 570 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 571 * @param __IT_CLEAR__: specifies the interrupt clear register flag that needs to be set
elmot 1:d0dfbce63a89 572 * to clear the corresponding interrupt
elmot 1:d0dfbce63a89 573 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 574 * @arg @ref IRDA_CLEAR_PEF Parity Error Clear Flag
elmot 1:d0dfbce63a89 575 * @arg @ref IRDA_CLEAR_FEF Framing Error Clear Flag
elmot 1:d0dfbce63a89 576 * @arg @ref IRDA_CLEAR_NEF Noise detected Clear Flag
elmot 1:d0dfbce63a89 577 * @arg @ref IRDA_CLEAR_OREF OverRun Error Clear Flag
elmot 1:d0dfbce63a89 578 * @arg @ref IRDA_CLEAR_TCF Transmission Complete Clear Flag
elmot 1:d0dfbce63a89 579 * @retval None
elmot 1:d0dfbce63a89 580 */
elmot 1:d0dfbce63a89 581 #define __HAL_IRDA_CLEAR_IT(__HANDLE__, __IT_CLEAR__) ((__HANDLE__)->Instance->ICR = (uint32_t)(__IT_CLEAR__))
elmot 1:d0dfbce63a89 582
elmot 1:d0dfbce63a89 583
elmot 1:d0dfbce63a89 584 /** @brief Set a specific IRDA request flag.
elmot 1:d0dfbce63a89 585 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 586 * @param __REQ__: specifies the request flag to set
elmot 1:d0dfbce63a89 587 * This parameter can be one of the following values:
elmot 1:d0dfbce63a89 588 * @arg @ref IRDA_AUTOBAUD_REQUEST Auto-Baud Rate Request
elmot 1:d0dfbce63a89 589 * @arg @ref IRDA_RXDATA_FLUSH_REQUEST Receive Data flush Request
elmot 1:d0dfbce63a89 590 * @arg @ref IRDA_TXDATA_FLUSH_REQUEST Transmit data flush Request
elmot 1:d0dfbce63a89 591 *
elmot 1:d0dfbce63a89 592 * @retval None
elmot 1:d0dfbce63a89 593 */
elmot 1:d0dfbce63a89 594 #define __HAL_IRDA_SEND_REQ(__HANDLE__, __REQ__) ((__HANDLE__)->Instance->RQR |= (uint16_t)(__REQ__))
elmot 1:d0dfbce63a89 595
elmot 1:d0dfbce63a89 596 /** @brief Enable the IRDA one bit sample method.
elmot 1:d0dfbce63a89 597 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 598 * @retval None
elmot 1:d0dfbce63a89 599 */
elmot 1:d0dfbce63a89 600 #define __HAL_IRDA_ONE_BIT_SAMPLE_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3|= USART_CR3_ONEBIT)
elmot 1:d0dfbce63a89 601
elmot 1:d0dfbce63a89 602 /** @brief Disable the IRDA one bit sample method.
elmot 1:d0dfbce63a89 603 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 604 * @retval None
elmot 1:d0dfbce63a89 605 */
elmot 1:d0dfbce63a89 606 #define __HAL_IRDA_ONE_BIT_SAMPLE_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3 &= (uint32_t)~((uint32_t)USART_CR3_ONEBIT))
elmot 1:d0dfbce63a89 607
elmot 1:d0dfbce63a89 608 /** @brief Enable UART/USART associated to IRDA Handle.
elmot 1:d0dfbce63a89 609 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 610 * @retval None
elmot 1:d0dfbce63a89 611 */
elmot 1:d0dfbce63a89 612 #define __HAL_IRDA_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= USART_CR1_UE)
elmot 1:d0dfbce63a89 613
elmot 1:d0dfbce63a89 614 /** @brief Disable UART/USART associated to IRDA Handle.
elmot 1:d0dfbce63a89 615 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 616 * @retval None
elmot 1:d0dfbce63a89 617 */
elmot 1:d0dfbce63a89 618 #define __HAL_IRDA_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~USART_CR1_UE)
elmot 1:d0dfbce63a89 619
elmot 1:d0dfbce63a89 620 /**
elmot 1:d0dfbce63a89 621 * @}
elmot 1:d0dfbce63a89 622 */
elmot 1:d0dfbce63a89 623
elmot 1:d0dfbce63a89 624 /* Private macros --------------------------------------------------------*/
elmot 1:d0dfbce63a89 625 /** @defgroup IRDA_Private_Macros IRDA Private Macros
elmot 1:d0dfbce63a89 626 * @{
elmot 1:d0dfbce63a89 627 */
elmot 1:d0dfbce63a89 628
elmot 1:d0dfbce63a89 629 /** @brief Compute the mask to apply to retrieve the received data
elmot 1:d0dfbce63a89 630 * according to the word length and to the parity bits activation.
elmot 1:d0dfbce63a89 631 * @param __HANDLE__: specifies the IRDA Handle.
elmot 1:d0dfbce63a89 632 * @retval None, the mask to apply to the associated UART RDR register is stored in (__HANDLE__)->Mask field.
elmot 1:d0dfbce63a89 633 */
elmot 1:d0dfbce63a89 634 #define IRDA_MASK_COMPUTATION(__HANDLE__) \
elmot 1:d0dfbce63a89 635 do { \
elmot 1:d0dfbce63a89 636 if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_9B) \
elmot 1:d0dfbce63a89 637 { \
elmot 1:d0dfbce63a89 638 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
elmot 1:d0dfbce63a89 639 { \
elmot 1:d0dfbce63a89 640 (__HANDLE__)->Mask = 0x01FF ; \
elmot 1:d0dfbce63a89 641 } \
elmot 1:d0dfbce63a89 642 else \
elmot 1:d0dfbce63a89 643 { \
elmot 1:d0dfbce63a89 644 (__HANDLE__)->Mask = 0x00FF ; \
elmot 1:d0dfbce63a89 645 } \
elmot 1:d0dfbce63a89 646 } \
elmot 1:d0dfbce63a89 647 else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_8B) \
elmot 1:d0dfbce63a89 648 { \
elmot 1:d0dfbce63a89 649 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
elmot 1:d0dfbce63a89 650 { \
elmot 1:d0dfbce63a89 651 (__HANDLE__)->Mask = 0x00FF ; \
elmot 1:d0dfbce63a89 652 } \
elmot 1:d0dfbce63a89 653 else \
elmot 1:d0dfbce63a89 654 { \
elmot 1:d0dfbce63a89 655 (__HANDLE__)->Mask = 0x007F ; \
elmot 1:d0dfbce63a89 656 } \
elmot 1:d0dfbce63a89 657 } \
elmot 1:d0dfbce63a89 658 else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_7B) \
elmot 1:d0dfbce63a89 659 { \
elmot 1:d0dfbce63a89 660 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
elmot 1:d0dfbce63a89 661 { \
elmot 1:d0dfbce63a89 662 (__HANDLE__)->Mask = 0x007F ; \
elmot 1:d0dfbce63a89 663 } \
elmot 1:d0dfbce63a89 664 else \
elmot 1:d0dfbce63a89 665 { \
elmot 1:d0dfbce63a89 666 (__HANDLE__)->Mask = 0x003F ; \
elmot 1:d0dfbce63a89 667 } \
elmot 1:d0dfbce63a89 668 } \
elmot 1:d0dfbce63a89 669 } while(0)
elmot 1:d0dfbce63a89 670
elmot 1:d0dfbce63a89 671 /** @brief Ensure that IRDA Baud rate is less or equal to maximum value.
elmot 1:d0dfbce63a89 672 * @param __BAUDRATE__: specifies the IRDA Baudrate set by the user.
elmot 1:d0dfbce63a89 673 * @retval True or False
elmot 1:d0dfbce63a89 674 */
elmot 1:d0dfbce63a89 675 #define IS_IRDA_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) < 115201)
elmot 1:d0dfbce63a89 676
elmot 1:d0dfbce63a89 677 /** @brief Ensure that IRDA prescaler value is strictly larger than 0.
elmot 1:d0dfbce63a89 678 * @param __PRESCALER__: specifies the IRDA prescaler value set by the user.
elmot 1:d0dfbce63a89 679 * @retval True or False
elmot 1:d0dfbce63a89 680 */
elmot 1:d0dfbce63a89 681 #define IS_IRDA_PRESCALER(__PRESCALER__) ((__PRESCALER__) > 0)
elmot 1:d0dfbce63a89 682
elmot 1:d0dfbce63a89 683 /**
elmot 1:d0dfbce63a89 684 * @brief Ensure that IRDA frame length is valid.
elmot 1:d0dfbce63a89 685 * @param __LENGTH__: IRDA frame length.
elmot 1:d0dfbce63a89 686 * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid)
elmot 1:d0dfbce63a89 687 */
elmot 1:d0dfbce63a89 688 #define IS_IRDA_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == IRDA_WORDLENGTH_7B) || \
elmot 1:d0dfbce63a89 689 ((__LENGTH__) == IRDA_WORDLENGTH_8B) || \
elmot 1:d0dfbce63a89 690 ((__LENGTH__) == IRDA_WORDLENGTH_9B))
elmot 1:d0dfbce63a89 691
elmot 1:d0dfbce63a89 692 /**
elmot 1:d0dfbce63a89 693 * @brief Ensure that IRDA frame parity is valid.
elmot 1:d0dfbce63a89 694 * @param __PARITY__: IRDA frame parity.
elmot 1:d0dfbce63a89 695 * @retval SET (__PARITY__ is valid) or RESET (__PARITY__ is invalid)
elmot 1:d0dfbce63a89 696 */
elmot 1:d0dfbce63a89 697 #define IS_IRDA_PARITY(__PARITY__) (((__PARITY__) == IRDA_PARITY_NONE) || \
elmot 1:d0dfbce63a89 698 ((__PARITY__) == IRDA_PARITY_EVEN) || \
elmot 1:d0dfbce63a89 699 ((__PARITY__) == IRDA_PARITY_ODD))
elmot 1:d0dfbce63a89 700
elmot 1:d0dfbce63a89 701 /**
elmot 1:d0dfbce63a89 702 * @brief Ensure that IRDA communication mode is valid.
elmot 1:d0dfbce63a89 703 * @param __MODE__: IRDA communication mode.
elmot 1:d0dfbce63a89 704 * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
elmot 1:d0dfbce63a89 705 */
elmot 1:d0dfbce63a89 706 #define IS_IRDA_TX_RX_MODE(__MODE__) ((((__MODE__) & (~((uint32_t)(IRDA_MODE_TX_RX)))) == (uint32_t)0x00) && ((__MODE__) != (uint32_t)0x00))
elmot 1:d0dfbce63a89 707
elmot 1:d0dfbce63a89 708 /**
elmot 1:d0dfbce63a89 709 * @brief Ensure that IRDA power mode is valid.
elmot 1:d0dfbce63a89 710 * @param __MODE__: IRDA power mode.
elmot 1:d0dfbce63a89 711 * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
elmot 1:d0dfbce63a89 712 */
elmot 1:d0dfbce63a89 713 #define IS_IRDA_POWERMODE(__MODE__) (((__MODE__) == IRDA_POWERMODE_LOWPOWER) || \
elmot 1:d0dfbce63a89 714 ((__MODE__) == IRDA_POWERMODE_NORMAL))
elmot 1:d0dfbce63a89 715
elmot 1:d0dfbce63a89 716 /**
elmot 1:d0dfbce63a89 717 * @brief Ensure that IRDA state is valid.
elmot 1:d0dfbce63a89 718 * @param __STATE__: IRDA state mode.
elmot 1:d0dfbce63a89 719 * @retval SET (__STATE__ is valid) or RESET (__STATE__ is invalid)
elmot 1:d0dfbce63a89 720 */
elmot 1:d0dfbce63a89 721 #define IS_IRDA_STATE(__STATE__) (((__STATE__) == IRDA_STATE_DISABLE) || \
elmot 1:d0dfbce63a89 722 ((__STATE__) == IRDA_STATE_ENABLE))
elmot 1:d0dfbce63a89 723
elmot 1:d0dfbce63a89 724 /**
elmot 1:d0dfbce63a89 725 * @brief Ensure that IRDA associated UART/USART mode is valid.
elmot 1:d0dfbce63a89 726 * @param __MODE__: IRDA associated UART/USART mode.
elmot 1:d0dfbce63a89 727 * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
elmot 1:d0dfbce63a89 728 */
elmot 1:d0dfbce63a89 729 #define IS_IRDA_MODE(__MODE__) (((__MODE__) == IRDA_MODE_DISABLE) || \
elmot 1:d0dfbce63a89 730 ((__MODE__) == IRDA_MODE_ENABLE))
elmot 1:d0dfbce63a89 731
elmot 1:d0dfbce63a89 732 /**
elmot 1:d0dfbce63a89 733 * @brief Ensure that IRDA sampling rate is valid.
elmot 1:d0dfbce63a89 734 * @param __ONEBIT__: IRDA sampling rate.
elmot 1:d0dfbce63a89 735 * @retval SET (__ONEBIT__ is valid) or RESET (__ONEBIT__ is invalid)
elmot 1:d0dfbce63a89 736 */
elmot 1:d0dfbce63a89 737 #define IS_IRDA_ONE_BIT_SAMPLE(__ONEBIT__) (((__ONEBIT__) == IRDA_ONE_BIT_SAMPLE_DISABLE) || \
elmot 1:d0dfbce63a89 738 ((__ONEBIT__) == IRDA_ONE_BIT_SAMPLE_ENABLE))
elmot 1:d0dfbce63a89 739
elmot 1:d0dfbce63a89 740 /**
elmot 1:d0dfbce63a89 741 * @brief Ensure that IRDA DMA TX mode is valid.
elmot 1:d0dfbce63a89 742 * @param __DMATX__: IRDA DMA TX mode.
elmot 1:d0dfbce63a89 743 * @retval SET (__DMATX__ is valid) or RESET (__DMATX__ is invalid)
elmot 1:d0dfbce63a89 744 */
elmot 1:d0dfbce63a89 745 #define IS_IRDA_DMA_TX(__DMATX__) (((__DMATX__) == IRDA_DMA_TX_DISABLE) || \
elmot 1:d0dfbce63a89 746 ((__DMATX__) == IRDA_DMA_TX_ENABLE))
elmot 1:d0dfbce63a89 747
elmot 1:d0dfbce63a89 748 /**
elmot 1:d0dfbce63a89 749 * @brief Ensure that IRDA DMA RX mode is valid.
elmot 1:d0dfbce63a89 750 * @param __DMARX__: IRDA DMA RX mode.
elmot 1:d0dfbce63a89 751 * @retval SET (__DMARX__ is valid) or RESET (__DMARX__ is invalid)
elmot 1:d0dfbce63a89 752 */
elmot 1:d0dfbce63a89 753 #define IS_IRDA_DMA_RX(__DMARX__) (((__DMARX__) == IRDA_DMA_RX_DISABLE) || \
elmot 1:d0dfbce63a89 754 ((__DMARX__) == IRDA_DMA_RX_ENABLE))
elmot 1:d0dfbce63a89 755
elmot 1:d0dfbce63a89 756 /**
elmot 1:d0dfbce63a89 757 * @brief Ensure that IRDA request is valid.
elmot 1:d0dfbce63a89 758 * @param __PARAM__: IRDA request.
elmot 1:d0dfbce63a89 759 * @retval SET (__PARAM__ is valid) or RESET (__PARAM__ is invalid)
elmot 1:d0dfbce63a89 760 */
elmot 1:d0dfbce63a89 761 #define IS_IRDA_REQUEST_PARAMETER(__PARAM__) (((__PARAM__) == IRDA_AUTOBAUD_REQUEST) || \
elmot 1:d0dfbce63a89 762 ((__PARAM__) == IRDA_RXDATA_FLUSH_REQUEST) || \
elmot 1:d0dfbce63a89 763 ((__PARAM__) == IRDA_TXDATA_FLUSH_REQUEST))
elmot 1:d0dfbce63a89 764 /**
elmot 1:d0dfbce63a89 765 * @}
elmot 1:d0dfbce63a89 766 */
elmot 1:d0dfbce63a89 767
elmot 1:d0dfbce63a89 768 /* Include IRDA HAL Extended module */
elmot 1:d0dfbce63a89 769 #include "stm32l4xx_hal_irda_ex.h"
elmot 1:d0dfbce63a89 770
elmot 1:d0dfbce63a89 771 /* Exported functions --------------------------------------------------------*/
elmot 1:d0dfbce63a89 772 /** @addtogroup IRDA_Exported_Functions IRDA Exported Functions
elmot 1:d0dfbce63a89 773 * @{
elmot 1:d0dfbce63a89 774 */
elmot 1:d0dfbce63a89 775
elmot 1:d0dfbce63a89 776 /** @addtogroup IRDA_Exported_Functions_Group1 Initialization and de-initialization functions
elmot 1:d0dfbce63a89 777 * @{
elmot 1:d0dfbce63a89 778 */
elmot 1:d0dfbce63a89 779
elmot 1:d0dfbce63a89 780 /* Initialization and de-initialization functions ****************************/
elmot 1:d0dfbce63a89 781 HAL_StatusTypeDef HAL_IRDA_Init(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 782 HAL_StatusTypeDef HAL_IRDA_DeInit(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 783 void HAL_IRDA_MspInit(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 784 void HAL_IRDA_MspDeInit(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 785
elmot 1:d0dfbce63a89 786 /**
elmot 1:d0dfbce63a89 787 * @}
elmot 1:d0dfbce63a89 788 */
elmot 1:d0dfbce63a89 789
elmot 1:d0dfbce63a89 790 /** @addtogroup IRDA_Exported_Functions_Group2 IO operation functions
elmot 1:d0dfbce63a89 791 * @{
elmot 1:d0dfbce63a89 792 */
elmot 1:d0dfbce63a89 793
elmot 1:d0dfbce63a89 794 /* IO operation functions *****************************************************/
elmot 1:d0dfbce63a89 795 HAL_StatusTypeDef HAL_IRDA_Transmit(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout);
elmot 1:d0dfbce63a89 796 HAL_StatusTypeDef HAL_IRDA_Receive(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout);
elmot 1:d0dfbce63a89 797 HAL_StatusTypeDef HAL_IRDA_Transmit_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
elmot 1:d0dfbce63a89 798 HAL_StatusTypeDef HAL_IRDA_Receive_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
elmot 1:d0dfbce63a89 799 HAL_StatusTypeDef HAL_IRDA_Transmit_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
elmot 1:d0dfbce63a89 800 HAL_StatusTypeDef HAL_IRDA_Receive_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
elmot 1:d0dfbce63a89 801 HAL_StatusTypeDef HAL_IRDA_DMAPause(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 802 HAL_StatusTypeDef HAL_IRDA_DMAResume(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 803 HAL_StatusTypeDef HAL_IRDA_DMAStop(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 804 void HAL_IRDA_IRQHandler(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 805 void HAL_IRDA_TxCpltCallback(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 806 void HAL_IRDA_RxCpltCallback(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 807 void HAL_IRDA_TxHalfCpltCallback(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 808 void HAL_IRDA_RxHalfCpltCallback(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 809 void HAL_IRDA_ErrorCallback(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 810
elmot 1:d0dfbce63a89 811 /**
elmot 1:d0dfbce63a89 812 * @}
elmot 1:d0dfbce63a89 813 */
elmot 1:d0dfbce63a89 814
elmot 1:d0dfbce63a89 815 /* Peripheral Control functions ************************************************/
elmot 1:d0dfbce63a89 816
elmot 1:d0dfbce63a89 817 /** @addtogroup IRDA_Exported_Functions_Group4 Peripheral State and Error functions
elmot 1:d0dfbce63a89 818 * @{
elmot 1:d0dfbce63a89 819 */
elmot 1:d0dfbce63a89 820
elmot 1:d0dfbce63a89 821 /* Peripheral State and Error functions ***************************************/
elmot 1:d0dfbce63a89 822 HAL_IRDA_StateTypeDef HAL_IRDA_GetState(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 823 uint32_t HAL_IRDA_GetError(IRDA_HandleTypeDef *hirda);
elmot 1:d0dfbce63a89 824
elmot 1:d0dfbce63a89 825 /**
elmot 1:d0dfbce63a89 826 * @}
elmot 1:d0dfbce63a89 827 */
elmot 1:d0dfbce63a89 828
elmot 1:d0dfbce63a89 829 /**
elmot 1:d0dfbce63a89 830 * @}
elmot 1:d0dfbce63a89 831 */
elmot 1:d0dfbce63a89 832
elmot 1:d0dfbce63a89 833 /**
elmot 1:d0dfbce63a89 834 * @}
elmot 1:d0dfbce63a89 835 */
elmot 1:d0dfbce63a89 836
elmot 1:d0dfbce63a89 837 /**
elmot 1:d0dfbce63a89 838 * @}
elmot 1:d0dfbce63a89 839 */
elmot 1:d0dfbce63a89 840
elmot 1:d0dfbce63a89 841 #ifdef __cplusplus
elmot 1:d0dfbce63a89 842 }
elmot 1:d0dfbce63a89 843 #endif
elmot 1:d0dfbce63a89 844
elmot 1:d0dfbce63a89 845 #endif /* __STM32L4xx_HAL_IRDA_H */
elmot 1:d0dfbce63a89 846
elmot 1:d0dfbce63a89 847 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/