mbed library sources

Dependents:   Encrypted my_mbed lklk CyaSSL_DTLS_Cellular ... more

Superseded

This library was superseded by mbed-dev - https://os.mbed.com/users/mbed_official/code/mbed-dev/.

Development branch of the mbed library sources. This library is kept in synch with the latest changes from the mbed SDK and it is not guaranteed to work.

If you are looking for a stable and tested release, please import one of the official mbed library releases:

Import librarymbed

The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Committer:
mbed_official
Date:
Fri Nov 07 08:15:08 2014 +0000
Revision:
392:2b59412bb664
Parent:
targets/cmsis/TARGET_STM/TARGET_NUCLEO_F091RC/stm32f0xx_hal_irda.h@340:28d1f895c6fe
Child:
441:d2c15dda23c1
Synchronized with git revision eec0be05cd92349bee83c65f9e1302b25b5badf4

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

Targets: STM32F0 - Factorisation of NUCLEO_F030R8/F072RB/F091RC cmsis folders

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_irda.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 This file contains all the functions prototypes for the IRDA
mbed_official 340:28d1f895c6fe 8 * firmware library.
mbed_official 340:28d1f895c6fe 9 ******************************************************************************
mbed_official 340:28d1f895c6fe 10 * @attention
mbed_official 340:28d1f895c6fe 11 *
mbed_official 340:28d1f895c6fe 12 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
mbed_official 340:28d1f895c6fe 13 *
mbed_official 340:28d1f895c6fe 14 * Redistribution and use in source and binary forms, with or without modification,
mbed_official 340:28d1f895c6fe 15 * are permitted provided that the following conditions are met:
mbed_official 340:28d1f895c6fe 16 * 1. Redistributions of source code must retain the above copyright notice,
mbed_official 340:28d1f895c6fe 17 * this list of conditions and the following disclaimer.
mbed_official 340:28d1f895c6fe 18 * 2. Redistributions in binary form must reproduce the above copyright notice,
mbed_official 340:28d1f895c6fe 19 * this list of conditions and the following disclaimer in the documentation
mbed_official 340:28d1f895c6fe 20 * and/or other materials provided with the distribution.
mbed_official 340:28d1f895c6fe 21 * 3. Neither the name of STMicroelectronics nor the names of its contributors
mbed_official 340:28d1f895c6fe 22 * may be used to endorse or promote products derived from this software
mbed_official 340:28d1f895c6fe 23 * without specific prior written permission.
mbed_official 340:28d1f895c6fe 24 *
mbed_official 340:28d1f895c6fe 25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
mbed_official 340:28d1f895c6fe 26 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
mbed_official 340:28d1f895c6fe 27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
mbed_official 340:28d1f895c6fe 28 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
mbed_official 340:28d1f895c6fe 29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
mbed_official 340:28d1f895c6fe 30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
mbed_official 340:28d1f895c6fe 31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
mbed_official 340:28d1f895c6fe 32 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
mbed_official 340:28d1f895c6fe 33 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
mbed_official 340:28d1f895c6fe 34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
mbed_official 340:28d1f895c6fe 35 *
mbed_official 340:28d1f895c6fe 36 ******************************************************************************
mbed_official 340:28d1f895c6fe 37 */
mbed_official 340:28d1f895c6fe 38
mbed_official 340:28d1f895c6fe 39 /* Define to prevent recursive inclusion -------------------------------------*/
mbed_official 340:28d1f895c6fe 40 #ifndef __STM32F0xx_HAL_IRDA_H
mbed_official 340:28d1f895c6fe 41 #define __STM32F0xx_HAL_IRDA_H
mbed_official 340:28d1f895c6fe 42
mbed_official 340:28d1f895c6fe 43 #ifdef __cplusplus
mbed_official 340:28d1f895c6fe 44 extern "C" {
mbed_official 340:28d1f895c6fe 45 #endif
mbed_official 340:28d1f895c6fe 46
mbed_official 340:28d1f895c6fe 47 #if !defined(STM32F030x6) && !defined(STM32F030x8)
mbed_official 340:28d1f895c6fe 48
mbed_official 340:28d1f895c6fe 49 /* Includes ------------------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 50 #include "stm32f0xx_hal_def.h"
mbed_official 340:28d1f895c6fe 51
mbed_official 340:28d1f895c6fe 52 /** @addtogroup STM32F0xx_HAL_Driver
mbed_official 340:28d1f895c6fe 53 * @{
mbed_official 340:28d1f895c6fe 54 */
mbed_official 340:28d1f895c6fe 55
mbed_official 340:28d1f895c6fe 56 /** @addtogroup IRDA
mbed_official 340:28d1f895c6fe 57 * @{
mbed_official 340:28d1f895c6fe 58 */
mbed_official 340:28d1f895c6fe 59
mbed_official 340:28d1f895c6fe 60 /* Exported types ------------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 61 /** @defgroup IRDA_Exported_Types IRDA Exported Types
mbed_official 340:28d1f895c6fe 62 * @{
mbed_official 340:28d1f895c6fe 63 */
mbed_official 340:28d1f895c6fe 64
mbed_official 340:28d1f895c6fe 65 /**
mbed_official 340:28d1f895c6fe 66 * @brief IRDA Init Structure definition
mbed_official 340:28d1f895c6fe 67 */
mbed_official 340:28d1f895c6fe 68 typedef struct
mbed_official 340:28d1f895c6fe 69 {
mbed_official 340:28d1f895c6fe 70 uint32_t BaudRate; /*!< This member configures the IRDA communication baud rate.
mbed_official 340:28d1f895c6fe 71 The baud rate register is computed using the following formula:
mbed_official 340:28d1f895c6fe 72 Baud Rate Register = ((PCLKx) / ((hirda->Init.BaudRate))) */
mbed_official 340:28d1f895c6fe 73
mbed_official 340:28d1f895c6fe 74 uint32_t WordLength; /*!< Specifies the number of data bits transmitted or received in a frame.
mbed_official 340:28d1f895c6fe 75 This parameter can be a value of @ref IRDAEx_Word_Length */
mbed_official 340:28d1f895c6fe 76
mbed_official 340:28d1f895c6fe 77 uint16_t Parity; /*!< Specifies the parity mode.
mbed_official 340:28d1f895c6fe 78 This parameter can be a value of @ref IRDA_Parity
mbed_official 340:28d1f895c6fe 79 @note When parity is enabled, the computed parity is inserted
mbed_official 340:28d1f895c6fe 80 at the MSB position of the transmitted data (9th bit when
mbed_official 340:28d1f895c6fe 81 the word length is set to 9 data bits; 8th bit when the
mbed_official 340:28d1f895c6fe 82 word length is set to 8 data bits). */
mbed_official 340:28d1f895c6fe 83
mbed_official 340:28d1f895c6fe 84 uint16_t Mode; /*!< Specifies whether the Receive or Transmit mode is enabled or disabled.
mbed_official 340:28d1f895c6fe 85 This parameter can be a value of @ref IRDA_Mode */
mbed_official 340:28d1f895c6fe 86
mbed_official 340:28d1f895c6fe 87 uint8_t Prescaler; /*!< Specifies the Prescaler value for dividing the UART/USART source clock
mbed_official 340:28d1f895c6fe 88 to achieve low-power frequency.
mbed_official 340:28d1f895c6fe 89 @note Prescaler value 0 is forbidden */
mbed_official 340:28d1f895c6fe 90
mbed_official 340:28d1f895c6fe 91 uint16_t PowerMode; /*!< Specifies the IRDA power mode.
mbed_official 340:28d1f895c6fe 92 This parameter can be a value of @ref IRDA_Low_Power */
mbed_official 340:28d1f895c6fe 93 }IRDA_InitTypeDef;
mbed_official 340:28d1f895c6fe 94
mbed_official 340:28d1f895c6fe 95 /**
mbed_official 340:28d1f895c6fe 96 * @brief HAL IRDA State structures definition
mbed_official 340:28d1f895c6fe 97 */
mbed_official 340:28d1f895c6fe 98 typedef enum
mbed_official 340:28d1f895c6fe 99 {
mbed_official 340:28d1f895c6fe 100 HAL_IRDA_STATE_RESET = 0x00, /*!< Peripheral is not initialized */
mbed_official 340:28d1f895c6fe 101 HAL_IRDA_STATE_READY = 0x01, /*!< Peripheral Initialized and ready for use */
mbed_official 340:28d1f895c6fe 102 HAL_IRDA_STATE_BUSY = 0x02, /*!< an internal process is ongoing */
mbed_official 340:28d1f895c6fe 103 HAL_IRDA_STATE_BUSY_TX = 0x12, /*!< Data Transmission process is ongoing */
mbed_official 340:28d1f895c6fe 104 HAL_IRDA_STATE_BUSY_RX = 0x22, /*!< Data Reception process is ongoing */
mbed_official 340:28d1f895c6fe 105 HAL_IRDA_STATE_BUSY_TX_RX = 0x32, /*!< Data Transmission and Reception process is ongoing */
mbed_official 340:28d1f895c6fe 106 HAL_IRDA_STATE_TIMEOUT = 0x03, /*!< Timeout state */
mbed_official 340:28d1f895c6fe 107 HAL_IRDA_STATE_ERROR = 0x04 /*!< Error */
mbed_official 340:28d1f895c6fe 108 }HAL_IRDA_StateTypeDef;
mbed_official 340:28d1f895c6fe 109
mbed_official 340:28d1f895c6fe 110 /**
mbed_official 340:28d1f895c6fe 111 * @brief HAL IRDA Error Code structure definition
mbed_official 340:28d1f895c6fe 112 */
mbed_official 340:28d1f895c6fe 113 typedef enum
mbed_official 340:28d1f895c6fe 114 {
mbed_official 340:28d1f895c6fe 115 HAL_IRDA_ERROR_NONE = 0x00, /*!< No error */
mbed_official 340:28d1f895c6fe 116 HAL_IRDA_ERROR_PE = 0x01, /*!< Parity error */
mbed_official 340:28d1f895c6fe 117 HAL_IRDA_ERROR_NE = 0x02, /*!< Noise error */
mbed_official 340:28d1f895c6fe 118 HAL_IRDA_ERROR_FE = 0x04, /*!< frame error */
mbed_official 340:28d1f895c6fe 119 HAL_IRDA_ERROR_ORE = 0x08, /*!< Overrun error */
mbed_official 340:28d1f895c6fe 120 HAL_IRDA_ERROR_DMA = 0x10 /*!< DMA transfer error */
mbed_official 340:28d1f895c6fe 121 }HAL_IRDA_ErrorTypeDef;
mbed_official 340:28d1f895c6fe 122
mbed_official 340:28d1f895c6fe 123 /**
mbed_official 340:28d1f895c6fe 124 * @brief IRDA clock sources definition
mbed_official 340:28d1f895c6fe 125 */
mbed_official 340:28d1f895c6fe 126 typedef enum
mbed_official 340:28d1f895c6fe 127 {
mbed_official 340:28d1f895c6fe 128 IRDA_CLOCKSOURCE_PCLK1 = 0x00, /*!< PCLK1 clock source */
mbed_official 340:28d1f895c6fe 129 IRDA_CLOCKSOURCE_HSI = 0x02, /*!< HSI clock source */
mbed_official 340:28d1f895c6fe 130 IRDA_CLOCKSOURCE_SYSCLK = 0x04, /*!< SYSCLK clock source */
mbed_official 340:28d1f895c6fe 131 IRDA_CLOCKSOURCE_LSE = 0x08, /*!< LSE clock source */
mbed_official 340:28d1f895c6fe 132 IRDA_CLOCKSOURCE_UNDEFINED = 0x10 /*!< undefined clock source */
mbed_official 340:28d1f895c6fe 133 }IRDA_ClockSourceTypeDef;
mbed_official 340:28d1f895c6fe 134
mbed_official 340:28d1f895c6fe 135 /**
mbed_official 340:28d1f895c6fe 136 * @brief IRDA handle Structure definition
mbed_official 340:28d1f895c6fe 137 */
mbed_official 340:28d1f895c6fe 138 typedef struct
mbed_official 340:28d1f895c6fe 139 {
mbed_official 340:28d1f895c6fe 140 USART_TypeDef *Instance; /* USART registers base address */
mbed_official 340:28d1f895c6fe 141
mbed_official 340:28d1f895c6fe 142 IRDA_InitTypeDef Init; /* IRDA communication parameters */
mbed_official 340:28d1f895c6fe 143
mbed_official 340:28d1f895c6fe 144 uint8_t *pTxBuffPtr; /* Pointer to IRDA Tx transfer Buffer */
mbed_official 340:28d1f895c6fe 145
mbed_official 340:28d1f895c6fe 146 uint16_t TxXferSize; /* IRDA Tx Transfer size */
mbed_official 340:28d1f895c6fe 147
mbed_official 340:28d1f895c6fe 148 uint16_t TxXferCount; /* IRDA Tx Transfer Counter */
mbed_official 340:28d1f895c6fe 149
mbed_official 340:28d1f895c6fe 150 uint8_t *pRxBuffPtr; /* Pointer to IRDA Rx transfer Buffer */
mbed_official 340:28d1f895c6fe 151
mbed_official 340:28d1f895c6fe 152 uint16_t RxXferSize; /* IRDA Rx Transfer size */
mbed_official 340:28d1f895c6fe 153
mbed_official 340:28d1f895c6fe 154 uint16_t RxXferCount; /* IRDA Rx Transfer Counter */
mbed_official 340:28d1f895c6fe 155
mbed_official 340:28d1f895c6fe 156 uint16_t Mask; /* USART RX RDR register mask */
mbed_official 340:28d1f895c6fe 157
mbed_official 340:28d1f895c6fe 158 DMA_HandleTypeDef *hdmatx; /* IRDA Tx DMA Handle parameters */
mbed_official 340:28d1f895c6fe 159
mbed_official 340:28d1f895c6fe 160 DMA_HandleTypeDef *hdmarx; /* IRDA Rx DMA Handle parameters */
mbed_official 340:28d1f895c6fe 161
mbed_official 340:28d1f895c6fe 162 HAL_LockTypeDef Lock; /* Locking object */
mbed_official 340:28d1f895c6fe 163
mbed_official 340:28d1f895c6fe 164 HAL_IRDA_StateTypeDef State; /* IRDA communication state */
mbed_official 340:28d1f895c6fe 165
mbed_official 340:28d1f895c6fe 166 HAL_IRDA_ErrorTypeDef ErrorCode; /* IRDA Error code */
mbed_official 340:28d1f895c6fe 167
mbed_official 340:28d1f895c6fe 168 }IRDA_HandleTypeDef;
mbed_official 340:28d1f895c6fe 169
mbed_official 340:28d1f895c6fe 170 /**
mbed_official 340:28d1f895c6fe 171 * @brief IRDA Configuration enumeration values definition
mbed_official 340:28d1f895c6fe 172 */
mbed_official 340:28d1f895c6fe 173 typedef enum
mbed_official 340:28d1f895c6fe 174 {
mbed_official 340:28d1f895c6fe 175 IRDA_BAUDRATE = 0x00,
mbed_official 340:28d1f895c6fe 176 IRDA_PARITY = 0x01,
mbed_official 340:28d1f895c6fe 177 IRDA_WORDLENGTH = 0x02,
mbed_official 340:28d1f895c6fe 178 IRDA_MODE = 0x03,
mbed_official 340:28d1f895c6fe 179 IRDA_PRESCALER = 0x04,
mbed_official 340:28d1f895c6fe 180 IRDA_POWERMODE = 0x05
mbed_official 340:28d1f895c6fe 181 }IRDA_ControlTypeDef;
mbed_official 340:28d1f895c6fe 182
mbed_official 340:28d1f895c6fe 183 /**
mbed_official 340:28d1f895c6fe 184 * @}
mbed_official 340:28d1f895c6fe 185 */
mbed_official 340:28d1f895c6fe 186
mbed_official 340:28d1f895c6fe 187 /* Exported constants --------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 188 /** @defgroup IRDA_Exported_Constants IRDA Exported constants
mbed_official 340:28d1f895c6fe 189 * @{
mbed_official 340:28d1f895c6fe 190 */
mbed_official 340:28d1f895c6fe 191
mbed_official 340:28d1f895c6fe 192 /** @defgroup IRDA_Parity IRDA Parity
mbed_official 340:28d1f895c6fe 193 * @{
mbed_official 340:28d1f895c6fe 194 */
mbed_official 340:28d1f895c6fe 195 #define IRDA_PARITY_NONE ((uint16_t)0x0000)
mbed_official 340:28d1f895c6fe 196 #define IRDA_PARITY_EVEN ((uint16_t)USART_CR1_PCE)
mbed_official 340:28d1f895c6fe 197 #define IRDA_PARITY_ODD ((uint16_t)(USART_CR1_PCE | USART_CR1_PS))
mbed_official 340:28d1f895c6fe 198 #define IS_IRDA_PARITY(PARITY) (((PARITY) == IRDA_PARITY_NONE) || \
mbed_official 340:28d1f895c6fe 199 ((PARITY) == IRDA_PARITY_EVEN) || \
mbed_official 340:28d1f895c6fe 200 ((PARITY) == IRDA_PARITY_ODD))
mbed_official 340:28d1f895c6fe 201 /**
mbed_official 340:28d1f895c6fe 202 * @}
mbed_official 340:28d1f895c6fe 203 */
mbed_official 340:28d1f895c6fe 204
mbed_official 340:28d1f895c6fe 205
mbed_official 340:28d1f895c6fe 206 /** @defgroup IRDA_Transfer_Mode IRDA Transfer Mode
mbed_official 340:28d1f895c6fe 207 * @{
mbed_official 340:28d1f895c6fe 208 */
mbed_official 340:28d1f895c6fe 209 #define IRDA_MODE_RX ((uint16_t)USART_CR1_RE)
mbed_official 340:28d1f895c6fe 210 #define IRDA_MODE_TX ((uint16_t)USART_CR1_TE)
mbed_official 340:28d1f895c6fe 211 #define IRDA_MODE_TX_RX ((uint16_t)(USART_CR1_TE |USART_CR1_RE))
mbed_official 340:28d1f895c6fe 212 #define IS_IRDA_TX_RX_MODE(MODE) ((((MODE) & ((uint16_t)(~((uint16_t)(IRDA_MODE_TX_RX))))) == (uint16_t)0x00) && ((MODE) != (uint16_t)0x00))
mbed_official 340:28d1f895c6fe 213 /**
mbed_official 340:28d1f895c6fe 214 * @}
mbed_official 340:28d1f895c6fe 215 */
mbed_official 340:28d1f895c6fe 216
mbed_official 340:28d1f895c6fe 217 /** @defgroup IRDA_Low_Power IRDA Low Power
mbed_official 340:28d1f895c6fe 218 * @{
mbed_official 340:28d1f895c6fe 219 */
mbed_official 340:28d1f895c6fe 220 #define IRDA_POWERMODE_NORMAL ((uint16_t)0x0000)
mbed_official 340:28d1f895c6fe 221 #define IRDA_POWERMODE_LOWPOWER ((uint16_t)USART_CR3_IRLP)
mbed_official 340:28d1f895c6fe 222 #define IS_IRDA_POWERMODE(MODE) (((MODE) == IRDA_POWERMODE_LOWPOWER) || \
mbed_official 340:28d1f895c6fe 223 ((MODE) == IRDA_POWERMODE_NORMAL))
mbed_official 340:28d1f895c6fe 224 /**
mbed_official 340:28d1f895c6fe 225 * @}
mbed_official 340:28d1f895c6fe 226 */
mbed_official 340:28d1f895c6fe 227
mbed_official 340:28d1f895c6fe 228 /** @defgroup IRDA_State IRDA State
mbed_official 340:28d1f895c6fe 229 * @{
mbed_official 340:28d1f895c6fe 230 */
mbed_official 340:28d1f895c6fe 231 #define IRDA_STATE_DISABLE ((uint16_t)0x0000)
mbed_official 340:28d1f895c6fe 232 #define IRDA_STATE_ENABLE ((uint16_t)USART_CR1_UE)
mbed_official 340:28d1f895c6fe 233 #define IS_IRDA_STATE(STATE) (((STATE) == IRDA_STATE_DISABLE) || \
mbed_official 340:28d1f895c6fe 234 ((STATE) == IRDA_STATE_ENABLE))
mbed_official 340:28d1f895c6fe 235 /**
mbed_official 340:28d1f895c6fe 236 * @}
mbed_official 340:28d1f895c6fe 237 */
mbed_official 340:28d1f895c6fe 238
mbed_official 340:28d1f895c6fe 239 /** @defgroup IRDA_Mode IRDA Mode
mbed_official 340:28d1f895c6fe 240 * @{
mbed_official 340:28d1f895c6fe 241 */
mbed_official 340:28d1f895c6fe 242 #define IRDA_MODE_DISABLE ((uint16_t)0x0000)
mbed_official 340:28d1f895c6fe 243 #define IRDA_MODE_ENABLE ((uint16_t)USART_CR3_IREN)
mbed_official 340:28d1f895c6fe 244 #define IS_IRDA_MODE(STATE) (((STATE) == IRDA_MODE_DISABLE) || \
mbed_official 340:28d1f895c6fe 245 ((STATE) == IRDA_MODE_ENABLE))
mbed_official 340:28d1f895c6fe 246 /**
mbed_official 340:28d1f895c6fe 247 * @}
mbed_official 340:28d1f895c6fe 248 */
mbed_official 340:28d1f895c6fe 249
mbed_official 340:28d1f895c6fe 250 /** @defgroup IRDA_One_Bit IRDA One Bit Sampling
mbed_official 340:28d1f895c6fe 251 * @{
mbed_official 340:28d1f895c6fe 252 */
mbed_official 340:28d1f895c6fe 253 #define IRDA_ONE_BIT_SAMPLE_DISABLED ((uint16_t)0x00000000)
mbed_official 340:28d1f895c6fe 254 #define IRDA_ONE_BIT_SAMPLE_ENABLED ((uint16_t)USART_CR3_ONEBIT)
mbed_official 340:28d1f895c6fe 255 #define IS_IRDA_ONEBIT_SAMPLE(ONEBIT) (((ONEBIT) == IRDA_ONE_BIT_SAMPLE_DISABLED) || \
mbed_official 340:28d1f895c6fe 256 ((ONEBIT) == IRDA_ONE_BIT_SAMPLE_ENABLED))
mbed_official 340:28d1f895c6fe 257 /**
mbed_official 340:28d1f895c6fe 258 * @}
mbed_official 340:28d1f895c6fe 259 */
mbed_official 340:28d1f895c6fe 260
mbed_official 340:28d1f895c6fe 261 /** @defgroup IRDA_DMA_Tx IRDA DMA Tx
mbed_official 340:28d1f895c6fe 262 * @{
mbed_official 340:28d1f895c6fe 263 */
mbed_official 340:28d1f895c6fe 264 #define IRDA_DMA_TX_DISABLE ((uint16_t)0x00000000)
mbed_official 340:28d1f895c6fe 265 #define IRDA_DMA_TX_ENABLE ((uint16_t)USART_CR3_DMAT)
mbed_official 340:28d1f895c6fe 266 #define IS_IRDA_DMA_TX(DMATX) (((DMATX) == IRDA_DMA_TX_DISABLE) || \
mbed_official 340:28d1f895c6fe 267 ((DMATX) == IRDA_DMA_TX_ENABLE))
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 IRDA_DMA_Rx IRDA DMA Rx
mbed_official 340:28d1f895c6fe 273 * @{
mbed_official 340:28d1f895c6fe 274 */
mbed_official 340:28d1f895c6fe 275 #define IRDA_DMA_RX_DISABLE ((uint16_t)0x0000)
mbed_official 340:28d1f895c6fe 276 #define IRDA_DMA_RX_ENABLE ((uint16_t)USART_CR3_DMAR)
mbed_official 340:28d1f895c6fe 277 #define IS_IRDA_DMA_RX(DMARX) (((DMARX) == IRDA_DMA_RX_DISABLE) || \
mbed_official 340:28d1f895c6fe 278 ((DMARX) == IRDA_DMA_RX_ENABLE))
mbed_official 340:28d1f895c6fe 279 /**
mbed_official 340:28d1f895c6fe 280 * @}
mbed_official 340:28d1f895c6fe 281 */
mbed_official 340:28d1f895c6fe 282
mbed_official 340:28d1f895c6fe 283 /** @defgroup IRDA_Flags IRDA Flags
mbed_official 340:28d1f895c6fe 284 * Elements values convention: 0xXXXX
mbed_official 340:28d1f895c6fe 285 * - 0xXXXX : Flag mask in the ISR register
mbed_official 340:28d1f895c6fe 286 * @{
mbed_official 340:28d1f895c6fe 287 */
mbed_official 340:28d1f895c6fe 288 #define IRDA_FLAG_REACK ((uint32_t)0x00400000)
mbed_official 340:28d1f895c6fe 289 #define IRDA_FLAG_TEACK ((uint32_t)0x00200000)
mbed_official 340:28d1f895c6fe 290 #define IRDA_FLAG_BUSY ((uint32_t)0x00010000)
mbed_official 340:28d1f895c6fe 291 #define IRDA_FLAG_ABRF ((uint32_t)0x00008000)
mbed_official 340:28d1f895c6fe 292 #define IRDA_FLAG_ABRE ((uint32_t)0x00004000)
mbed_official 340:28d1f895c6fe 293 #define IRDA_FLAG_TXE ((uint32_t)0x00000080)
mbed_official 340:28d1f895c6fe 294 #define IRDA_FLAG_TC ((uint32_t)0x00000040)
mbed_official 340:28d1f895c6fe 295 #define IRDA_FLAG_RXNE ((uint32_t)0x00000020)
mbed_official 340:28d1f895c6fe 296 #define IRDA_FLAG_ORE ((uint32_t)0x00000008)
mbed_official 340:28d1f895c6fe 297 #define IRDA_FLAG_NE ((uint32_t)0x00000004)
mbed_official 340:28d1f895c6fe 298 #define IRDA_FLAG_FE ((uint32_t)0x00000002)
mbed_official 340:28d1f895c6fe 299 #define IRDA_FLAG_PE ((uint32_t)0x00000001)
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 IRDA_Interrupt_definition IRDA Interrupt Definition
mbed_official 340:28d1f895c6fe 305 * Elements values convention: 0000ZZZZ0XXYYYYYb
mbed_official 340:28d1f895c6fe 306 * - YYYYY : Interrupt source position in the XX register (5bits)
mbed_official 340:28d1f895c6fe 307 * - XX : Interrupt source register (2bits)
mbed_official 340:28d1f895c6fe 308 * - 01: CR1 register
mbed_official 340:28d1f895c6fe 309 * - 10: CR2 register
mbed_official 340:28d1f895c6fe 310 * - 11: CR3 register
mbed_official 340:28d1f895c6fe 311 * - ZZZZ : Flag position in the ISR register(4bits)
mbed_official 340:28d1f895c6fe 312 * @{
mbed_official 340:28d1f895c6fe 313 */
mbed_official 340:28d1f895c6fe 314 #define IRDA_IT_PE ((uint16_t)0x0028)
mbed_official 340:28d1f895c6fe 315 #define IRDA_IT_TXE ((uint16_t)0x0727)
mbed_official 340:28d1f895c6fe 316 #define IRDA_IT_TC ((uint16_t)0x0626)
mbed_official 340:28d1f895c6fe 317 #define IRDA_IT_RXNE ((uint16_t)0x0525)
mbed_official 340:28d1f895c6fe 318 #define IRDA_IT_IDLE ((uint16_t)0x0424)
mbed_official 340:28d1f895c6fe 319
mbed_official 340:28d1f895c6fe 320
mbed_official 340:28d1f895c6fe 321
mbed_official 340:28d1f895c6fe 322 /** Elements values convention: 000000000XXYYYYYb
mbed_official 340:28d1f895c6fe 323 * - YYYYY : Interrupt source position in the XX register (5bits)
mbed_official 340:28d1f895c6fe 324 * - XX : Interrupt source register (2bits)
mbed_official 340:28d1f895c6fe 325 * - 01: CR1 register
mbed_official 340:28d1f895c6fe 326 * - 10: CR2 register
mbed_official 340:28d1f895c6fe 327 * - 11: CR3 register
mbed_official 340:28d1f895c6fe 328 */
mbed_official 340:28d1f895c6fe 329 #define IRDA_IT_ERR ((uint16_t)0x0060)
mbed_official 340:28d1f895c6fe 330
mbed_official 340:28d1f895c6fe 331 /** Elements values convention: 0000ZZZZ00000000b
mbed_official 340:28d1f895c6fe 332 * - ZZZZ : Flag position in the ISR register(4bits)
mbed_official 340:28d1f895c6fe 333 */
mbed_official 340:28d1f895c6fe 334 #define IRDA_IT_ORE ((uint16_t)0x0300)
mbed_official 340:28d1f895c6fe 335 #define IRDA_IT_NE ((uint16_t)0x0200)
mbed_official 340:28d1f895c6fe 336 #define IRDA_IT_FE ((uint16_t)0x0100)
mbed_official 340:28d1f895c6fe 337 /**
mbed_official 340:28d1f895c6fe 338 * @}
mbed_official 340:28d1f895c6fe 339 */
mbed_official 340:28d1f895c6fe 340
mbed_official 340:28d1f895c6fe 341 /** @defgroup IRDA_IT_CLEAR_Flags IRDA Interruption Clear Flags
mbed_official 340:28d1f895c6fe 342 * @{
mbed_official 340:28d1f895c6fe 343 */
mbed_official 340:28d1f895c6fe 344 #define IRDA_CLEAR_PEF USART_ICR_PECF /*!< Parity Error Clear Flag */
mbed_official 340:28d1f895c6fe 345 #define IRDA_CLEAR_FEF USART_ICR_FECF /*!< Framing Error Clear Flag */
mbed_official 340:28d1f895c6fe 346 #define IRDA_CLEAR_NEF USART_ICR_NCF /*!< Noise detected Clear Flag */
mbed_official 340:28d1f895c6fe 347 #define IRDA_CLEAR_OREF USART_ICR_ORECF /*!< OverRun Error Clear Flag */
mbed_official 340:28d1f895c6fe 348 #define IRDA_CLEAR_TCF USART_ICR_TCCF /*!< Transmission Complete Clear Flag */
mbed_official 340:28d1f895c6fe 349 /**
mbed_official 340:28d1f895c6fe 350 * @}
mbed_official 340:28d1f895c6fe 351 */
mbed_official 340:28d1f895c6fe 352
mbed_official 340:28d1f895c6fe 353
mbed_official 340:28d1f895c6fe 354
mbed_official 340:28d1f895c6fe 355 /** @defgroup IRDA_Request_Parameters IRDA Request Parameters
mbed_official 340:28d1f895c6fe 356 * @{
mbed_official 340:28d1f895c6fe 357 */
mbed_official 340:28d1f895c6fe 358 #define IRDA_AUTOBAUD_REQUEST ((uint16_t)USART_RQR_ABRRQ) /*!< Auto-Baud Rate Request */
mbed_official 340:28d1f895c6fe 359 #define IRDA_RXDATA_FLUSH_REQUEST ((uint16_t)USART_RQR_RXFRQ) /*!< Receive Data flush Request */
mbed_official 340:28d1f895c6fe 360 #define IRDA_TXDATA_FLUSH_REQUEST ((uint16_t)USART_RQR_TXFRQ) /*!< Transmit data flush Request */
mbed_official 340:28d1f895c6fe 361 #define IS_IRDA_REQUEST_PARAMETER(PARAM) (((PARAM) == IRDA_AUTOBAUD_REQUEST) || \
mbed_official 340:28d1f895c6fe 362 ((PARAM) == IRDA_RXDATA_FLUSH_REQUEST) || \
mbed_official 340:28d1f895c6fe 363 ((PARAM) == IRDA_TXDATA_FLUSH_REQUEST))
mbed_official 340:28d1f895c6fe 364 /**
mbed_official 340:28d1f895c6fe 365 * @}
mbed_official 340:28d1f895c6fe 366 */
mbed_official 340:28d1f895c6fe 367
mbed_official 340:28d1f895c6fe 368 /** @defgroup IRDA_Interruption_Mask IRDA interruptions flag mask
mbed_official 340:28d1f895c6fe 369 * @{
mbed_official 340:28d1f895c6fe 370 */
mbed_official 340:28d1f895c6fe 371 #define IRDA_IT_MASK ((uint16_t)0x001F)
mbed_official 340:28d1f895c6fe 372 /**
mbed_official 340:28d1f895c6fe 373 * @}
mbed_official 340:28d1f895c6fe 374 */
mbed_official 340:28d1f895c6fe 375
mbed_official 340:28d1f895c6fe 376 /**
mbed_official 340:28d1f895c6fe 377 * @}
mbed_official 340:28d1f895c6fe 378 */
mbed_official 340:28d1f895c6fe 379
mbed_official 340:28d1f895c6fe 380 /* Exported macro ------------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 381 /** @defgroup IRDA_Exported_Macros IRDA Exported Macros
mbed_official 340:28d1f895c6fe 382 * @{
mbed_official 340:28d1f895c6fe 383 */
mbed_official 340:28d1f895c6fe 384
mbed_official 340:28d1f895c6fe 385 /** @brief Reset IRDA handle state
mbed_official 340:28d1f895c6fe 386 * @param __HANDLE__: IRDA handle.
mbed_official 340:28d1f895c6fe 387 * @retval None
mbed_official 340:28d1f895c6fe 388 */
mbed_official 340:28d1f895c6fe 389 #define __HAL_IRDA_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_IRDA_STATE_RESET)
mbed_official 340:28d1f895c6fe 390
mbed_official 340:28d1f895c6fe 391 /** @brief Checks whether the specified IRDA flag is set or not.
mbed_official 340:28d1f895c6fe 392 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 393 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 394 * UART peripheral
mbed_official 340:28d1f895c6fe 395 * @param __FLAG__: specifies the flag to check.
mbed_official 340:28d1f895c6fe 396 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 397 * @arg IRDA_FLAG_REACK: Receive enable ackowledge flag
mbed_official 340:28d1f895c6fe 398 * @arg IRDA_FLAG_TEACK: Transmit enable ackowledge flag
mbed_official 340:28d1f895c6fe 399 * @arg IRDA_FLAG_BUSY: Busy flag
mbed_official 340:28d1f895c6fe 400 * @arg IRDA_FLAG_ABRF: Auto Baud rate detection flag
mbed_official 340:28d1f895c6fe 401 * @arg IRDA_FLAG_ABRE: Auto Baud rate detection error flag
mbed_official 340:28d1f895c6fe 402 * @arg IRDA_FLAG_TXE: Transmit data register empty flag
mbed_official 340:28d1f895c6fe 403 * @arg IRDA_FLAG_TC: Transmission Complete flag
mbed_official 340:28d1f895c6fe 404 * @arg IRDA_FLAG_RXNE: Receive data register not empty flag
mbed_official 340:28d1f895c6fe 405 * @arg IRDA_FLAG_IDLE: Idle Line detection flag
mbed_official 340:28d1f895c6fe 406 * @arg IRDA_FLAG_ORE: OverRun Error flag
mbed_official 340:28d1f895c6fe 407 * @arg IRDA_FLAG_NE: Noise Error flag
mbed_official 340:28d1f895c6fe 408 * @arg IRDA_FLAG_FE: Framing Error flag
mbed_official 340:28d1f895c6fe 409 * @arg IRDA_FLAG_PE: Parity Error flag
mbed_official 340:28d1f895c6fe 410 * @retval The new state of __FLAG__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 411 */
mbed_official 340:28d1f895c6fe 412 #define __HAL_IRDA_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__))
mbed_official 340:28d1f895c6fe 413
mbed_official 340:28d1f895c6fe 414 /** @brief Enables the specified IRDA interrupt.
mbed_official 340:28d1f895c6fe 415 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 416 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 417 * UART peripheral
mbed_official 340:28d1f895c6fe 418 * @param __INTERRUPT__: specifies the IRDA interrupt source to enable.
mbed_official 340:28d1f895c6fe 419 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 420 * @arg IRDA_IT_TXE: Transmit Data Register empty interrupt
mbed_official 340:28d1f895c6fe 421 * @arg IRDA_IT_TC: Transmission complete interrupt
mbed_official 340:28d1f895c6fe 422 * @arg IRDA_IT_RXNE: Receive Data register not empty interrupt
mbed_official 340:28d1f895c6fe 423 * @arg IRDA_IT_IDLE: Idle line detection interrupt
mbed_official 340:28d1f895c6fe 424 * @arg IRDA_IT_PE: Parity Error interrupt
mbed_official 340:28d1f895c6fe 425 * @arg IRDA_IT_ERR: Error interrupt(Frame error, noise error, overrun error)
mbed_official 340:28d1f895c6fe 426 * @retval None
mbed_official 340:28d1f895c6fe 427 */
mbed_official 340:28d1f895c6fe 428 #define __HAL_IRDA_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((((uint8_t)(__INTERRUPT__)) >> 5U) == 1)? ((__HANDLE__)->Instance->CR1 |= (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
mbed_official 340:28d1f895c6fe 429 ((((uint8_t)(__INTERRUPT__)) >> 5U) == 2)? ((__HANDLE__)->Instance->CR2 |= (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
mbed_official 340:28d1f895c6fe 430 ((__HANDLE__)->Instance->CR3 |= (1U << ((__INTERRUPT__) & IRDA_IT_MASK))))
mbed_official 340:28d1f895c6fe 431
mbed_official 340:28d1f895c6fe 432 /** @brief Disables the specified IRDA interrupt.
mbed_official 340:28d1f895c6fe 433 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 434 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 435 * UART peripheral
mbed_official 340:28d1f895c6fe 436 * @param __INTERRUPT__: specifies the IRDA interrupt source to disable.
mbed_official 340:28d1f895c6fe 437 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 438 * @arg IRDA_IT_TXE: Transmit Data Register empty interrupt
mbed_official 340:28d1f895c6fe 439 * @arg IRDA_IT_TC: Transmission complete interrupt
mbed_official 340:28d1f895c6fe 440 * @arg IRDA_IT_RXNE: Receive Data register not empty interrupt
mbed_official 340:28d1f895c6fe 441 * @arg IRDA_IT_IDLE: Idle line detection interrupt
mbed_official 340:28d1f895c6fe 442 * @arg IRDA_IT_PE: Parity Error interrupt
mbed_official 340:28d1f895c6fe 443 * @arg IRDA_IT_ERR: Error interrupt(Frame error, noise error, overrun error)
mbed_official 340:28d1f895c6fe 444 * @retval None
mbed_official 340:28d1f895c6fe 445 */
mbed_official 340:28d1f895c6fe 446 #define __HAL_IRDA_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((((uint8_t)(__INTERRUPT__)) >> 5U) == 1)? ((__HANDLE__)->Instance->CR1 &= ~ (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
mbed_official 340:28d1f895c6fe 447 ((((uint8_t)(__INTERRUPT__)) >> 5U) == 2)? ((__HANDLE__)->Instance->CR2 &= ~ (1U << ((__INTERRUPT__) & IRDA_IT_MASK))): \
mbed_official 340:28d1f895c6fe 448 ((__HANDLE__)->Instance->CR3 &= ~ (1U << ((__INTERRUPT__) & IRDA_IT_MASK))))
mbed_official 340:28d1f895c6fe 449
mbed_official 340:28d1f895c6fe 450
mbed_official 340:28d1f895c6fe 451 /** @brief Checks whether the specified IRDA interrupt has occurred or not.
mbed_official 340:28d1f895c6fe 452 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 453 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 454 * UART peripheral
mbed_official 340:28d1f895c6fe 455 * @param __IT__: specifies the IRDA interrupt source to check.
mbed_official 340:28d1f895c6fe 456 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 457 * @arg IRDA_IT_TXE: Transmit Data Register empty interrupt
mbed_official 340:28d1f895c6fe 458 * @arg IRDA_IT_TC: Transmission complete interrupt
mbed_official 340:28d1f895c6fe 459 * @arg IRDA_IT_RXNE: Receive Data register not empty interrupt
mbed_official 340:28d1f895c6fe 460 * @arg IRDA_IT_IDLE: Idle line detection interrupt
mbed_official 340:28d1f895c6fe 461 * @arg IRDA_IT_ORE: OverRun Error interrupt
mbed_official 340:28d1f895c6fe 462 * @arg IRDA_IT_NE: Noise Error interrupt
mbed_official 340:28d1f895c6fe 463 * @arg IRDA_IT_FE: Framing Error interrupt
mbed_official 340:28d1f895c6fe 464 * @arg IRDA_IT_PE: Parity Error interrupt
mbed_official 340:28d1f895c6fe 465 * @retval The new state of __IT__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 466 */
mbed_official 340:28d1f895c6fe 467 #define __HAL_IRDA_GET_IT(__HANDLE__, __IT__) ((__HANDLE__)->Instance->ISR & ((uint32_t)1U << ((__IT__)>> 0x08)))
mbed_official 340:28d1f895c6fe 468
mbed_official 340:28d1f895c6fe 469 /** @brief Checks whether the specified IRDA interrupt source is enabled.
mbed_official 340:28d1f895c6fe 470 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 471 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 472 * UART peripheral
mbed_official 340:28d1f895c6fe 473 * @param __IT__: specifies the IRDA interrupt source to check.
mbed_official 340:28d1f895c6fe 474 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 475 * @arg IRDA_IT_TXE: Transmit Data Register empty interrupt
mbed_official 340:28d1f895c6fe 476 * @arg IRDA_IT_TC: Transmission complete interrupt
mbed_official 340:28d1f895c6fe 477 * @arg IRDA_IT_RXNE: Receive Data register not empty interrupt
mbed_official 340:28d1f895c6fe 478 * @arg IRDA_IT_IDLE: Idle line detection interrupt
mbed_official 340:28d1f895c6fe 479 * @arg IRDA_IT_ORE: OverRun Error interrupt
mbed_official 340:28d1f895c6fe 480 * @arg IRDA_IT_NE: Noise Error interrupt
mbed_official 340:28d1f895c6fe 481 * @arg IRDA_IT_FE: Framing Error interrupt
mbed_official 340:28d1f895c6fe 482 * @arg IRDA_IT_PE: Parity Error interrupt
mbed_official 340:28d1f895c6fe 483 * @retval The new state of __IT__ (TRUE or FALSE).
mbed_official 340:28d1f895c6fe 484 */
mbed_official 340:28d1f895c6fe 485 #define __HAL_IRDA_GET_IT_SOURCE(__HANDLE__, __IT__) ((((((uint8_t)(__IT__)) >> 5U) == 1)? (__HANDLE__)->Instance->CR1:(((((uint8_t)(__IT__)) >> 5U) == 2)? \
mbed_official 340:28d1f895c6fe 486 (__HANDLE__)->Instance->CR2 : (__HANDLE__)->Instance->CR3)) & ((uint32_t)1 << (((uint16_t)(__IT__)) & IRDA_IT_MASK)))
mbed_official 340:28d1f895c6fe 487
mbed_official 340:28d1f895c6fe 488
mbed_official 340:28d1f895c6fe 489 /** @brief Clears the specified IRDA ISR flag, in setting the proper ICR register flag.
mbed_official 340:28d1f895c6fe 490 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 491 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 492 * UART peripheral
mbed_official 340:28d1f895c6fe 493 * @param __IT_CLEAR__: specifies the interrupt clear register flag that needs to be set
mbed_official 340:28d1f895c6fe 494 * to clear the corresponding interrupt
mbed_official 340:28d1f895c6fe 495 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 496 * @arg IRDA_CLEAR_PEF: Parity Error Clear Flag
mbed_official 340:28d1f895c6fe 497 * @arg IRDA_CLEAR_FEF: Framing Error Clear Flag
mbed_official 340:28d1f895c6fe 498 * @arg IRDA_CLEAR_NEF: Noise detected Clear Flag
mbed_official 340:28d1f895c6fe 499 * @arg IRDA_CLEAR_OREF: OverRun Error Clear Flag
mbed_official 340:28d1f895c6fe 500 * @arg IRDA_CLEAR_TCF: Transmission Complete Clear Flag
mbed_official 340:28d1f895c6fe 501 * @retval None
mbed_official 340:28d1f895c6fe 502 */
mbed_official 340:28d1f895c6fe 503 #define __HAL_IRDA_CLEAR_IT(__HANDLE__, __IT_CLEAR__) ((__HANDLE__)->Instance->ICR = (uint32_t)(__IT_CLEAR__))
mbed_official 340:28d1f895c6fe 504
mbed_official 340:28d1f895c6fe 505
mbed_official 340:28d1f895c6fe 506 /** @brief Set a specific IRDA request flag.
mbed_official 340:28d1f895c6fe 507 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 508 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 509 * UART peripheral
mbed_official 340:28d1f895c6fe 510 * @param __REQ__: specifies the request flag to set
mbed_official 340:28d1f895c6fe 511 * This parameter can be one of the following values:
mbed_official 340:28d1f895c6fe 512 * @arg IRDA_AUTOBAUD_REQUEST: Auto-Baud Rate Request
mbed_official 340:28d1f895c6fe 513 * @arg IRDA_RXDATA_FLUSH_REQUEST: Receive Data flush Request
mbed_official 340:28d1f895c6fe 514 * @arg IRDA_TXDATA_FLUSH_REQUEST: Transmit data flush Request
mbed_official 340:28d1f895c6fe 515 *
mbed_official 340:28d1f895c6fe 516 * @retval None
mbed_official 340:28d1f895c6fe 517 */
mbed_official 340:28d1f895c6fe 518 #define __HAL_IRDA_SEND_REQ(__HANDLE__, __REQ__) ((__HANDLE__)->Instance->RQR |= (uint16_t)(__REQ__))
mbed_official 340:28d1f895c6fe 519
mbed_official 340:28d1f895c6fe 520
mbed_official 340:28d1f895c6fe 521
mbed_official 340:28d1f895c6fe 522 /** @brief Enable UART/USART associated to IRDA Handle
mbed_official 340:28d1f895c6fe 523 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 524 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 525 * UART peripheral
mbed_official 340:28d1f895c6fe 526 * @retval None
mbed_official 340:28d1f895c6fe 527 */
mbed_official 340:28d1f895c6fe 528 #define __HAL_IRDA_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= USART_CR1_UE)
mbed_official 340:28d1f895c6fe 529
mbed_official 340:28d1f895c6fe 530 /** @brief Disable UART/USART associated to IRDA Handle
mbed_official 340:28d1f895c6fe 531 * @param __HANDLE__: specifies the IRDA Handle.
mbed_official 340:28d1f895c6fe 532 * The Handle Instance can be UARTx where x: 1, 2, 3, 4, 5 to select the USART or
mbed_official 340:28d1f895c6fe 533 * UART peripheral
mbed_official 340:28d1f895c6fe 534 * @retval None
mbed_official 340:28d1f895c6fe 535 */
mbed_official 340:28d1f895c6fe 536 #define __HAL_IRDA_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~USART_CR1_UE)
mbed_official 340:28d1f895c6fe 537
mbed_official 340:28d1f895c6fe 538 /** @brief Ensure that IRDA Baud rate is less or equal to maximum value
mbed_official 340:28d1f895c6fe 539 * @param __BAUDRATE__: specifies the IRDA Baudrate set by the user.
mbed_official 340:28d1f895c6fe 540 * @retval True or False
mbed_official 340:28d1f895c6fe 541 */
mbed_official 340:28d1f895c6fe 542 #define IS_IRDA_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) < 115201)
mbed_official 340:28d1f895c6fe 543
mbed_official 340:28d1f895c6fe 544 /** @brief Ensure that IRDA prescaler value is strictly larger than 0
mbed_official 340:28d1f895c6fe 545 * @param __PRESCALER__: specifies the IRDA prescaler value set by the user.
mbed_official 340:28d1f895c6fe 546 * @retval True or False
mbed_official 340:28d1f895c6fe 547 */
mbed_official 340:28d1f895c6fe 548 #define IS_IRDA_PRESCALER(__PRESCALER__) ((__PRESCALER__) > 0)
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 /* Include IRDA HAL Extension module */
mbed_official 340:28d1f895c6fe 555 #include "stm32f0xx_hal_irda_ex.h"
mbed_official 340:28d1f895c6fe 556
mbed_official 340:28d1f895c6fe 557 /* Exported functions --------------------------------------------------------*/
mbed_official 340:28d1f895c6fe 558
mbed_official 340:28d1f895c6fe 559 /** @addtogroup IRDA_Exported_Functions IRDA Exported Functions
mbed_official 340:28d1f895c6fe 560 * @{
mbed_official 340:28d1f895c6fe 561 */
mbed_official 340:28d1f895c6fe 562
mbed_official 340:28d1f895c6fe 563 /** @addtogroup IRDA_Exported_Functions_Group1 Initialization and de-initialization functions
mbed_official 340:28d1f895c6fe 564 * @{
mbed_official 340:28d1f895c6fe 565 */
mbed_official 340:28d1f895c6fe 566
mbed_official 340:28d1f895c6fe 567 /* Initialization and de-initialization functions ****************************/
mbed_official 340:28d1f895c6fe 568 HAL_StatusTypeDef HAL_IRDA_Init(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 569 HAL_StatusTypeDef HAL_IRDA_DeInit(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 570 void HAL_IRDA_MspInit(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 571 void HAL_IRDA_MspDeInit(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 572
mbed_official 340:28d1f895c6fe 573 /**
mbed_official 340:28d1f895c6fe 574 * @}
mbed_official 340:28d1f895c6fe 575 */
mbed_official 340:28d1f895c6fe 576
mbed_official 340:28d1f895c6fe 577 /** @addtogroup IRDA_Exported_Functions_Group2 IO operation functions
mbed_official 340:28d1f895c6fe 578 * @{
mbed_official 340:28d1f895c6fe 579 */
mbed_official 340:28d1f895c6fe 580
mbed_official 340:28d1f895c6fe 581 /* IO operation functions *****************************************************/
mbed_official 340:28d1f895c6fe 582 HAL_StatusTypeDef HAL_IRDA_Transmit(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 583 HAL_StatusTypeDef HAL_IRDA_Receive(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout);
mbed_official 340:28d1f895c6fe 584 HAL_StatusTypeDef HAL_IRDA_Transmit_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 585 HAL_StatusTypeDef HAL_IRDA_Receive_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 586 HAL_StatusTypeDef HAL_IRDA_Transmit_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 587 HAL_StatusTypeDef HAL_IRDA_Receive_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size);
mbed_official 340:28d1f895c6fe 588 void HAL_IRDA_IRQHandler(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 589 void HAL_IRDA_TxCpltCallback(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 590 void HAL_IRDA_RxCpltCallback(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 591 void HAL_IRDA_ErrorCallback(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 592
mbed_official 340:28d1f895c6fe 593 /**
mbed_official 340:28d1f895c6fe 594 * @}
mbed_official 340:28d1f895c6fe 595 */
mbed_official 340:28d1f895c6fe 596
mbed_official 340:28d1f895c6fe 597 /** @addtogroup IRDA_Exported_Functions_Group3
mbed_official 340:28d1f895c6fe 598 * @{
mbed_official 340:28d1f895c6fe 599 */
mbed_official 340:28d1f895c6fe 600
mbed_official 340:28d1f895c6fe 601 /* Peripheral State and Error functions ***************************************/
mbed_official 340:28d1f895c6fe 602 HAL_IRDA_StateTypeDef HAL_IRDA_GetState(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 603 uint32_t HAL_IRDA_GetError(IRDA_HandleTypeDef *hirda);
mbed_official 340:28d1f895c6fe 604
mbed_official 340:28d1f895c6fe 605 /**
mbed_official 340:28d1f895c6fe 606 * @}
mbed_official 340:28d1f895c6fe 607 */
mbed_official 340:28d1f895c6fe 608
mbed_official 340:28d1f895c6fe 609 /**
mbed_official 340:28d1f895c6fe 610 * @}
mbed_official 340:28d1f895c6fe 611 */
mbed_official 340:28d1f895c6fe 612
mbed_official 340:28d1f895c6fe 613 /**
mbed_official 340:28d1f895c6fe 614 * @}
mbed_official 340:28d1f895c6fe 615 */
mbed_official 340:28d1f895c6fe 616
mbed_official 340:28d1f895c6fe 617 /**
mbed_official 340:28d1f895c6fe 618 * @}
mbed_official 340:28d1f895c6fe 619 */
mbed_official 340:28d1f895c6fe 620
mbed_official 340:28d1f895c6fe 621 #endif /* !defined(STM32F030x6) && !defined(STM32F030x8) */
mbed_official 340:28d1f895c6fe 622
mbed_official 340:28d1f895c6fe 623 #ifdef __cplusplus
mbed_official 340:28d1f895c6fe 624 }
mbed_official 340:28d1f895c6fe 625 #endif
mbed_official 340:28d1f895c6fe 626
mbed_official 340:28d1f895c6fe 627 #endif /* __STM32F0xx_HAL_IRDA_H */
mbed_official 340:28d1f895c6fe 628
mbed_official 340:28d1f895c6fe 629 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
mbed_official 340:28d1f895c6fe 630