mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Wed Feb 20 22:31:08 2019 +0000
Revision:
189:f392fc9709a3
Parent:
186:707f6e361f3e
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /**
<> 144:ef7eb2e8f9f7 2 ******************************************************************************
<> 144:ef7eb2e8f9f7 3 * @file stm32l0xx_hal_smartcard_ex.h
<> 144:ef7eb2e8f9f7 4 * @author MCD Application Team
Anna Bridge 186:707f6e361f3e 5 * @brief Header file of SMARTCARD HAL Extended module.
<> 144:ef7eb2e8f9f7 6 ******************************************************************************
<> 144:ef7eb2e8f9f7 7 * @attention
<> 144:ef7eb2e8f9f7 8 *
<> 144:ef7eb2e8f9f7 9 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
<> 144:ef7eb2e8f9f7 10 *
<> 144:ef7eb2e8f9f7 11 * Redistribution and use in source and binary forms, with or without modification,
<> 144:ef7eb2e8f9f7 12 * are permitted provided that the following conditions are met:
<> 144:ef7eb2e8f9f7 13 * 1. Redistributions of source code must retain the above copyright notice,
<> 144:ef7eb2e8f9f7 14 * this list of conditions and the following disclaimer.
<> 144:ef7eb2e8f9f7 15 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 144:ef7eb2e8f9f7 16 * this list of conditions and the following disclaimer in the documentation
<> 144:ef7eb2e8f9f7 17 * and/or other materials provided with the distribution.
<> 144:ef7eb2e8f9f7 18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
<> 144:ef7eb2e8f9f7 19 * may be used to endorse or promote products derived from this software
<> 144:ef7eb2e8f9f7 20 * without specific prior written permission.
<> 144:ef7eb2e8f9f7 21 *
<> 144:ef7eb2e8f9f7 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 144:ef7eb2e8f9f7 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 144:ef7eb2e8f9f7 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 144:ef7eb2e8f9f7 25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 144:ef7eb2e8f9f7 26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 144:ef7eb2e8f9f7 27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 144:ef7eb2e8f9f7 28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 144:ef7eb2e8f9f7 29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 144:ef7eb2e8f9f7 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 144:ef7eb2e8f9f7 31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 144:ef7eb2e8f9f7 32 *
<> 144:ef7eb2e8f9f7 33 ******************************************************************************
<> 144:ef7eb2e8f9f7 34 */
<> 144:ef7eb2e8f9f7 35
<> 144:ef7eb2e8f9f7 36 /* Define to prevent recursive inclusion -------------------------------------*/
<> 144:ef7eb2e8f9f7 37 #ifndef __STM32L0xx_HAL_SMARTCARD_EX_H
<> 144:ef7eb2e8f9f7 38 #define __STM32L0xx_HAL_SMARTCARD_EX_H
<> 144:ef7eb2e8f9f7 39
<> 144:ef7eb2e8f9f7 40 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 41 extern "C" {
<> 144:ef7eb2e8f9f7 42 #endif
<> 144:ef7eb2e8f9f7 43
<> 144:ef7eb2e8f9f7 44 /* Includes ------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 45 #include "stm32l0xx_hal_def.h"
<> 144:ef7eb2e8f9f7 46
<> 144:ef7eb2e8f9f7 47 /** @addtogroup STM32L0xx_HAL_Driver
<> 144:ef7eb2e8f9f7 48 * @{
<> 144:ef7eb2e8f9f7 49 */
<> 144:ef7eb2e8f9f7 50
Anna Bridge 186:707f6e361f3e 51 /** @addtogroup SMARTCARDEx
<> 144:ef7eb2e8f9f7 52 * @{
<> 144:ef7eb2e8f9f7 53 */
Anna Bridge 186:707f6e361f3e 54
Anna Bridge 186:707f6e361f3e 55 /* Exported types ------------------------------------------------------------*/
Anna Bridge 186:707f6e361f3e 56 /* Exported constants --------------------------------------------------------*/
Anna Bridge 186:707f6e361f3e 57 /* Exported macros -----------------------------------------------------------*/
Anna Bridge 186:707f6e361f3e 58 /* Private macros ------------------------------------------------------------*/
Anna Bridge 186:707f6e361f3e 59 /** @defgroup SMARTCARDEx_Private_Macros SMARTCARD Extended Private Macros
Anna Bridge 186:707f6e361f3e 60 * @{
Anna Bridge 186:707f6e361f3e 61 */
Anna Bridge 186:707f6e361f3e 62
Anna Bridge 186:707f6e361f3e 63 /** @brief Report the SMARTCARD clock source.
Anna Bridge 186:707f6e361f3e 64 * @param __HANDLE__: specifies the SMARTCARD Handle.
Anna Bridge 186:707f6e361f3e 65 * @param __CLOCKSOURCE__: output variable.
Anna Bridge 186:707f6e361f3e 66 * @retval the SMARTCARD clocking source, written in __CLOCKSOURCE__.
<> 144:ef7eb2e8f9f7 67 */
<> 144:ef7eb2e8f9f7 68 #if defined (STM32L031xx) || defined (STM32L041xx) || defined (STM32L011xx) || defined (STM32L021xx)
Anna Bridge 186:707f6e361f3e 69 #define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
Anna Bridge 186:707f6e361f3e 70 do { \
Anna Bridge 186:707f6e361f3e 71 if((__HANDLE__)->Instance == USART2) \
Anna Bridge 186:707f6e361f3e 72 { \
Anna Bridge 186:707f6e361f3e 73 switch(__HAL_RCC_GET_USART2_SOURCE()) \
Anna Bridge 186:707f6e361f3e 74 { \
Anna Bridge 186:707f6e361f3e 75 case RCC_USART2CLKSOURCE_PCLK1: \
Anna Bridge 186:707f6e361f3e 76 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \
Anna Bridge 186:707f6e361f3e 77 break; \
Anna Bridge 186:707f6e361f3e 78 case RCC_USART2CLKSOURCE_HSI: \
Anna Bridge 186:707f6e361f3e 79 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \
Anna Bridge 186:707f6e361f3e 80 break; \
Anna Bridge 186:707f6e361f3e 81 case RCC_USART2CLKSOURCE_SYSCLK: \
Anna Bridge 186:707f6e361f3e 82 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \
Anna Bridge 186:707f6e361f3e 83 break; \
Anna Bridge 186:707f6e361f3e 84 case RCC_USART2CLKSOURCE_LSE: \
Anna Bridge 186:707f6e361f3e 85 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \
Anna Bridge 186:707f6e361f3e 86 break; \
Anna Bridge 186:707f6e361f3e 87 default: \
Anna Bridge 186:707f6e361f3e 88 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \
Anna Bridge 186:707f6e361f3e 89 break; \
Anna Bridge 186:707f6e361f3e 90 } \
Anna Bridge 186:707f6e361f3e 91 } \
<> 144:ef7eb2e8f9f7 92 } while(0)
<> 144:ef7eb2e8f9f7 93
<> 144:ef7eb2e8f9f7 94 #else /* (STM32L031xx) || defined (STM32L041xx) || (STM32L011xx) || defined (STM32L021xx) */
<> 144:ef7eb2e8f9f7 95
Anna Bridge 186:707f6e361f3e 96 #define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \
Anna Bridge 186:707f6e361f3e 97 do { \
Anna Bridge 186:707f6e361f3e 98 if((__HANDLE__)->Instance == USART1) \
Anna Bridge 186:707f6e361f3e 99 { \
Anna Bridge 186:707f6e361f3e 100 switch(__HAL_RCC_GET_USART1_SOURCE()) \
Anna Bridge 186:707f6e361f3e 101 { \
Anna Bridge 186:707f6e361f3e 102 case RCC_USART1CLKSOURCE_PCLK2: \
Anna Bridge 186:707f6e361f3e 103 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK2; \
Anna Bridge 186:707f6e361f3e 104 break; \
Anna Bridge 186:707f6e361f3e 105 case RCC_USART1CLKSOURCE_HSI: \
Anna Bridge 186:707f6e361f3e 106 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \
Anna Bridge 186:707f6e361f3e 107 break; \
Anna Bridge 186:707f6e361f3e 108 case RCC_USART1CLKSOURCE_SYSCLK: \
Anna Bridge 186:707f6e361f3e 109 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \
Anna Bridge 186:707f6e361f3e 110 break; \
Anna Bridge 186:707f6e361f3e 111 case RCC_USART1CLKSOURCE_LSE: \
Anna Bridge 186:707f6e361f3e 112 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \
Anna Bridge 186:707f6e361f3e 113 break; \
Anna Bridge 186:707f6e361f3e 114 default: \
Anna Bridge 186:707f6e361f3e 115 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \
Anna Bridge 186:707f6e361f3e 116 break; \
Anna Bridge 186:707f6e361f3e 117 } \
Anna Bridge 186:707f6e361f3e 118 } \
Anna Bridge 186:707f6e361f3e 119 else if((__HANDLE__)->Instance == USART2) \
Anna Bridge 186:707f6e361f3e 120 { \
Anna Bridge 186:707f6e361f3e 121 switch(__HAL_RCC_GET_USART2_SOURCE()) \
Anna Bridge 186:707f6e361f3e 122 { \
Anna Bridge 186:707f6e361f3e 123 case RCC_USART2CLKSOURCE_PCLK1: \
Anna Bridge 186:707f6e361f3e 124 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \
Anna Bridge 186:707f6e361f3e 125 break; \
Anna Bridge 186:707f6e361f3e 126 case RCC_USART2CLKSOURCE_HSI: \
Anna Bridge 186:707f6e361f3e 127 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \
Anna Bridge 186:707f6e361f3e 128 break; \
Anna Bridge 186:707f6e361f3e 129 case RCC_USART2CLKSOURCE_SYSCLK: \
Anna Bridge 186:707f6e361f3e 130 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \
Anna Bridge 186:707f6e361f3e 131 break; \
Anna Bridge 186:707f6e361f3e 132 case RCC_USART2CLKSOURCE_LSE: \
Anna Bridge 186:707f6e361f3e 133 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \
Anna Bridge 186:707f6e361f3e 134 break; \
Anna Bridge 186:707f6e361f3e 135 default: \
Anna Bridge 186:707f6e361f3e 136 (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \
Anna Bridge 186:707f6e361f3e 137 break; \
Anna Bridge 186:707f6e361f3e 138 } \
Anna Bridge 186:707f6e361f3e 139 } \
<> 144:ef7eb2e8f9f7 140 } while(0)
<> 144:ef7eb2e8f9f7 141 #endif /* (STM32L031xx) || (STM32L041xx) || (STM32L011xx) || defined (STM32L021xx) */
<> 144:ef7eb2e8f9f7 142
<> 144:ef7eb2e8f9f7 143 /**
<> 144:ef7eb2e8f9f7 144 * @}
<> 144:ef7eb2e8f9f7 145 */
<> 144:ef7eb2e8f9f7 146
<> 144:ef7eb2e8f9f7 147 /* Exported functions --------------------------------------------------------*/
Anna Bridge 186:707f6e361f3e 148 /** @addtogroup SMARTCARDEx_Exported_Functions
<> 144:ef7eb2e8f9f7 149 * @{
<> 144:ef7eb2e8f9f7 150 */
<> 144:ef7eb2e8f9f7 151
<> 144:ef7eb2e8f9f7 152 /* Initialization and de-initialization functions ****************************/
Anna Bridge 186:707f6e361f3e 153 /* IO operation methods *******************************************************/
Anna Bridge 186:707f6e361f3e 154
Anna Bridge 186:707f6e361f3e 155 /** @addtogroup SMARTCARDEx_Exported_Functions_Group1
Anna Bridge 186:707f6e361f3e 156 * @{
Anna Bridge 186:707f6e361f3e 157 */
Anna Bridge 186:707f6e361f3e 158
<> 144:ef7eb2e8f9f7 159 /* Peripheral Control functions ***********************************************/
Anna Bridge 186:707f6e361f3e 160 void HAL_SMARTCARDEx_BlockLength_Config(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t BlockLength);
Anna Bridge 186:707f6e361f3e 161 void HAL_SMARTCARDEx_TimeOut_Config(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t TimeOutValue);
Anna Bridge 186:707f6e361f3e 162 HAL_StatusTypeDef HAL_SMARTCARDEx_EnableReceiverTimeOut(SMARTCARD_HandleTypeDef *hsmartcard);
Anna Bridge 186:707f6e361f3e 163 HAL_StatusTypeDef HAL_SMARTCARDEx_DisableReceiverTimeOut(SMARTCARD_HandleTypeDef *hsmartcard);
<> 144:ef7eb2e8f9f7 164
<> 144:ef7eb2e8f9f7 165 /**
<> 144:ef7eb2e8f9f7 166 * @}
<> 144:ef7eb2e8f9f7 167 */
<> 144:ef7eb2e8f9f7 168
<> 144:ef7eb2e8f9f7 169 /**
<> 144:ef7eb2e8f9f7 170 * @}
<> 144:ef7eb2e8f9f7 171 */
<> 144:ef7eb2e8f9f7 172
<> 144:ef7eb2e8f9f7 173 /**
<> 144:ef7eb2e8f9f7 174 * @}
<> 144:ef7eb2e8f9f7 175 */
Anna Bridge 186:707f6e361f3e 176
Anna Bridge 186:707f6e361f3e 177 /**
Anna Bridge 186:707f6e361f3e 178 * @}
Anna Bridge 186:707f6e361f3e 179 */
Anna Bridge 186:707f6e361f3e 180
<> 144:ef7eb2e8f9f7 181 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 182 }
<> 144:ef7eb2e8f9f7 183 #endif
<> 144:ef7eb2e8f9f7 184
<> 144:ef7eb2e8f9f7 185 #endif /* __STM32L0xx_HAL_SMARTCARD_EX_H */
<> 144:ef7eb2e8f9f7 186
<> 144:ef7eb2e8f9f7 187 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
<> 144:ef7eb2e8f9f7 188