Soundharrajan

Fork of mbed by mbed official

Committer:
emilmont
Date:
Fri Feb 14 14:36:43 2014 +0000
Revision:
77:869cf507173a
Child:
81:7d30d6019079
Release 77 of the mbed library

Main changes:
* Add target NUCLEO_F030R8
* Add target NUCLEO_F401RE
* Add target NUCLEO_F103RB
* Add target NUCLEO_L152RE

Who changed what in which revision?

UserRevisionLine numberNew contents of line
emilmont 77:869cf507173a 1 /**
emilmont 77:869cf507173a 2 ******************************************************************************
emilmont 77:869cf507173a 3 * @file stm32l1xx_usart.h
emilmont 77:869cf507173a 4 * @author MCD Application Team
emilmont 77:869cf507173a 5 * @version V1.3.0
emilmont 77:869cf507173a 6 * @date 31-January-2014
emilmont 77:869cf507173a 7 * @brief This file contains all the functions prototypes for the USART
emilmont 77:869cf507173a 8 * firmware library.
emilmont 77:869cf507173a 9 ******************************************************************************
emilmont 77:869cf507173a 10 * @attention
emilmont 77:869cf507173a 11 *
emilmont 77:869cf507173a 12 * <h2><center>&copy; COPYRIGHT 2014 STMicroelectronics</center></h2>
emilmont 77:869cf507173a 13 *
emilmont 77:869cf507173a 14 * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
emilmont 77:869cf507173a 15 * You may not use this file except in compliance with the License.
emilmont 77:869cf507173a 16 * You may obtain a copy of the License at:
emilmont 77:869cf507173a 17 *
emilmont 77:869cf507173a 18 * http://www.st.com/software_license_agreement_liberty_v2
emilmont 77:869cf507173a 19 *
emilmont 77:869cf507173a 20 * Unless required by applicable law or agreed to in writing, software
emilmont 77:869cf507173a 21 * distributed under the License is distributed on an "AS IS" BASIS,
emilmont 77:869cf507173a 22 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
emilmont 77:869cf507173a 23 * See the License for the specific language governing permissions and
emilmont 77:869cf507173a 24 * limitations under the License.
emilmont 77:869cf507173a 25 *
emilmont 77:869cf507173a 26 ******************************************************************************
emilmont 77:869cf507173a 27 */
emilmont 77:869cf507173a 28
emilmont 77:869cf507173a 29 /* Define to prevent recursive inclusion -------------------------------------*/
emilmont 77:869cf507173a 30 #ifndef __STM32L1xx_USART_H
emilmont 77:869cf507173a 31 #define __STM32L1xx_USART_H
emilmont 77:869cf507173a 32
emilmont 77:869cf507173a 33 #ifdef __cplusplus
emilmont 77:869cf507173a 34 extern "C" {
emilmont 77:869cf507173a 35 #endif
emilmont 77:869cf507173a 36
emilmont 77:869cf507173a 37 /* Includes ------------------------------------------------------------------*/
emilmont 77:869cf507173a 38 #include "stm32l1xx.h"
emilmont 77:869cf507173a 39
emilmont 77:869cf507173a 40 /** @addtogroup STM32L1xx_StdPeriph_Driver
emilmont 77:869cf507173a 41 * @{
emilmont 77:869cf507173a 42 */
emilmont 77:869cf507173a 43
emilmont 77:869cf507173a 44 /** @addtogroup USART
emilmont 77:869cf507173a 45 * @{
emilmont 77:869cf507173a 46 */
emilmont 77:869cf507173a 47
emilmont 77:869cf507173a 48 /* Exported types ------------------------------------------------------------*/
emilmont 77:869cf507173a 49
emilmont 77:869cf507173a 50 /**
emilmont 77:869cf507173a 51 * @brief USART Init Structure definition
emilmont 77:869cf507173a 52 */
emilmont 77:869cf507173a 53
emilmont 77:869cf507173a 54 typedef struct
emilmont 77:869cf507173a 55 {
emilmont 77:869cf507173a 56 uint32_t USART_BaudRate; /*!< This member configures the USART communication baud rate.
emilmont 77:869cf507173a 57 The baud rate is computed using the following formula:
emilmont 77:869cf507173a 58 - IntegerDivider = ((PCLKx) / (8 * (OVR8+1) * (USART_InitStruct->USART_BaudRate)))
emilmont 77:869cf507173a 59 - FractionalDivider = ((IntegerDivider - ((u32) IntegerDivider)) * 8 * (OVR8+1)) + 0.5
emilmont 77:869cf507173a 60 Where OVR8 is the "oversampling by 8 mode" configuration bit in the CR1 register. */
emilmont 77:869cf507173a 61
emilmont 77:869cf507173a 62 uint16_t USART_WordLength; /*!< Specifies the number of data bits transmitted or received in a frame.
emilmont 77:869cf507173a 63 This parameter can be a value of @ref USART_Word_Length */
emilmont 77:869cf507173a 64
emilmont 77:869cf507173a 65 uint16_t USART_StopBits; /*!< Specifies the number of stop bits transmitted.
emilmont 77:869cf507173a 66 This parameter can be a value of @ref USART_Stop_Bits */
emilmont 77:869cf507173a 67
emilmont 77:869cf507173a 68 uint16_t USART_Parity; /*!< Specifies the parity mode.
emilmont 77:869cf507173a 69 This parameter can be a value of @ref USART_Parity
emilmont 77:869cf507173a 70 @note When parity is enabled, the computed parity is inserted
emilmont 77:869cf507173a 71 at the MSB position of the transmitted data (9th bit when
emilmont 77:869cf507173a 72 the word length is set to 9 data bits; 8th bit when the
emilmont 77:869cf507173a 73 word length is set to 8 data bits). */
emilmont 77:869cf507173a 74
emilmont 77:869cf507173a 75 uint16_t USART_Mode; /*!< Specifies wether the Receive or Transmit mode is enabled or disabled.
emilmont 77:869cf507173a 76 This parameter can be a value of @ref USART_Mode */
emilmont 77:869cf507173a 77
emilmont 77:869cf507173a 78 uint16_t USART_HardwareFlowControl; /*!< Specifies wether the hardware flow control mode is enabled
emilmont 77:869cf507173a 79 or disabled.
emilmont 77:869cf507173a 80 This parameter can be a value of @ref USART_Hardware_Flow_Control */
emilmont 77:869cf507173a 81 } USART_InitTypeDef;
emilmont 77:869cf507173a 82
emilmont 77:869cf507173a 83 /**
emilmont 77:869cf507173a 84 * @brief USART Clock Init Structure definition
emilmont 77:869cf507173a 85 */
emilmont 77:869cf507173a 86
emilmont 77:869cf507173a 87 typedef struct
emilmont 77:869cf507173a 88 {
emilmont 77:869cf507173a 89
emilmont 77:869cf507173a 90 uint16_t USART_Clock; /*!< Specifies whether the USART clock is enabled or disabled.
emilmont 77:869cf507173a 91 This parameter can be a value of @ref USART_Clock */
emilmont 77:869cf507173a 92
emilmont 77:869cf507173a 93 uint16_t USART_CPOL; /*!< Specifies the steady state of the serial clock.
emilmont 77:869cf507173a 94 This parameter can be a value of @ref USART_Clock_Polarity */
emilmont 77:869cf507173a 95
emilmont 77:869cf507173a 96 uint16_t USART_CPHA; /*!< Specifies the clock transition on which the bit capture is made.
emilmont 77:869cf507173a 97 This parameter can be a value of @ref USART_Clock_Phase */
emilmont 77:869cf507173a 98
emilmont 77:869cf507173a 99 uint16_t USART_LastBit; /*!< Specifies whether the clock pulse corresponding to the last transmitted
emilmont 77:869cf507173a 100 data bit (MSB) has to be output on the SCLK pin in synchronous mode.
emilmont 77:869cf507173a 101 This parameter can be a value of @ref USART_Last_Bit */
emilmont 77:869cf507173a 102 } USART_ClockInitTypeDef;
emilmont 77:869cf507173a 103
emilmont 77:869cf507173a 104 /* Exported constants --------------------------------------------------------*/
emilmont 77:869cf507173a 105
emilmont 77:869cf507173a 106 /** @defgroup USART_Exported_Constants
emilmont 77:869cf507173a 107 * @{
emilmont 77:869cf507173a 108 */
emilmont 77:869cf507173a 109
emilmont 77:869cf507173a 110 #define IS_USART_ALL_PERIPH(PERIPH) (((PERIPH) == USART1) || \
emilmont 77:869cf507173a 111 ((PERIPH) == USART2) || \
emilmont 77:869cf507173a 112 ((PERIPH) == USART3) || \
emilmont 77:869cf507173a 113 ((PERIPH) == UART4) || \
emilmont 77:869cf507173a 114 ((PERIPH) == UART5))
emilmont 77:869cf507173a 115
emilmont 77:869cf507173a 116 #define IS_USART_123_PERIPH(PERIPH) (((PERIPH) == USART1) || \
emilmont 77:869cf507173a 117 ((PERIPH) == USART2) || \
emilmont 77:869cf507173a 118 ((PERIPH) == USART3))
emilmont 77:869cf507173a 119
emilmont 77:869cf507173a 120 /** @defgroup USART_Word_Length
emilmont 77:869cf507173a 121 * @{
emilmont 77:869cf507173a 122 */
emilmont 77:869cf507173a 123
emilmont 77:869cf507173a 124 #define USART_WordLength_8b ((uint16_t)0x0000)
emilmont 77:869cf507173a 125 #define USART_WordLength_9b ((uint16_t)0x1000)
emilmont 77:869cf507173a 126
emilmont 77:869cf507173a 127 #define IS_USART_WORD_LENGTH(LENGTH) (((LENGTH) == USART_WordLength_8b) || \
emilmont 77:869cf507173a 128 ((LENGTH) == USART_WordLength_9b))
emilmont 77:869cf507173a 129 /**
emilmont 77:869cf507173a 130 * @}
emilmont 77:869cf507173a 131 */
emilmont 77:869cf507173a 132
emilmont 77:869cf507173a 133 /** @defgroup USART_Stop_Bits
emilmont 77:869cf507173a 134 * @{
emilmont 77:869cf507173a 135 */
emilmont 77:869cf507173a 136
emilmont 77:869cf507173a 137 #define USART_StopBits_1 ((uint16_t)0x0000)
emilmont 77:869cf507173a 138 #define USART_StopBits_0_5 ((uint16_t)0x1000)
emilmont 77:869cf507173a 139 #define USART_StopBits_2 ((uint16_t)0x2000)
emilmont 77:869cf507173a 140 #define USART_StopBits_1_5 ((uint16_t)0x3000)
emilmont 77:869cf507173a 141 #define IS_USART_STOPBITS(STOPBITS) (((STOPBITS) == USART_StopBits_1) || \
emilmont 77:869cf507173a 142 ((STOPBITS) == USART_StopBits_0_5) || \
emilmont 77:869cf507173a 143 ((STOPBITS) == USART_StopBits_2) || \
emilmont 77:869cf507173a 144 ((STOPBITS) == USART_StopBits_1_5))
emilmont 77:869cf507173a 145 /**
emilmont 77:869cf507173a 146 * @}
emilmont 77:869cf507173a 147 */
emilmont 77:869cf507173a 148
emilmont 77:869cf507173a 149 /** @defgroup USART_Parity
emilmont 77:869cf507173a 150 * @{
emilmont 77:869cf507173a 151 */
emilmont 77:869cf507173a 152
emilmont 77:869cf507173a 153 #define USART_Parity_No ((uint16_t)0x0000)
emilmont 77:869cf507173a 154 #define USART_Parity_Even ((uint16_t)0x0400)
emilmont 77:869cf507173a 155 #define USART_Parity_Odd ((uint16_t)0x0600)
emilmont 77:869cf507173a 156 #define IS_USART_PARITY(PARITY) (((PARITY) == USART_Parity_No) || \
emilmont 77:869cf507173a 157 ((PARITY) == USART_Parity_Even) || \
emilmont 77:869cf507173a 158 ((PARITY) == USART_Parity_Odd))
emilmont 77:869cf507173a 159 /**
emilmont 77:869cf507173a 160 * @}
emilmont 77:869cf507173a 161 */
emilmont 77:869cf507173a 162
emilmont 77:869cf507173a 163 /** @defgroup USART_Mode
emilmont 77:869cf507173a 164 * @{
emilmont 77:869cf507173a 165 */
emilmont 77:869cf507173a 166
emilmont 77:869cf507173a 167 #define USART_Mode_Rx ((uint16_t)0x0004)
emilmont 77:869cf507173a 168 #define USART_Mode_Tx ((uint16_t)0x0008)
emilmont 77:869cf507173a 169 #define IS_USART_MODE(MODE) ((((MODE) & (uint16_t)0xFFF3) == 0x00) && ((MODE) != (uint16_t)0x00))
emilmont 77:869cf507173a 170 /**
emilmont 77:869cf507173a 171 * @}
emilmont 77:869cf507173a 172 */
emilmont 77:869cf507173a 173
emilmont 77:869cf507173a 174 /** @defgroup USART_Hardware_Flow_Control
emilmont 77:869cf507173a 175 * @{
emilmont 77:869cf507173a 176 */
emilmont 77:869cf507173a 177 #define USART_HardwareFlowControl_None ((uint16_t)0x0000)
emilmont 77:869cf507173a 178 #define USART_HardwareFlowControl_RTS ((uint16_t)0x0100)
emilmont 77:869cf507173a 179 #define USART_HardwareFlowControl_CTS ((uint16_t)0x0200)
emilmont 77:869cf507173a 180 #define USART_HardwareFlowControl_RTS_CTS ((uint16_t)0x0300)
emilmont 77:869cf507173a 181 #define IS_USART_HARDWARE_FLOW_CONTROL(CONTROL)\
emilmont 77:869cf507173a 182 (((CONTROL) == USART_HardwareFlowControl_None) || \
emilmont 77:869cf507173a 183 ((CONTROL) == USART_HardwareFlowControl_RTS) || \
emilmont 77:869cf507173a 184 ((CONTROL) == USART_HardwareFlowControl_CTS) || \
emilmont 77:869cf507173a 185 ((CONTROL) == USART_HardwareFlowControl_RTS_CTS))
emilmont 77:869cf507173a 186 /**
emilmont 77:869cf507173a 187 * @}
emilmont 77:869cf507173a 188 */
emilmont 77:869cf507173a 189
emilmont 77:869cf507173a 190 /** @defgroup USART_Clock
emilmont 77:869cf507173a 191 * @{
emilmont 77:869cf507173a 192 */
emilmont 77:869cf507173a 193 #define USART_Clock_Disable ((uint16_t)0x0000)
emilmont 77:869cf507173a 194 #define USART_Clock_Enable ((uint16_t)0x0800)
emilmont 77:869cf507173a 195 #define IS_USART_CLOCK(CLOCK) (((CLOCK) == USART_Clock_Disable) || \
emilmont 77:869cf507173a 196 ((CLOCK) == USART_Clock_Enable))
emilmont 77:869cf507173a 197 /**
emilmont 77:869cf507173a 198 * @}
emilmont 77:869cf507173a 199 */
emilmont 77:869cf507173a 200
emilmont 77:869cf507173a 201 /** @defgroup USART_Clock_Polarity
emilmont 77:869cf507173a 202 * @{
emilmont 77:869cf507173a 203 */
emilmont 77:869cf507173a 204
emilmont 77:869cf507173a 205 #define USART_CPOL_Low ((uint16_t)0x0000)
emilmont 77:869cf507173a 206 #define USART_CPOL_High ((uint16_t)0x0400)
emilmont 77:869cf507173a 207 #define IS_USART_CPOL(CPOL) (((CPOL) == USART_CPOL_Low) || ((CPOL) == USART_CPOL_High))
emilmont 77:869cf507173a 208
emilmont 77:869cf507173a 209 /**
emilmont 77:869cf507173a 210 * @}
emilmont 77:869cf507173a 211 */
emilmont 77:869cf507173a 212
emilmont 77:869cf507173a 213 /** @defgroup USART_Clock_Phase
emilmont 77:869cf507173a 214 * @{
emilmont 77:869cf507173a 215 */
emilmont 77:869cf507173a 216
emilmont 77:869cf507173a 217 #define USART_CPHA_1Edge ((uint16_t)0x0000)
emilmont 77:869cf507173a 218 #define USART_CPHA_2Edge ((uint16_t)0x0200)
emilmont 77:869cf507173a 219 #define IS_USART_CPHA(CPHA) (((CPHA) == USART_CPHA_1Edge) || ((CPHA) == USART_CPHA_2Edge))
emilmont 77:869cf507173a 220
emilmont 77:869cf507173a 221 /**
emilmont 77:869cf507173a 222 * @}
emilmont 77:869cf507173a 223 */
emilmont 77:869cf507173a 224
emilmont 77:869cf507173a 225 /** @defgroup USART_Last_Bit
emilmont 77:869cf507173a 226 * @{
emilmont 77:869cf507173a 227 */
emilmont 77:869cf507173a 228
emilmont 77:869cf507173a 229 #define USART_LastBit_Disable ((uint16_t)0x0000)
emilmont 77:869cf507173a 230 #define USART_LastBit_Enable ((uint16_t)0x0100)
emilmont 77:869cf507173a 231 #define IS_USART_LASTBIT(LASTBIT) (((LASTBIT) == USART_LastBit_Disable) || \
emilmont 77:869cf507173a 232 ((LASTBIT) == USART_LastBit_Enable))
emilmont 77:869cf507173a 233 /**
emilmont 77:869cf507173a 234 * @}
emilmont 77:869cf507173a 235 */
emilmont 77:869cf507173a 236
emilmont 77:869cf507173a 237 /** @defgroup USART_Interrupt_definition
emilmont 77:869cf507173a 238 * @{
emilmont 77:869cf507173a 239 */
emilmont 77:869cf507173a 240
emilmont 77:869cf507173a 241 #define USART_IT_PE ((uint16_t)0x0028)
emilmont 77:869cf507173a 242 #define USART_IT_TXE ((uint16_t)0x0727)
emilmont 77:869cf507173a 243 #define USART_IT_TC ((uint16_t)0x0626)
emilmont 77:869cf507173a 244 #define USART_IT_RXNE ((uint16_t)0x0525)
emilmont 77:869cf507173a 245 #define USART_IT_IDLE ((uint16_t)0x0424)
emilmont 77:869cf507173a 246 #define USART_IT_LBD ((uint16_t)0x0846)
emilmont 77:869cf507173a 247 #define USART_IT_ORE_RX ((uint16_t)0x0325) /* In case interrupt is generated if the RXNEIE bit is set */
emilmont 77:869cf507173a 248 #define USART_IT_CTS ((uint16_t)0x096A)
emilmont 77:869cf507173a 249 #define USART_IT_ERR ((uint16_t)0x0060)
emilmont 77:869cf507173a 250 #define USART_IT_ORE_ER ((uint16_t)0x0360) /* In case interrupt is generated if the EIE bit is set */
emilmont 77:869cf507173a 251 #define USART_IT_NE ((uint16_t)0x0260)
emilmont 77:869cf507173a 252 #define USART_IT_FE ((uint16_t)0x0160)
emilmont 77:869cf507173a 253
emilmont 77:869cf507173a 254 /** @defgroup USART_Legacy
emilmont 77:869cf507173a 255 * @{
emilmont 77:869cf507173a 256 */
emilmont 77:869cf507173a 257 #define USART_IT_ORE USART_IT_ORE_ER
emilmont 77:869cf507173a 258 /**
emilmont 77:869cf507173a 259 * @}
emilmont 77:869cf507173a 260 */
emilmont 77:869cf507173a 261
emilmont 77:869cf507173a 262 #define IS_USART_CONFIG_IT(IT) (((IT) == USART_IT_PE) || ((IT) == USART_IT_TXE) || \
emilmont 77:869cf507173a 263 ((IT) == USART_IT_TC) || ((IT) == USART_IT_RXNE) || \
emilmont 77:869cf507173a 264 ((IT) == USART_IT_IDLE) || ((IT) == USART_IT_LBD) || \
emilmont 77:869cf507173a 265 ((IT) == USART_IT_CTS) || ((IT) == USART_IT_ERR))
emilmont 77:869cf507173a 266 #define IS_USART_GET_IT(IT) (((IT) == USART_IT_PE) || ((IT) == USART_IT_TXE) || \
emilmont 77:869cf507173a 267 ((IT) == USART_IT_TC) || ((IT) == USART_IT_RXNE) || \
emilmont 77:869cf507173a 268 ((IT) == USART_IT_IDLE) || ((IT) == USART_IT_LBD) || \
emilmont 77:869cf507173a 269 ((IT) == USART_IT_CTS) || ((IT) == USART_IT_ORE_RX) || \
emilmont 77:869cf507173a 270 ((IT) == USART_IT_ORE_ER) || ((IT) == USART_IT_NE) || \
emilmont 77:869cf507173a 271 ((IT) == USART_IT_FE))
emilmont 77:869cf507173a 272 #define IS_USART_CLEAR_IT(IT) (((IT) == USART_IT_TC) || ((IT) == USART_IT_RXNE) || \
emilmont 77:869cf507173a 273 ((IT) == USART_IT_LBD) || ((IT) == USART_IT_CTS))
emilmont 77:869cf507173a 274 /**
emilmont 77:869cf507173a 275 * @}
emilmont 77:869cf507173a 276 */
emilmont 77:869cf507173a 277
emilmont 77:869cf507173a 278 /** @defgroup USART_DMA_Requests
emilmont 77:869cf507173a 279 * @{
emilmont 77:869cf507173a 280 */
emilmont 77:869cf507173a 281
emilmont 77:869cf507173a 282 #define USART_DMAReq_Tx ((uint16_t)0x0080)
emilmont 77:869cf507173a 283 #define USART_DMAReq_Rx ((uint16_t)0x0040)
emilmont 77:869cf507173a 284 #define IS_USART_DMAREQ(DMAREQ) ((((DMAREQ) & (uint16_t)0xFF3F) == 0x00) && ((DMAREQ) != (uint16_t)0x00))
emilmont 77:869cf507173a 285
emilmont 77:869cf507173a 286 /**
emilmont 77:869cf507173a 287 * @}
emilmont 77:869cf507173a 288 */
emilmont 77:869cf507173a 289
emilmont 77:869cf507173a 290 /** @defgroup USART_WakeUp_methods
emilmont 77:869cf507173a 291 * @{
emilmont 77:869cf507173a 292 */
emilmont 77:869cf507173a 293
emilmont 77:869cf507173a 294 #define USART_WakeUp_IdleLine ((uint16_t)0x0000)
emilmont 77:869cf507173a 295 #define USART_WakeUp_AddressMark ((uint16_t)0x0800)
emilmont 77:869cf507173a 296 #define IS_USART_WAKEUP(WAKEUP) (((WAKEUP) == USART_WakeUp_IdleLine) || \
emilmont 77:869cf507173a 297 ((WAKEUP) == USART_WakeUp_AddressMark))
emilmont 77:869cf507173a 298 /**
emilmont 77:869cf507173a 299 * @}
emilmont 77:869cf507173a 300 */
emilmont 77:869cf507173a 301
emilmont 77:869cf507173a 302 /** @defgroup USART_LIN_Break_Detection_Length
emilmont 77:869cf507173a 303 * @{
emilmont 77:869cf507173a 304 */
emilmont 77:869cf507173a 305
emilmont 77:869cf507173a 306 #define USART_LINBreakDetectLength_10b ((uint16_t)0x0000)
emilmont 77:869cf507173a 307 #define USART_LINBreakDetectLength_11b ((uint16_t)0x0020)
emilmont 77:869cf507173a 308 #define IS_USART_LIN_BREAK_DETECT_LENGTH(LENGTH) \
emilmont 77:869cf507173a 309 (((LENGTH) == USART_LINBreakDetectLength_10b) || \
emilmont 77:869cf507173a 310 ((LENGTH) == USART_LINBreakDetectLength_11b))
emilmont 77:869cf507173a 311 /**
emilmont 77:869cf507173a 312 * @}
emilmont 77:869cf507173a 313 */
emilmont 77:869cf507173a 314
emilmont 77:869cf507173a 315 /** @defgroup USART_IrDA_Low_Power
emilmont 77:869cf507173a 316 * @{
emilmont 77:869cf507173a 317 */
emilmont 77:869cf507173a 318
emilmont 77:869cf507173a 319 #define USART_IrDAMode_LowPower ((uint16_t)0x0004)
emilmont 77:869cf507173a 320 #define USART_IrDAMode_Normal ((uint16_t)0x0000)
emilmont 77:869cf507173a 321 #define IS_USART_IRDA_MODE(MODE) (((MODE) == USART_IrDAMode_LowPower) || \
emilmont 77:869cf507173a 322 ((MODE) == USART_IrDAMode_Normal))
emilmont 77:869cf507173a 323 /**
emilmont 77:869cf507173a 324 * @}
emilmont 77:869cf507173a 325 */
emilmont 77:869cf507173a 326
emilmont 77:869cf507173a 327 /** @defgroup USART_Flags
emilmont 77:869cf507173a 328 * @{
emilmont 77:869cf507173a 329 */
emilmont 77:869cf507173a 330
emilmont 77:869cf507173a 331 #define USART_FLAG_CTS ((uint16_t)0x0200)
emilmont 77:869cf507173a 332 #define USART_FLAG_LBD ((uint16_t)0x0100)
emilmont 77:869cf507173a 333 #define USART_FLAG_TXE ((uint16_t)0x0080)
emilmont 77:869cf507173a 334 #define USART_FLAG_TC ((uint16_t)0x0040)
emilmont 77:869cf507173a 335 #define USART_FLAG_RXNE ((uint16_t)0x0020)
emilmont 77:869cf507173a 336 #define USART_FLAG_IDLE ((uint16_t)0x0010)
emilmont 77:869cf507173a 337 #define USART_FLAG_ORE ((uint16_t)0x0008)
emilmont 77:869cf507173a 338 #define USART_FLAG_NE ((uint16_t)0x0004)
emilmont 77:869cf507173a 339 #define USART_FLAG_FE ((uint16_t)0x0002)
emilmont 77:869cf507173a 340 #define USART_FLAG_PE ((uint16_t)0x0001)
emilmont 77:869cf507173a 341 #define IS_USART_FLAG(FLAG) (((FLAG) == USART_FLAG_PE) || ((FLAG) == USART_FLAG_TXE) || \
emilmont 77:869cf507173a 342 ((FLAG) == USART_FLAG_TC) || ((FLAG) == USART_FLAG_RXNE) || \
emilmont 77:869cf507173a 343 ((FLAG) == USART_FLAG_IDLE) || ((FLAG) == USART_FLAG_LBD) || \
emilmont 77:869cf507173a 344 ((FLAG) == USART_FLAG_CTS) || ((FLAG) == USART_FLAG_ORE) || \
emilmont 77:869cf507173a 345 ((FLAG) == USART_FLAG_NE) || ((FLAG) == USART_FLAG_FE))
emilmont 77:869cf507173a 346
emilmont 77:869cf507173a 347 #define IS_USART_CLEAR_FLAG(FLAG) ((((FLAG) & (uint16_t)0xFC9F) == 0x00) && ((FLAG) != (uint16_t)0x00))
emilmont 77:869cf507173a 348
emilmont 77:869cf507173a 349 #define IS_USART_BAUDRATE(BAUDRATE) (((BAUDRATE) > 0) && ((BAUDRATE) < 0x003D0901))
emilmont 77:869cf507173a 350 #define IS_USART_ADDRESS(ADDRESS) ((ADDRESS) <= 0xF)
emilmont 77:869cf507173a 351 #define IS_USART_DATA(DATA) ((DATA) <= 0x1FF)
emilmont 77:869cf507173a 352
emilmont 77:869cf507173a 353 /**
emilmont 77:869cf507173a 354 * @}
emilmont 77:869cf507173a 355 */
emilmont 77:869cf507173a 356
emilmont 77:869cf507173a 357 /**
emilmont 77:869cf507173a 358 * @}
emilmont 77:869cf507173a 359 */
emilmont 77:869cf507173a 360
emilmont 77:869cf507173a 361 /* Exported macro ------------------------------------------------------------*/
emilmont 77:869cf507173a 362 /* Exported functions ------------------------------------------------------- */
emilmont 77:869cf507173a 363
emilmont 77:869cf507173a 364 /* Function used to set the USART configuration to the default reset state ***/
emilmont 77:869cf507173a 365 void USART_DeInit(USART_TypeDef* USARTx);
emilmont 77:869cf507173a 366
emilmont 77:869cf507173a 367 /* Initialization and Configuration functions *********************************/
emilmont 77:869cf507173a 368 void USART_Init(USART_TypeDef* USARTx, USART_InitTypeDef* USART_InitStruct);
emilmont 77:869cf507173a 369 void USART_StructInit(USART_InitTypeDef* USART_InitStruct);
emilmont 77:869cf507173a 370 void USART_ClockInit(USART_TypeDef* USARTx, USART_ClockInitTypeDef* USART_ClockInitStruct);
emilmont 77:869cf507173a 371 void USART_ClockStructInit(USART_ClockInitTypeDef* USART_ClockInitStruct);
emilmont 77:869cf507173a 372 void USART_Cmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 373 void USART_SetPrescaler(USART_TypeDef* USARTx, uint8_t USART_Prescaler);
emilmont 77:869cf507173a 374 void USART_OverSampling8Cmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 375 void USART_OneBitMethodCmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 376
emilmont 77:869cf507173a 377 /* Data transfers functions ***************************************************/
emilmont 77:869cf507173a 378 void USART_SendData(USART_TypeDef* USARTx, uint16_t Data);
emilmont 77:869cf507173a 379 uint16_t USART_ReceiveData(USART_TypeDef* USARTx);
emilmont 77:869cf507173a 380
emilmont 77:869cf507173a 381 /* Multi-Processor Communication functions ************************************/
emilmont 77:869cf507173a 382 void USART_SetAddress(USART_TypeDef* USARTx, uint8_t USART_Address);
emilmont 77:869cf507173a 383 void USART_WakeUpConfig(USART_TypeDef* USARTx, uint16_t USART_WakeUp);
emilmont 77:869cf507173a 384 void USART_ReceiverWakeUpCmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 385
emilmont 77:869cf507173a 386 /* LIN mode functions *********************************************************/
emilmont 77:869cf507173a 387 void USART_LINBreakDetectLengthConfig(USART_TypeDef* USARTx, uint16_t USART_LINBreakDetectLength);
emilmont 77:869cf507173a 388 void USART_LINCmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 389 void USART_SendBreak(USART_TypeDef* USARTx);
emilmont 77:869cf507173a 390
emilmont 77:869cf507173a 391 /* Half-duplex mode function **************************************************/
emilmont 77:869cf507173a 392 void USART_HalfDuplexCmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 393
emilmont 77:869cf507173a 394 /* Smartcard mode functions ***************************************************/
emilmont 77:869cf507173a 395 void USART_SmartCardCmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 396 void USART_SmartCardNACKCmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 397 void USART_SetGuardTime(USART_TypeDef* USARTx, uint8_t USART_GuardTime);
emilmont 77:869cf507173a 398
emilmont 77:869cf507173a 399 /* IrDA mode functions ********************************************************/
emilmont 77:869cf507173a 400 void USART_IrDAConfig(USART_TypeDef* USARTx, uint16_t USART_IrDAMode);
emilmont 77:869cf507173a 401 void USART_IrDACmd(USART_TypeDef* USARTx, FunctionalState NewState);
emilmont 77:869cf507173a 402
emilmont 77:869cf507173a 403 /* DMA transfers management functions *****************************************/
emilmont 77:869cf507173a 404 void USART_DMACmd(USART_TypeDef* USARTx, uint16_t USART_DMAReq, FunctionalState NewState);
emilmont 77:869cf507173a 405
emilmont 77:869cf507173a 406 /* Interrupts and flags management functions **********************************/
emilmont 77:869cf507173a 407 void USART_ITConfig(USART_TypeDef* USARTx, uint16_t USART_IT, FunctionalState NewState);
emilmont 77:869cf507173a 408 FlagStatus USART_GetFlagStatus(USART_TypeDef* USARTx, uint16_t USART_FLAG);
emilmont 77:869cf507173a 409 void USART_ClearFlag(USART_TypeDef* USARTx, uint16_t USART_FLAG);
emilmont 77:869cf507173a 410 ITStatus USART_GetITStatus(USART_TypeDef* USARTx, uint16_t USART_IT);
emilmont 77:869cf507173a 411 void USART_ClearITPendingBit(USART_TypeDef* USARTx, uint16_t USART_IT);
emilmont 77:869cf507173a 412
emilmont 77:869cf507173a 413 #ifdef __cplusplus
emilmont 77:869cf507173a 414 }
emilmont 77:869cf507173a 415 #endif
emilmont 77:869cf507173a 416
emilmont 77:869cf507173a 417 #endif /* __STM32L1xx_USART_H */
emilmont 77:869cf507173a 418
emilmont 77:869cf507173a 419 /**
emilmont 77:869cf507173a 420 * @}
emilmont 77:869cf507173a 421 */
emilmont 77:869cf507173a 422
emilmont 77:869cf507173a 423 /**
emilmont 77:869cf507173a 424 * @}
emilmont 77:869cf507173a 425 */
emilmont 77:869cf507173a 426
emilmont 77:869cf507173a 427 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/