my fork

Dependents:   Nucleo_blueNRG

Fork of mbed by mbed official

Committer:
filartrix
Date:
Wed Apr 08 14:12:53 2015 +0000
Revision:
97:4298809c7c9e
Parent:
93:e188a91d3eaa
First reale BlueNRG module for nucleo 401 board

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bogdanm 85:024bf7f99721 1 /**
bogdanm 85:024bf7f99721 2 ******************************************************************************
bogdanm 85:024bf7f99721 3 * @file stm32f0xx_hal_irda_ex.h
bogdanm 85:024bf7f99721 4 * @author MCD Application Team
Kojto 93:e188a91d3eaa 5 * @version V1.2.0
Kojto 93:e188a91d3eaa 6 * @date 11-December-2014
bogdanm 85:024bf7f99721 7 * @brief Header file of IRDA HAL Extension module.
bogdanm 85:024bf7f99721 8 ******************************************************************************
bogdanm 85:024bf7f99721 9 * @attention
bogdanm 85:024bf7f99721 10 *
bogdanm 85:024bf7f99721 11 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
bogdanm 85:024bf7f99721 12 *
bogdanm 85:024bf7f99721 13 * Redistribution and use in source and binary forms, with or without modification,
bogdanm 85:024bf7f99721 14 * are permitted provided that the following conditions are met:
bogdanm 85:024bf7f99721 15 * 1. Redistributions of source code must retain the above copyright notice,
bogdanm 85:024bf7f99721 16 * this list of conditions and the following disclaimer.
bogdanm 85:024bf7f99721 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
bogdanm 85:024bf7f99721 18 * this list of conditions and the following disclaimer in the documentation
bogdanm 85:024bf7f99721 19 * and/or other materials provided with the distribution.
bogdanm 85:024bf7f99721 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
bogdanm 85:024bf7f99721 21 * may be used to endorse or promote products derived from this software
bogdanm 85:024bf7f99721 22 * without specific prior written permission.
bogdanm 85:024bf7f99721 23 *
bogdanm 85:024bf7f99721 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
bogdanm 85:024bf7f99721 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
bogdanm 85:024bf7f99721 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
bogdanm 85:024bf7f99721 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
bogdanm 85:024bf7f99721 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
bogdanm 85:024bf7f99721 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
bogdanm 85:024bf7f99721 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
bogdanm 85:024bf7f99721 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
bogdanm 85:024bf7f99721 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
bogdanm 85:024bf7f99721 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
bogdanm 85:024bf7f99721 34 *
bogdanm 85:024bf7f99721 35 ******************************************************************************
bogdanm 85:024bf7f99721 36 */
bogdanm 85:024bf7f99721 37
bogdanm 85:024bf7f99721 38 /* Define to prevent recursive inclusion -------------------------------------*/
bogdanm 85:024bf7f99721 39 #ifndef __STM32F0xx_HAL_IRDA_EX_H
bogdanm 85:024bf7f99721 40 #define __STM32F0xx_HAL_IRDA_EX_H
bogdanm 85:024bf7f99721 41
bogdanm 85:024bf7f99721 42 #ifdef __cplusplus
bogdanm 85:024bf7f99721 43 extern "C" {
bogdanm 85:024bf7f99721 44 #endif
bogdanm 85:024bf7f99721 45
Kojto 93:e188a91d3eaa 46 #if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC)
bogdanm 85:024bf7f99721 47
bogdanm 85:024bf7f99721 48 /* Includes ------------------------------------------------------------------*/
bogdanm 85:024bf7f99721 49 #include "stm32f0xx_hal_def.h"
bogdanm 85:024bf7f99721 50
bogdanm 85:024bf7f99721 51 /** @addtogroup STM32F0xx_HAL_Driver
bogdanm 85:024bf7f99721 52 * @{
bogdanm 85:024bf7f99721 53 */
bogdanm 85:024bf7f99721 54
bogdanm 92:4fc01daae5a5 55 /** @addtogroup IRDAEx IRDAEx Extended HAL module driver
bogdanm 85:024bf7f99721 56 * @{
bogdanm 85:024bf7f99721 57 */
bogdanm 85:024bf7f99721 58
bogdanm 85:024bf7f99721 59 /* Exported types ------------------------------------------------------------*/
bogdanm 85:024bf7f99721 60 /* Exported constants --------------------------------------------------------*/
bogdanm 92:4fc01daae5a5 61 /** @defgroup IRDAEx_Exported_Constants IRDAEx Exported Constants
bogdanm 85:024bf7f99721 62 * @{
bogdanm 85:024bf7f99721 63 */
bogdanm 85:024bf7f99721 64
bogdanm 85:024bf7f99721 65 /** @defgroup IRDAEx_Word_Length IRDA Word Length
bogdanm 85:024bf7f99721 66 * @{
bogdanm 85:024bf7f99721 67 */
bogdanm 85:024bf7f99721 68 #if defined (STM32F042x6) || defined (STM32F048xx) || \
bogdanm 92:4fc01daae5a5 69 defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \
bogdanm 92:4fc01daae5a5 70 defined (STM32F091xC) || defined (STM32F098xx)
bogdanm 85:024bf7f99721 71 #define IRDA_WORDLENGTH_7B ((uint32_t)USART_CR1_M1)
bogdanm 85:024bf7f99721 72 #define IRDA_WORDLENGTH_8B ((uint32_t)0x00000000)
bogdanm 85:024bf7f99721 73 #define IRDA_WORDLENGTH_9B ((uint32_t)USART_CR1_M0)
bogdanm 85:024bf7f99721 74 #define IS_IRDA_WORD_LENGTH(LENGTH) (((LENGTH) == IRDA_WORDLENGTH_7B) || \
bogdanm 85:024bf7f99721 75 ((LENGTH) == IRDA_WORDLENGTH_8B) || \
bogdanm 85:024bf7f99721 76 ((LENGTH) == IRDA_WORDLENGTH_9B))
bogdanm 85:024bf7f99721 77 #else
bogdanm 85:024bf7f99721 78 #define IRDA_WORDLENGTH_8B ((uint32_t)0x00000000)
bogdanm 85:024bf7f99721 79 #define IRDA_WORDLENGTH_9B ((uint32_t)USART_CR1_M)
bogdanm 85:024bf7f99721 80 #define IS_IRDA_WORD_LENGTH(LENGTH) (((LENGTH) == IRDA_WORDLENGTH_8B) || \
bogdanm 85:024bf7f99721 81 ((LENGTH) == IRDA_WORDLENGTH_9B))
bogdanm 85:024bf7f99721 82 #endif /* defined (STM32F042x6) || defined (STM32F048xx) || \
bogdanm 92:4fc01daae5a5 83 defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \
bogdanm 92:4fc01daae5a5 84 defined (STM32F091xC) || defined (STM32F098xx)*/
bogdanm 85:024bf7f99721 85 /**
bogdanm 85:024bf7f99721 86 * @}
bogdanm 85:024bf7f99721 87 */
bogdanm 85:024bf7f99721 88
bogdanm 85:024bf7f99721 89
bogdanm 85:024bf7f99721 90 /**
bogdanm 85:024bf7f99721 91 * @}
bogdanm 85:024bf7f99721 92 */
bogdanm 85:024bf7f99721 93
bogdanm 85:024bf7f99721 94 /* Exported macros -----------------------------------------------------------*/
bogdanm 85:024bf7f99721 95
bogdanm 92:4fc01daae5a5 96 /** @defgroup IRDAEx_Exported_Macros IRDAEx Exported Macros
bogdanm 85:024bf7f99721 97 * @{
bogdanm 85:024bf7f99721 98 */
bogdanm 85:024bf7f99721 99
bogdanm 92:4fc01daae5a5 100 /** @brief Reports the IRDA clock source.
bogdanm 92:4fc01daae5a5 101 * @param __HANDLE__: specifies the IRDA Handle
bogdanm 92:4fc01daae5a5 102 * @param __CLOCKSOURCE__ : output variable
bogdanm 92:4fc01daae5a5 103 * @retval IRDA clocking source, written in __CLOCKSOURCE__.
bogdanm 92:4fc01daae5a5 104 */
bogdanm 92:4fc01daae5a5 105
Kojto 93:e188a91d3eaa 106 #if defined(STM32F031x6) || defined(STM32F038xx)
bogdanm 92:4fc01daae5a5 107 #define __HAL_IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
bogdanm 92:4fc01daae5a5 108 do { \
bogdanm 92:4fc01daae5a5 109 switch(__HAL_RCC_GET_USART1_SOURCE()) \
bogdanm 92:4fc01daae5a5 110 { \
bogdanm 92:4fc01daae5a5 111 case RCC_USART1CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 112 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 113 break; \
bogdanm 92:4fc01daae5a5 114 case RCC_USART1CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 115 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 116 break; \
bogdanm 92:4fc01daae5a5 117 case RCC_USART1CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 118 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 119 break; \
bogdanm 92:4fc01daae5a5 120 case RCC_USART1CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 121 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 122 break; \
bogdanm 92:4fc01daae5a5 123 default: \
bogdanm 92:4fc01daae5a5 124 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 125 break; \
bogdanm 92:4fc01daae5a5 126 } \
bogdanm 92:4fc01daae5a5 127 } while(0)
Kojto 93:e188a91d3eaa 128 #elif defined (STM32F042x6) || defined (STM32F048xx) || \
bogdanm 92:4fc01daae5a5 129 defined (STM32F051x8) || defined (STM32F058xx)
bogdanm 92:4fc01daae5a5 130 #define __HAL_IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
bogdanm 92:4fc01daae5a5 131 do { \
bogdanm 92:4fc01daae5a5 132 if((__HANDLE__)->Instance == USART1) \
bogdanm 92:4fc01daae5a5 133 { \
bogdanm 92:4fc01daae5a5 134 switch(__HAL_RCC_GET_USART1_SOURCE()) \
bogdanm 92:4fc01daae5a5 135 { \
bogdanm 92:4fc01daae5a5 136 case RCC_USART1CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 137 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 138 break; \
bogdanm 92:4fc01daae5a5 139 case RCC_USART1CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 140 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 141 break; \
bogdanm 92:4fc01daae5a5 142 case RCC_USART1CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 143 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 144 break; \
bogdanm 92:4fc01daae5a5 145 case RCC_USART1CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 146 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 147 break; \
bogdanm 92:4fc01daae5a5 148 default: \
bogdanm 92:4fc01daae5a5 149 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 150 break; \
bogdanm 92:4fc01daae5a5 151 } \
bogdanm 92:4fc01daae5a5 152 } \
bogdanm 92:4fc01daae5a5 153 else if((__HANDLE__)->Instance == USART2) \
bogdanm 92:4fc01daae5a5 154 { \
bogdanm 92:4fc01daae5a5 155 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 156 } \
bogdanm 92:4fc01daae5a5 157 else \
bogdanm 92:4fc01daae5a5 158 { \
bogdanm 92:4fc01daae5a5 159 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 160 } \
bogdanm 92:4fc01daae5a5 161 } while(0)
bogdanm 92:4fc01daae5a5 162 #elif defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)
bogdanm 92:4fc01daae5a5 163 #define __HAL_IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
bogdanm 92:4fc01daae5a5 164 do { \
bogdanm 92:4fc01daae5a5 165 if((__HANDLE__)->Instance == USART1) \
bogdanm 92:4fc01daae5a5 166 { \
bogdanm 92:4fc01daae5a5 167 switch(__HAL_RCC_GET_USART1_SOURCE()) \
bogdanm 92:4fc01daae5a5 168 { \
bogdanm 92:4fc01daae5a5 169 case RCC_USART1CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 170 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 171 break; \
bogdanm 92:4fc01daae5a5 172 case RCC_USART1CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 173 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 174 break; \
bogdanm 92:4fc01daae5a5 175 case RCC_USART1CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 176 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 177 break; \
bogdanm 92:4fc01daae5a5 178 case RCC_USART1CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 179 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 180 break; \
bogdanm 92:4fc01daae5a5 181 default: \
bogdanm 92:4fc01daae5a5 182 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 183 break; \
bogdanm 92:4fc01daae5a5 184 } \
bogdanm 92:4fc01daae5a5 185 } \
bogdanm 92:4fc01daae5a5 186 else if((__HANDLE__)->Instance == USART2) \
bogdanm 92:4fc01daae5a5 187 { \
bogdanm 92:4fc01daae5a5 188 switch(__HAL_RCC_GET_USART2_SOURCE()) \
bogdanm 92:4fc01daae5a5 189 { \
bogdanm 92:4fc01daae5a5 190 case RCC_USART2CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 191 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 192 break; \
bogdanm 92:4fc01daae5a5 193 case RCC_USART2CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 194 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 195 break; \
bogdanm 92:4fc01daae5a5 196 case RCC_USART2CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 197 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 198 break; \
bogdanm 92:4fc01daae5a5 199 case RCC_USART2CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 200 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 201 break; \
bogdanm 92:4fc01daae5a5 202 default: \
bogdanm 92:4fc01daae5a5 203 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 204 break; \
bogdanm 92:4fc01daae5a5 205 } \
bogdanm 92:4fc01daae5a5 206 } \
bogdanm 92:4fc01daae5a5 207 else if((__HANDLE__)->Instance == USART3) \
bogdanm 92:4fc01daae5a5 208 { \
bogdanm 92:4fc01daae5a5 209 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 210 } \
bogdanm 92:4fc01daae5a5 211 else if((__HANDLE__)->Instance == USART4) \
bogdanm 92:4fc01daae5a5 212 { \
bogdanm 92:4fc01daae5a5 213 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 214 } \
bogdanm 92:4fc01daae5a5 215 else \
bogdanm 92:4fc01daae5a5 216 { \
bogdanm 92:4fc01daae5a5 217 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 218 } \
bogdanm 92:4fc01daae5a5 219 } while(0)
bogdanm 92:4fc01daae5a5 220 #elif defined(STM32F091xC) || defined(STM32F098xx)
bogdanm 92:4fc01daae5a5 221 #define __HAL_IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
bogdanm 92:4fc01daae5a5 222 do { \
bogdanm 92:4fc01daae5a5 223 if((__HANDLE__)->Instance == USART1) \
bogdanm 92:4fc01daae5a5 224 { \
bogdanm 92:4fc01daae5a5 225 switch(__HAL_RCC_GET_USART1_SOURCE()) \
bogdanm 92:4fc01daae5a5 226 { \
bogdanm 92:4fc01daae5a5 227 case RCC_USART1CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 228 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 229 break; \
bogdanm 92:4fc01daae5a5 230 case RCC_USART1CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 231 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 232 break; \
bogdanm 92:4fc01daae5a5 233 case RCC_USART1CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 234 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 235 break; \
bogdanm 92:4fc01daae5a5 236 case RCC_USART1CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 237 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 238 break; \
bogdanm 92:4fc01daae5a5 239 default: \
bogdanm 92:4fc01daae5a5 240 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 241 break; \
bogdanm 92:4fc01daae5a5 242 } \
bogdanm 92:4fc01daae5a5 243 } \
bogdanm 92:4fc01daae5a5 244 else if((__HANDLE__)->Instance == USART2) \
bogdanm 92:4fc01daae5a5 245 { \
bogdanm 92:4fc01daae5a5 246 switch(__HAL_RCC_GET_USART2_SOURCE()) \
bogdanm 92:4fc01daae5a5 247 { \
bogdanm 92:4fc01daae5a5 248 case RCC_USART2CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 249 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 250 break; \
bogdanm 92:4fc01daae5a5 251 case RCC_USART2CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 252 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 253 break; \
bogdanm 92:4fc01daae5a5 254 case RCC_USART2CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 255 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 256 break; \
bogdanm 92:4fc01daae5a5 257 case RCC_USART2CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 258 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 259 break; \
bogdanm 92:4fc01daae5a5 260 default: \
bogdanm 92:4fc01daae5a5 261 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 262 break; \
bogdanm 92:4fc01daae5a5 263 } \
bogdanm 92:4fc01daae5a5 264 } \
bogdanm 92:4fc01daae5a5 265 else if((__HANDLE__)->Instance == USART3) \
bogdanm 92:4fc01daae5a5 266 { \
bogdanm 92:4fc01daae5a5 267 switch(__HAL_RCC_GET_USART3_SOURCE()) \
bogdanm 92:4fc01daae5a5 268 { \
bogdanm 92:4fc01daae5a5 269 case RCC_USART3CLKSOURCE_PCLK1: \
bogdanm 92:4fc01daae5a5 270 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 271 break; \
bogdanm 92:4fc01daae5a5 272 case RCC_USART3CLKSOURCE_HSI: \
bogdanm 92:4fc01daae5a5 273 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \
bogdanm 92:4fc01daae5a5 274 break; \
bogdanm 92:4fc01daae5a5 275 case RCC_USART3CLKSOURCE_SYSCLK: \
bogdanm 92:4fc01daae5a5 276 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \
bogdanm 92:4fc01daae5a5 277 break; \
bogdanm 92:4fc01daae5a5 278 case RCC_USART3CLKSOURCE_LSE: \
bogdanm 92:4fc01daae5a5 279 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \
bogdanm 92:4fc01daae5a5 280 break; \
bogdanm 92:4fc01daae5a5 281 default: \
bogdanm 92:4fc01daae5a5 282 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 283 break; \
bogdanm 92:4fc01daae5a5 284 } \
bogdanm 92:4fc01daae5a5 285 } \
bogdanm 92:4fc01daae5a5 286 else if((__HANDLE__)->Instance == USART4) \
bogdanm 92:4fc01daae5a5 287 { \
bogdanm 92:4fc01daae5a5 288 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 289 } \
bogdanm 92:4fc01daae5a5 290 else if((__HANDLE__)->Instance == USART5) \
bogdanm 92:4fc01daae5a5 291 { \
bogdanm 92:4fc01daae5a5 292 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 293 } \
bogdanm 92:4fc01daae5a5 294 else if((__HANDLE__)->Instance == USART6) \
bogdanm 92:4fc01daae5a5 295 { \
bogdanm 92:4fc01daae5a5 296 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 297 } \
bogdanm 92:4fc01daae5a5 298 else if((__HANDLE__)->Instance == USART7) \
bogdanm 92:4fc01daae5a5 299 { \
bogdanm 92:4fc01daae5a5 300 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 301 } \
bogdanm 92:4fc01daae5a5 302 else if((__HANDLE__)->Instance == USART8) \
bogdanm 92:4fc01daae5a5 303 { \
bogdanm 92:4fc01daae5a5 304 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \
bogdanm 92:4fc01daae5a5 305 } \
bogdanm 92:4fc01daae5a5 306 else \
bogdanm 92:4fc01daae5a5 307 { \
bogdanm 92:4fc01daae5a5 308 (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \
bogdanm 92:4fc01daae5a5 309 } \
bogdanm 92:4fc01daae5a5 310 } while(0)
bogdanm 92:4fc01daae5a5 311
Kojto 93:e188a91d3eaa 312 #endif /* defined(STM32F031x6) || defined(STM32F038xx) */
bogdanm 92:4fc01daae5a5 313
bogdanm 92:4fc01daae5a5 314
bogdanm 85:024bf7f99721 315 /** @brief Computes the mask to apply to retrieve the received data
bogdanm 85:024bf7f99721 316 * according to the word length and to the parity bits activation.
bogdanm 85:024bf7f99721 317 * @param __HANDLE__: specifies the IRDA Handle
bogdanm 85:024bf7f99721 318 * @retval none
bogdanm 85:024bf7f99721 319 */
bogdanm 85:024bf7f99721 320 #if defined (STM32F042x6) || defined (STM32F048xx) || \
bogdanm 92:4fc01daae5a5 321 defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \
bogdanm 92:4fc01daae5a5 322 defined (STM32F091xC) || defined (STM32F098xx)
bogdanm 85:024bf7f99721 323 #define __HAL_IRDA_MASK_COMPUTATION(__HANDLE__) \
bogdanm 85:024bf7f99721 324 do { \
bogdanm 85:024bf7f99721 325 if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_9B) \
bogdanm 85:024bf7f99721 326 { \
bogdanm 85:024bf7f99721 327 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
bogdanm 85:024bf7f99721 328 { \
bogdanm 85:024bf7f99721 329 (__HANDLE__)->Mask = 0x01FF ; \
bogdanm 85:024bf7f99721 330 } \
bogdanm 85:024bf7f99721 331 else \
bogdanm 85:024bf7f99721 332 { \
bogdanm 85:024bf7f99721 333 (__HANDLE__)->Mask = 0x00FF ; \
bogdanm 85:024bf7f99721 334 } \
bogdanm 85:024bf7f99721 335 } \
bogdanm 85:024bf7f99721 336 else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_8B) \
bogdanm 85:024bf7f99721 337 { \
bogdanm 85:024bf7f99721 338 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
bogdanm 85:024bf7f99721 339 { \
bogdanm 85:024bf7f99721 340 (__HANDLE__)->Mask = 0x00FF ; \
bogdanm 85:024bf7f99721 341 } \
bogdanm 85:024bf7f99721 342 else \
bogdanm 85:024bf7f99721 343 { \
bogdanm 85:024bf7f99721 344 (__HANDLE__)->Mask = 0x007F ; \
bogdanm 85:024bf7f99721 345 } \
bogdanm 85:024bf7f99721 346 } \
bogdanm 85:024bf7f99721 347 else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_7B) \
bogdanm 85:024bf7f99721 348 { \
bogdanm 85:024bf7f99721 349 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
bogdanm 85:024bf7f99721 350 { \
bogdanm 85:024bf7f99721 351 (__HANDLE__)->Mask = 0x007F ; \
bogdanm 85:024bf7f99721 352 } \
bogdanm 85:024bf7f99721 353 else \
bogdanm 85:024bf7f99721 354 { \
bogdanm 85:024bf7f99721 355 (__HANDLE__)->Mask = 0x003F ; \
bogdanm 85:024bf7f99721 356 } \
bogdanm 85:024bf7f99721 357 } \
bogdanm 85:024bf7f99721 358 } while(0)
bogdanm 85:024bf7f99721 359 #else
bogdanm 85:024bf7f99721 360 #define __HAL_IRDA_MASK_COMPUTATION(__HANDLE__) \
bogdanm 85:024bf7f99721 361 do { \
bogdanm 85:024bf7f99721 362 if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_9B) \
bogdanm 85:024bf7f99721 363 { \
bogdanm 85:024bf7f99721 364 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
bogdanm 85:024bf7f99721 365 { \
bogdanm 85:024bf7f99721 366 (__HANDLE__)->Mask = 0x01FF ; \
bogdanm 85:024bf7f99721 367 } \
bogdanm 85:024bf7f99721 368 else \
bogdanm 85:024bf7f99721 369 { \
bogdanm 85:024bf7f99721 370 (__HANDLE__)->Mask = 0x00FF ; \
bogdanm 85:024bf7f99721 371 } \
bogdanm 85:024bf7f99721 372 } \
bogdanm 85:024bf7f99721 373 else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_8B) \
bogdanm 85:024bf7f99721 374 { \
bogdanm 85:024bf7f99721 375 if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \
bogdanm 85:024bf7f99721 376 { \
bogdanm 85:024bf7f99721 377 (__HANDLE__)->Mask = 0x00FF ; \
bogdanm 85:024bf7f99721 378 } \
bogdanm 85:024bf7f99721 379 else \
bogdanm 85:024bf7f99721 380 { \
bogdanm 85:024bf7f99721 381 (__HANDLE__)->Mask = 0x007F ; \
bogdanm 85:024bf7f99721 382 } \
bogdanm 85:024bf7f99721 383 } \
bogdanm 85:024bf7f99721 384 } while(0)
bogdanm 85:024bf7f99721 385 #endif /* defined (STM32F042x6) || defined (STM32F048xx) || \
bogdanm 92:4fc01daae5a5 386 defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \
bogdanm 92:4fc01daae5a5 387 defined (STM32F091xC) || defined(STM32F098xx) */
bogdanm 85:024bf7f99721 388 /**
bogdanm 85:024bf7f99721 389 * @}
bogdanm 85:024bf7f99721 390 */
bogdanm 85:024bf7f99721 391
bogdanm 85:024bf7f99721 392 /* Exported functions --------------------------------------------------------*/
bogdanm 85:024bf7f99721 393 /* Initialization and de-initialization functions ****************************/
bogdanm 85:024bf7f99721 394 /* IO operation functions *****************************************************/
bogdanm 85:024bf7f99721 395 /* Peripheral Control functions ***********************************************/
bogdanm 85:024bf7f99721 396 /* Peripheral State and Error functions ***************************************/
bogdanm 85:024bf7f99721 397
bogdanm 85:024bf7f99721 398 /**
bogdanm 85:024bf7f99721 399 * @}
bogdanm 85:024bf7f99721 400 */
bogdanm 85:024bf7f99721 401
bogdanm 85:024bf7f99721 402 /**
bogdanm 85:024bf7f99721 403 * @}
bogdanm 85:024bf7f99721 404 */
bogdanm 85:024bf7f99721 405
Kojto 93:e188a91d3eaa 406 #endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) */
bogdanm 85:024bf7f99721 407
bogdanm 85:024bf7f99721 408 #ifdef __cplusplus
bogdanm 85:024bf7f99721 409 }
bogdanm 85:024bf7f99721 410 #endif
bogdanm 85:024bf7f99721 411
bogdanm 85:024bf7f99721 412 #endif /* __STM32F0xx_HAL_IRDA_EX_H */
bogdanm 85:024bf7f99721 413
bogdanm 85:024bf7f99721 414 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
bogdanm 92:4fc01daae5a5 415