cc y / mbed

Fork of mbed by mbed official

Committer:
Kojto
Date:
Wed Apr 27 12:10:56 2016 -0500
Revision:
119:aae6fcc7d9bb
Parent:
96:487b796308b0
Release 119 of the mbed library

Changes:
- new targets - EFM32PG_STK3401, NUCLEO_L031K6
- ST - hwflwctl support for NUCLEO_L476RG
- Update STM32CUBE_L0 from v1.2 to v1.5
- STM32F7 - bugfix - The weak function HAL_Delay is overwritten to use us ticker API.
- Maxim - Fixing the send break for the MAXWSNENV and MAX32600MBED

Who changed what in which revision?

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