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

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
AnnaBridge
Date:
Thu Nov 08 11:45:42 2018 +0000
Revision:
171:3a7713b1edbc
Parent:
TARGET_NUCLEO_L011K4/TARGET_STM/TARGET_STM32L0/device/stm32l0xx_hal_lptim.h@167:84c0a372a020
mbed library. Release version 164

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 157:e7ca05fa8600 1 /**
AnnaBridge 157:e7ca05fa8600 2 ******************************************************************************
AnnaBridge 157:e7ca05fa8600 3 * @file stm32l0xx_hal_lptim.h
AnnaBridge 157:e7ca05fa8600 4 * @author MCD Application Team
AnnaBridge 157:e7ca05fa8600 5 * @brief Header file of LPTIM HAL module.
AnnaBridge 157:e7ca05fa8600 6 ******************************************************************************
AnnaBridge 157:e7ca05fa8600 7 * @attention
AnnaBridge 157:e7ca05fa8600 8 *
AnnaBridge 157:e7ca05fa8600 9 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
AnnaBridge 157:e7ca05fa8600 10 *
AnnaBridge 157:e7ca05fa8600 11 * Redistribution and use in source and binary forms, with or without modification,
AnnaBridge 157:e7ca05fa8600 12 * are permitted provided that the following conditions are met:
AnnaBridge 157:e7ca05fa8600 13 * 1. Redistributions of source code must retain the above copyright notice,
AnnaBridge 157:e7ca05fa8600 14 * this list of conditions and the following disclaimer.
AnnaBridge 157:e7ca05fa8600 15 * 2. Redistributions in binary form must reproduce the above copyright notice,
AnnaBridge 157:e7ca05fa8600 16 * this list of conditions and the following disclaimer in the documentation
AnnaBridge 157:e7ca05fa8600 17 * and/or other materials provided with the distribution.
AnnaBridge 157:e7ca05fa8600 18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
AnnaBridge 157:e7ca05fa8600 19 * may be used to endorse or promote products derived from this software
AnnaBridge 157:e7ca05fa8600 20 * without specific prior written permission.
AnnaBridge 157:e7ca05fa8600 21 *
AnnaBridge 157:e7ca05fa8600 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AnnaBridge 157:e7ca05fa8600 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
AnnaBridge 157:e7ca05fa8600 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
AnnaBridge 157:e7ca05fa8600 25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
AnnaBridge 157:e7ca05fa8600 26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
AnnaBridge 157:e7ca05fa8600 27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
AnnaBridge 157:e7ca05fa8600 28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
AnnaBridge 157:e7ca05fa8600 29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
AnnaBridge 157:e7ca05fa8600 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
AnnaBridge 157:e7ca05fa8600 31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
AnnaBridge 157:e7ca05fa8600 32 *
AnnaBridge 157:e7ca05fa8600 33 ******************************************************************************
AnnaBridge 157:e7ca05fa8600 34 */
AnnaBridge 157:e7ca05fa8600 35
AnnaBridge 157:e7ca05fa8600 36 /* Define to prevent recursive inclusion -------------------------------------*/
AnnaBridge 157:e7ca05fa8600 37 #ifndef __STM32L0xx_HAL_LPTIM_H
AnnaBridge 157:e7ca05fa8600 38 #define __STM32L0xx_HAL_LPTIM_H
AnnaBridge 157:e7ca05fa8600 39
AnnaBridge 157:e7ca05fa8600 40 #ifdef __cplusplus
AnnaBridge 157:e7ca05fa8600 41 extern "C" {
AnnaBridge 157:e7ca05fa8600 42 #endif
AnnaBridge 157:e7ca05fa8600 43
AnnaBridge 157:e7ca05fa8600 44 /* Includes ------------------------------------------------------------------*/
AnnaBridge 157:e7ca05fa8600 45 #include "stm32l0xx_hal_def.h"
AnnaBridge 157:e7ca05fa8600 46
AnnaBridge 157:e7ca05fa8600 47 /** @addtogroup STM32L0xx_HAL_Driver
AnnaBridge 157:e7ca05fa8600 48 * @{
AnnaBridge 157:e7ca05fa8600 49 */
AnnaBridge 157:e7ca05fa8600 50
AnnaBridge 157:e7ca05fa8600 51 /** @defgroup LPTIM LPTIM (Low power timer)
AnnaBridge 157:e7ca05fa8600 52 * @{
AnnaBridge 157:e7ca05fa8600 53 */
AnnaBridge 157:e7ca05fa8600 54
AnnaBridge 157:e7ca05fa8600 55 /* Exported types ------------------------------------------------------------*/
AnnaBridge 157:e7ca05fa8600 56 /** @defgroup LPTIM_Exported_Types LPTIM Exported Types
AnnaBridge 157:e7ca05fa8600 57 * @{
AnnaBridge 157:e7ca05fa8600 58 */
AnnaBridge 157:e7ca05fa8600 59
AnnaBridge 157:e7ca05fa8600 60 /** @defgroup LPTIM_Clock_Configuration LPTIM Clock configuration structure
AnnaBridge 157:e7ca05fa8600 61 * @{
AnnaBridge 157:e7ca05fa8600 62 */
AnnaBridge 157:e7ca05fa8600 63 #define LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT ((uint32_t)EXTI_IMR_IM29) /*!< External interrupt line 29 Connected to the LPTIM EXTI Line */
AnnaBridge 157:e7ca05fa8600 64
AnnaBridge 157:e7ca05fa8600 65 /**
AnnaBridge 157:e7ca05fa8600 66 * @brief LPTIM Clock configuration definition
AnnaBridge 157:e7ca05fa8600 67 */
AnnaBridge 157:e7ca05fa8600 68 typedef struct
AnnaBridge 157:e7ca05fa8600 69 {
AnnaBridge 157:e7ca05fa8600 70 uint32_t Source; /*!< Selects the clock source.
AnnaBridge 157:e7ca05fa8600 71 This parameter can be a value of @ref LPTIM_Clock_Source */
AnnaBridge 157:e7ca05fa8600 72
AnnaBridge 157:e7ca05fa8600 73 uint32_t Prescaler; /*!< Specifies the counter clock Prescaler.
AnnaBridge 157:e7ca05fa8600 74 This parameter can be a value of @ref LPTIM_Clock_Prescaler */
AnnaBridge 157:e7ca05fa8600 75
AnnaBridge 157:e7ca05fa8600 76 }LPTIM_ClockConfigTypeDef;
AnnaBridge 157:e7ca05fa8600 77 /**
AnnaBridge 157:e7ca05fa8600 78 * @}
AnnaBridge 157:e7ca05fa8600 79 */
AnnaBridge 157:e7ca05fa8600 80
AnnaBridge 157:e7ca05fa8600 81 /** @defgroup LPTIM_ULPClock_Configuration LPTIM ULP Clock configuration structure
AnnaBridge 157:e7ca05fa8600 82 * @{
AnnaBridge 157:e7ca05fa8600 83 */
AnnaBridge 157:e7ca05fa8600 84 /**
AnnaBridge 157:e7ca05fa8600 85 * @brief LPTIM ULP Clock configuration definition
AnnaBridge 157:e7ca05fa8600 86 */
AnnaBridge 157:e7ca05fa8600 87 typedef struct
AnnaBridge 157:e7ca05fa8600 88 {
AnnaBridge 157:e7ca05fa8600 89 uint32_t Polarity; /*!< Selects the polarity of the active edge for the counter unit
AnnaBridge 157:e7ca05fa8600 90 if the ULPTIM input is selected.
AnnaBridge 157:e7ca05fa8600 91 Note: This parameter is used only when Ultra low power clock source is used.
AnnaBridge 157:e7ca05fa8600 92 Note: If the polarity is configured on 'both edges', an auxiliary clock
AnnaBridge 157:e7ca05fa8600 93 (one of the Low power oscillator) must be active.
AnnaBridge 157:e7ca05fa8600 94 This parameter can be a value of @ref LPTIM_Clock_Polarity */
AnnaBridge 157:e7ca05fa8600 95
AnnaBridge 157:e7ca05fa8600 96 uint32_t SampleTime; /*!< Selects the clock sampling time to configure the clock glitch filter.
AnnaBridge 157:e7ca05fa8600 97 Note: This parameter is used only when Ultra low power clock source is used.
AnnaBridge 157:e7ca05fa8600 98 This parameter can be a value of @ref LPTIM_Clock_Sample_Time */
AnnaBridge 157:e7ca05fa8600 99
AnnaBridge 157:e7ca05fa8600 100 }LPTIM_ULPClockConfigTypeDef;
AnnaBridge 157:e7ca05fa8600 101 /**
AnnaBridge 157:e7ca05fa8600 102 * @}
AnnaBridge 157:e7ca05fa8600 103 */
AnnaBridge 157:e7ca05fa8600 104
AnnaBridge 157:e7ca05fa8600 105 /** @defgroup LPTIM_Trigger_Configuration LPTIM Trigger configuration structure
AnnaBridge 157:e7ca05fa8600 106 * @{
AnnaBridge 157:e7ca05fa8600 107 */
AnnaBridge 157:e7ca05fa8600 108 /**
AnnaBridge 157:e7ca05fa8600 109 * @brief LPTIM Trigger configuration structure
AnnaBridge 157:e7ca05fa8600 110 */
AnnaBridge 157:e7ca05fa8600 111 typedef struct
AnnaBridge 157:e7ca05fa8600 112 {
AnnaBridge 157:e7ca05fa8600 113 uint32_t Source; /*!< Selects the Trigger source.
AnnaBridge 167:84c0a372a020 114 This parameter can be a value of @ref LPTIM_Trigger_Source */
AnnaBridge 157:e7ca05fa8600 115
AnnaBridge 157:e7ca05fa8600 116 uint32_t ActiveEdge; /*!< Selects the Trigger active edge.
AnnaBridge 157:e7ca05fa8600 117 Note: This parameter is used only when an external trigger is used.
AnnaBridge 157:e7ca05fa8600 118 This parameter can be a value of @ref LPTIM_External_Trigger_Polarity */
AnnaBridge 157:e7ca05fa8600 119
AnnaBridge 157:e7ca05fa8600 120 uint32_t SampleTime; /*!< Selects the trigger sampling time to configure the clock glitch filter.
AnnaBridge 157:e7ca05fa8600 121 Note: This parameter is used only when an external trigger is used.
AnnaBridge 157:e7ca05fa8600 122 This parameter can be a value of @ref LPTIM_Trigger_Sample_Time */
AnnaBridge 157:e7ca05fa8600 123 }LPTIM_TriggerConfigTypeDef;
AnnaBridge 157:e7ca05fa8600 124 /**
AnnaBridge 157:e7ca05fa8600 125 * @}
AnnaBridge 157:e7ca05fa8600 126 */
AnnaBridge 157:e7ca05fa8600 127
AnnaBridge 157:e7ca05fa8600 128 /** @defgroup LPTIM_Init_Configuration LPTIM Initialization configuration structure
AnnaBridge 157:e7ca05fa8600 129 * @{
AnnaBridge 157:e7ca05fa8600 130 */
AnnaBridge 157:e7ca05fa8600 131 /**
AnnaBridge 157:e7ca05fa8600 132 * @brief LPTIM Initialization Structure definition
AnnaBridge 157:e7ca05fa8600 133 */
AnnaBridge 157:e7ca05fa8600 134 typedef struct
AnnaBridge 157:e7ca05fa8600 135 {
AnnaBridge 157:e7ca05fa8600 136 LPTIM_ClockConfigTypeDef Clock; /*!< Specifies the clock parameters */
AnnaBridge 157:e7ca05fa8600 137
AnnaBridge 157:e7ca05fa8600 138 LPTIM_ULPClockConfigTypeDef UltraLowPowerClock; /*!< Specifies the Ultra Low Power clock parameters */
AnnaBridge 157:e7ca05fa8600 139
AnnaBridge 157:e7ca05fa8600 140 LPTIM_TriggerConfigTypeDef Trigger; /*!< Specifies the Trigger parameters */
AnnaBridge 157:e7ca05fa8600 141
AnnaBridge 157:e7ca05fa8600 142 uint32_t OutputPolarity; /*!< Specifies the Output polarity.
AnnaBridge 157:e7ca05fa8600 143 This parameter can be a value of @ref LPTIM_Output_Polarity */
AnnaBridge 157:e7ca05fa8600 144
AnnaBridge 157:e7ca05fa8600 145 uint32_t UpdateMode; /*!< Specifies whether the update of the autorelaod and the compare
AnnaBridge 157:e7ca05fa8600 146 values is done immediately or after the end of current period.
AnnaBridge 157:e7ca05fa8600 147 This parameter can be a value of @ref LPTIM_Updating_Mode */
AnnaBridge 157:e7ca05fa8600 148
AnnaBridge 157:e7ca05fa8600 149 uint32_t CounterSource; /*!< Specifies whether the counter is incremented each internal event
AnnaBridge 157:e7ca05fa8600 150 or each external event.
AnnaBridge 157:e7ca05fa8600 151 This parameter can be a value of @ref LPTIM_Counter_Source */
AnnaBridge 157:e7ca05fa8600 152
AnnaBridge 157:e7ca05fa8600 153 }LPTIM_InitTypeDef;
AnnaBridge 157:e7ca05fa8600 154 /**
AnnaBridge 157:e7ca05fa8600 155 * @}
AnnaBridge 157:e7ca05fa8600 156 */
AnnaBridge 157:e7ca05fa8600 157 /** @defgroup LPTIM_State_structure LPTIM state definition
AnnaBridge 157:e7ca05fa8600 158 * @{
AnnaBridge 157:e7ca05fa8600 159 */
AnnaBridge 157:e7ca05fa8600 160 /**
AnnaBridge 157:e7ca05fa8600 161 * @brief HAL LPTIM State structure definition
AnnaBridge 157:e7ca05fa8600 162 */
AnnaBridge 157:e7ca05fa8600 163 typedef enum __HAL_LPTIM_StateTypeDef
AnnaBridge 157:e7ca05fa8600 164 {
AnnaBridge 157:e7ca05fa8600 165 HAL_LPTIM_STATE_RESET = 0x00U, /*!< Peripheral not yet initialized or disabled */
AnnaBridge 157:e7ca05fa8600 166 HAL_LPTIM_STATE_READY = 0x01U, /*!< Peripheral Initialized and ready for use */
AnnaBridge 157:e7ca05fa8600 167 HAL_LPTIM_STATE_BUSY = 0x02U, /*!< An internal process is ongoing */
AnnaBridge 157:e7ca05fa8600 168 HAL_LPTIM_STATE_TIMEOUT = 0x03U, /*!< Timeout state */
AnnaBridge 157:e7ca05fa8600 169 HAL_LPTIM_STATE_ERROR = 0x04U /*!< Internal Process is ongoing */
AnnaBridge 157:e7ca05fa8600 170 }HAL_LPTIM_StateTypeDef;
AnnaBridge 157:e7ca05fa8600 171 /**
AnnaBridge 157:e7ca05fa8600 172 * @}
AnnaBridge 157:e7ca05fa8600 173 */
AnnaBridge 157:e7ca05fa8600 174
AnnaBridge 157:e7ca05fa8600 175 /** @defgroup LPTIM_Handle LPTIM handler
AnnaBridge 157:e7ca05fa8600 176 * @{
AnnaBridge 157:e7ca05fa8600 177 */
AnnaBridge 157:e7ca05fa8600 178 /**
AnnaBridge 157:e7ca05fa8600 179 * @brief LPTIM handle Structure definition
AnnaBridge 157:e7ca05fa8600 180 */
AnnaBridge 157:e7ca05fa8600 181 typedef struct
AnnaBridge 157:e7ca05fa8600 182 {
AnnaBridge 157:e7ca05fa8600 183 LPTIM_TypeDef *Instance; /*!< Register base address */
AnnaBridge 157:e7ca05fa8600 184
AnnaBridge 157:e7ca05fa8600 185 LPTIM_InitTypeDef Init; /*!< LPTIM required parameters */
AnnaBridge 157:e7ca05fa8600 186
AnnaBridge 157:e7ca05fa8600 187 HAL_StatusTypeDef Status; /*!< LPTIM peripheral status */
AnnaBridge 157:e7ca05fa8600 188
AnnaBridge 157:e7ca05fa8600 189 HAL_LockTypeDef Lock; /*!< LPTIM locking object */
AnnaBridge 157:e7ca05fa8600 190
AnnaBridge 157:e7ca05fa8600 191 __IO HAL_LPTIM_StateTypeDef State; /*!< LPTIM peripheral state */
AnnaBridge 157:e7ca05fa8600 192
AnnaBridge 157:e7ca05fa8600 193 }LPTIM_HandleTypeDef;
AnnaBridge 157:e7ca05fa8600 194
AnnaBridge 157:e7ca05fa8600 195 /**
AnnaBridge 157:e7ca05fa8600 196 * @}
AnnaBridge 157:e7ca05fa8600 197 */
AnnaBridge 157:e7ca05fa8600 198 /**
AnnaBridge 157:e7ca05fa8600 199 * @}
AnnaBridge 157:e7ca05fa8600 200 */
AnnaBridge 157:e7ca05fa8600 201
AnnaBridge 157:e7ca05fa8600 202 /* Exported constants --------------------------------------------------------*/
AnnaBridge 157:e7ca05fa8600 203
AnnaBridge 157:e7ca05fa8600 204 /** @defgroup LPTIM_Exported_Constants LPTIM Exported constants
AnnaBridge 157:e7ca05fa8600 205 * @{
AnnaBridge 157:e7ca05fa8600 206 */
AnnaBridge 157:e7ca05fa8600 207
AnnaBridge 157:e7ca05fa8600 208 /* Check autoreload value */
AnnaBridge 157:e7ca05fa8600 209 #define IS_LPTIM_AUTORELOAD(__AUTORELOAD__) ((__AUTORELOAD__) <= 0x0000FFFFU)
AnnaBridge 157:e7ca05fa8600 210
AnnaBridge 157:e7ca05fa8600 211 /* Check compare value */
AnnaBridge 157:e7ca05fa8600 212 #define IS_LPTIM_COMPARE(__COMPARE__) ((__COMPARE__) <= 0x0000FFFFU)
AnnaBridge 157:e7ca05fa8600 213
AnnaBridge 157:e7ca05fa8600 214 /** @defgroup LPTIM_Clock_Source Clock source
AnnaBridge 157:e7ca05fa8600 215 * @{
AnnaBridge 157:e7ca05fa8600 216 */
AnnaBridge 157:e7ca05fa8600 217 #define LPTIM_CLOCKSOURCE_APBCLOCK_LPOSC ((uint32_t)0x00U)
AnnaBridge 157:e7ca05fa8600 218 #define LPTIM_CLOCKSOURCE_ULPTIM LPTIM_CFGR_CKSEL
AnnaBridge 157:e7ca05fa8600 219 /**
AnnaBridge 157:e7ca05fa8600 220 * @}
AnnaBridge 157:e7ca05fa8600 221 */
AnnaBridge 157:e7ca05fa8600 222 #define IS_LPTIM_CLOCK_SOURCE(__SOURCE__) (((__SOURCE__) == LPTIM_CLOCKSOURCE_ULPTIM) || \
AnnaBridge 157:e7ca05fa8600 223 ((__SOURCE__) == LPTIM_CLOCKSOURCE_APBCLOCK_LPOSC))
AnnaBridge 157:e7ca05fa8600 224
AnnaBridge 157:e7ca05fa8600 225
AnnaBridge 157:e7ca05fa8600 226 /** @defgroup LPTIM_Clock_Prescaler Prescaler
AnnaBridge 157:e7ca05fa8600 227 * @{
AnnaBridge 157:e7ca05fa8600 228 */
AnnaBridge 157:e7ca05fa8600 229 #define LPTIM_PRESCALER_DIV1 ((uint32_t)0x000000U)
AnnaBridge 157:e7ca05fa8600 230 #define LPTIM_PRESCALER_DIV2 LPTIM_CFGR_PRESC_0
AnnaBridge 157:e7ca05fa8600 231 #define LPTIM_PRESCALER_DIV4 LPTIM_CFGR_PRESC_1
AnnaBridge 157:e7ca05fa8600 232 #define LPTIM_PRESCALER_DIV8 ((uint32_t)(LPTIM_CFGR_PRESC_0 | LPTIM_CFGR_PRESC_1))
AnnaBridge 157:e7ca05fa8600 233 #define LPTIM_PRESCALER_DIV16 LPTIM_CFGR_PRESC_2
AnnaBridge 157:e7ca05fa8600 234 #define LPTIM_PRESCALER_DIV32 ((uint32_t)(LPTIM_CFGR_PRESC_0 | LPTIM_CFGR_PRESC_2))
AnnaBridge 157:e7ca05fa8600 235 #define LPTIM_PRESCALER_DIV64 ((uint32_t)(LPTIM_CFGR_PRESC_1 | LPTIM_CFGR_PRESC_2))
AnnaBridge 157:e7ca05fa8600 236 #define LPTIM_PRESCALER_DIV128 ((uint32_t)LPTIM_CFGR_PRESC)
AnnaBridge 157:e7ca05fa8600 237 /**
AnnaBridge 157:e7ca05fa8600 238 * @}
AnnaBridge 157:e7ca05fa8600 239 */
AnnaBridge 157:e7ca05fa8600 240
AnnaBridge 157:e7ca05fa8600 241 #define IS_LPTIM_CLOCK_PRESCALER(__PRESCALER__) (((__PRESCALER__) == LPTIM_PRESCALER_DIV1 ) || \
AnnaBridge 157:e7ca05fa8600 242 ((__PRESCALER__) == LPTIM_PRESCALER_DIV2 ) || \
AnnaBridge 157:e7ca05fa8600 243 ((__PRESCALER__) == LPTIM_PRESCALER_DIV4 ) || \
AnnaBridge 157:e7ca05fa8600 244 ((__PRESCALER__) == LPTIM_PRESCALER_DIV8 ) || \
AnnaBridge 157:e7ca05fa8600 245 ((__PRESCALER__) == LPTIM_PRESCALER_DIV16 ) || \
AnnaBridge 157:e7ca05fa8600 246 ((__PRESCALER__) == LPTIM_PRESCALER_DIV32 ) || \
AnnaBridge 157:e7ca05fa8600 247 ((__PRESCALER__) == LPTIM_PRESCALER_DIV64 ) || \
AnnaBridge 157:e7ca05fa8600 248 ((__PRESCALER__) == LPTIM_PRESCALER_DIV128))
AnnaBridge 157:e7ca05fa8600 249
AnnaBridge 157:e7ca05fa8600 250 #define IS_LPTIM_CLOCK_PRESCALERDIV1(__PRESCALER__) ((__PRESCALER__) == LPTIM_PRESCALER_DIV1)
AnnaBridge 157:e7ca05fa8600 251
AnnaBridge 157:e7ca05fa8600 252
AnnaBridge 157:e7ca05fa8600 253 /** @defgroup LPTIM_Output_Polarity Output polarity
AnnaBridge 157:e7ca05fa8600 254 * @{
AnnaBridge 157:e7ca05fa8600 255 */
AnnaBridge 157:e7ca05fa8600 256 #define LPTIM_OUTPUTPOLARITY_HIGH ((uint32_t)0x00000000U)
AnnaBridge 157:e7ca05fa8600 257 #define LPTIM_OUTPUTPOLARITY_LOW (LPTIM_CFGR_WAVPOL)
AnnaBridge 157:e7ca05fa8600 258 /**
AnnaBridge 157:e7ca05fa8600 259 * @}
AnnaBridge 157:e7ca05fa8600 260 */
AnnaBridge 157:e7ca05fa8600 261 #define IS_LPTIM_OUTPUT_POLARITY(__POLARITY__) (((__POLARITY__) == LPTIM_OUTPUTPOLARITY_LOW ) || \
AnnaBridge 157:e7ca05fa8600 262 ((__POLARITY__) == LPTIM_OUTPUTPOLARITY_HIGH))
AnnaBridge 157:e7ca05fa8600 263
AnnaBridge 157:e7ca05fa8600 264 /** @defgroup LPTIM_Clock_Sample_Time Clock sample time
AnnaBridge 157:e7ca05fa8600 265 * @{
AnnaBridge 157:e7ca05fa8600 266 */
AnnaBridge 157:e7ca05fa8600 267 #define LPTIM_CLOCKSAMPLETIME_DIRECTTRANSITION ((uint32_t)0x00000000U)
AnnaBridge 157:e7ca05fa8600 268 #define LPTIM_CLOCKSAMPLETIME_2TRANSITIONS LPTIM_CFGR_CKFLT_0
AnnaBridge 157:e7ca05fa8600 269 #define LPTIM_CLOCKSAMPLETIME_4TRANSITIONS LPTIM_CFGR_CKFLT_1
AnnaBridge 157:e7ca05fa8600 270 #define LPTIM_CLOCKSAMPLETIME_8TRANSITIONS LPTIM_CFGR_CKFLT
AnnaBridge 157:e7ca05fa8600 271 /**
AnnaBridge 157:e7ca05fa8600 272 * @}
AnnaBridge 157:e7ca05fa8600 273 */
AnnaBridge 157:e7ca05fa8600 274 #define IS_LPTIM_CLOCK_SAMPLE_TIME(__SAMPLETIME__) (((__SAMPLETIME__) == LPTIM_CLOCKSAMPLETIME_DIRECTTRANSITION) || \
AnnaBridge 157:e7ca05fa8600 275 ((__SAMPLETIME__) == LPTIM_CLOCKSAMPLETIME_2TRANSITIONS) || \
AnnaBridge 157:e7ca05fa8600 276 ((__SAMPLETIME__) == LPTIM_CLOCKSAMPLETIME_4TRANSITIONS) || \
AnnaBridge 157:e7ca05fa8600 277 ((__SAMPLETIME__) == LPTIM_CLOCKSAMPLETIME_8TRANSITIONS))
AnnaBridge 157:e7ca05fa8600 278
AnnaBridge 157:e7ca05fa8600 279 /** @defgroup LPTIM_Clock_Polarity Clock polarity
AnnaBridge 157:e7ca05fa8600 280 * @{
AnnaBridge 157:e7ca05fa8600 281 */
AnnaBridge 157:e7ca05fa8600 282 #define LPTIM_CLOCKPOLARITY_RISING ((uint32_t)0x00000000U)
AnnaBridge 157:e7ca05fa8600 283 #define LPTIM_CLOCKPOLARITY_FALLING LPTIM_CFGR_CKPOL_0
AnnaBridge 157:e7ca05fa8600 284 #define LPTIM_CLOCKPOLARITY_RISING_FALLING LPTIM_CFGR_CKPOL_1
AnnaBridge 157:e7ca05fa8600 285 /**
AnnaBridge 157:e7ca05fa8600 286 * @}
AnnaBridge 157:e7ca05fa8600 287 */
AnnaBridge 157:e7ca05fa8600 288
AnnaBridge 157:e7ca05fa8600 289 #define IS_LPTIM_CLOCK_POLARITY(__POLARITY__) (((__POLARITY__) == LPTIM_CLOCKPOLARITY_RISING) || \
AnnaBridge 157:e7ca05fa8600 290 ((__POLARITY__) == LPTIM_CLOCKPOLARITY_FALLING) || \
AnnaBridge 157:e7ca05fa8600 291 ((__POLARITY__) == LPTIM_CLOCKPOLARITY_RISING_FALLING))
AnnaBridge 157:e7ca05fa8600 292
AnnaBridge 157:e7ca05fa8600 293 /** @defgroup LPTIM_External_Trigger_Polarity Trigger polarity
AnnaBridge 157:e7ca05fa8600 294 * @{
AnnaBridge 157:e7ca05fa8600 295 */
AnnaBridge 157:e7ca05fa8600 296 #define LPTIM_ACTIVEEDGE_RISING LPTIM_CFGR_TRIGEN_0
AnnaBridge 157:e7ca05fa8600 297 #define LPTIM_ACTIVEEDGE_FALLING LPTIM_CFGR_TRIGEN_1
AnnaBridge 157:e7ca05fa8600 298 #define LPTIM_ACTIVEEDGE_RISING_FALLING LPTIM_CFGR_TRIGEN
AnnaBridge 157:e7ca05fa8600 299 /**
AnnaBridge 157:e7ca05fa8600 300 * @}
AnnaBridge 157:e7ca05fa8600 301 */
AnnaBridge 157:e7ca05fa8600 302 #define IS_LPTIM_EXT_TRG_POLARITY(__POLAR__) (((__POLAR__) == LPTIM_ACTIVEEDGE_RISING ) || \
AnnaBridge 157:e7ca05fa8600 303 ((__POLAR__) == LPTIM_ACTIVEEDGE_FALLING ) || \
AnnaBridge 157:e7ca05fa8600 304 ((__POLAR__) == LPTIM_ACTIVEEDGE_RISING_FALLING ))
AnnaBridge 157:e7ca05fa8600 305
AnnaBridge 157:e7ca05fa8600 306 /** @defgroup LPTIM_Trigger_Sample_Time Trigger sample time
AnnaBridge 157:e7ca05fa8600 307 * @{
AnnaBridge 157:e7ca05fa8600 308 */
AnnaBridge 157:e7ca05fa8600 309 #define LPTIM_TRIGSAMPLETIME_DIRECTTRANSITION ((uint32_t)0x00000000U)
AnnaBridge 157:e7ca05fa8600 310 #define LPTIM_TRIGSAMPLETIME_2TRANSITIONS LPTIM_CFGR_TRGFLT_0
AnnaBridge 157:e7ca05fa8600 311 #define LPTIM_TRIGSAMPLETIME_4TRANSITIONS LPTIM_CFGR_TRGFLT_1
AnnaBridge 157:e7ca05fa8600 312 #define LPTIM_TRIGSAMPLETIME_8TRANSITIONS LPTIM_CFGR_TRGFLT
AnnaBridge 157:e7ca05fa8600 313 /**
AnnaBridge 157:e7ca05fa8600 314 * @}
AnnaBridge 157:e7ca05fa8600 315 */
AnnaBridge 157:e7ca05fa8600 316 #define IS_LPTIM_TRIG_SAMPLE_TIME(__SAMPLETIME__) (((__SAMPLETIME__) == LPTIM_TRIGSAMPLETIME_DIRECTTRANSITION ) || \
AnnaBridge 157:e7ca05fa8600 317 ((__SAMPLETIME__) == LPTIM_TRIGSAMPLETIME_2TRANSITIONS ) || \
AnnaBridge 157:e7ca05fa8600 318 ((__SAMPLETIME__) == LPTIM_TRIGSAMPLETIME_4TRANSITIONS ) || \
AnnaBridge 157:e7ca05fa8600 319 ((__SAMPLETIME__) == LPTIM_TRIGSAMPLETIME_8TRANSITIONS ))
AnnaBridge 157:e7ca05fa8600 320
AnnaBridge 157:e7ca05fa8600 321
AnnaBridge 157:e7ca05fa8600 322 /** @defgroup LPTIM_Updating_Mode Updating mode
AnnaBridge 157:e7ca05fa8600 323 * @{
AnnaBridge 157:e7ca05fa8600 324 */
AnnaBridge 157:e7ca05fa8600 325
AnnaBridge 157:e7ca05fa8600 326 #define LPTIM_UPDATE_IMMEDIATE ((uint32_t)0x00000000U)
AnnaBridge 157:e7ca05fa8600 327 #define LPTIM_UPDATE_ENDOFPERIOD LPTIM_CFGR_PRELOAD
AnnaBridge 157:e7ca05fa8600 328 /**
AnnaBridge 157:e7ca05fa8600 329 * @}
AnnaBridge 157:e7ca05fa8600 330 */
AnnaBridge 157:e7ca05fa8600 331 #define IS_LPTIM_UPDATE_MODE(__MODE__) (((__MODE__) == LPTIM_UPDATE_IMMEDIATE) || \
AnnaBridge 157:e7ca05fa8600 332 ((__MODE__) == LPTIM_UPDATE_ENDOFPERIOD))
AnnaBridge 157:e7ca05fa8600 333
AnnaBridge 157:e7ca05fa8600 334
AnnaBridge 157:e7ca05fa8600 335
AnnaBridge 157:e7ca05fa8600 336 /** @defgroup LPTIM_Counter_Source Counter source
AnnaBridge 157:e7ca05fa8600 337 * @{
AnnaBridge 157:e7ca05fa8600 338 */
AnnaBridge 157:e7ca05fa8600 339 #define LPTIM_COUNTERSOURCE_INTERNAL ((uint32_t)0x00000000U)
AnnaBridge 157:e7ca05fa8600 340 #define LPTIM_COUNTERSOURCE_EXTERNAL LPTIM_CFGR_COUNTMODE
AnnaBridge 157:e7ca05fa8600 341 /**
AnnaBridge 157:e7ca05fa8600 342 * @}
AnnaBridge 157:e7ca05fa8600 343 */
AnnaBridge 157:e7ca05fa8600 344 #define IS_LPTIM_COUNTER_SOURCE(__SOURCE__) (((__SOURCE__) == LPTIM_COUNTERSOURCE_INTERNAL) || \
AnnaBridge 157:e7ca05fa8600 345 ((__SOURCE__) == LPTIM_COUNTERSOURCE_EXTERNAL))
AnnaBridge 157:e7ca05fa8600 346
AnnaBridge 157:e7ca05fa8600 347
AnnaBridge 157:e7ca05fa8600 348
AnnaBridge 157:e7ca05fa8600 349 /* Check for period value */
AnnaBridge 157:e7ca05fa8600 350 #define IS_LPTIM_PERIOD(__PERIOD__) ((__PERIOD__) <= 0x0000FFFFU)
AnnaBridge 157:e7ca05fa8600 351
AnnaBridge 157:e7ca05fa8600 352 /* Check for pulse value */
AnnaBridge 157:e7ca05fa8600 353 #define IS_LPTIM_PULSE(__PULSE__) ((__PULSE__) <= 0x0000FFFFU)
AnnaBridge 157:e7ca05fa8600 354
AnnaBridge 157:e7ca05fa8600 355 /** @defgroup LPTIM_Flag_Definition Flag definition
AnnaBridge 157:e7ca05fa8600 356 * @{
AnnaBridge 157:e7ca05fa8600 357 */
AnnaBridge 157:e7ca05fa8600 358 #define LPTIM_FLAG_DOWN LPTIM_ISR_DOWN
AnnaBridge 157:e7ca05fa8600 359 #define LPTIM_FLAG_UP LPTIM_ISR_UP
AnnaBridge 157:e7ca05fa8600 360 #define LPTIM_FLAG_ARROK LPTIM_ISR_ARROK
AnnaBridge 157:e7ca05fa8600 361 #define LPTIM_FLAG_CMPOK LPTIM_ISR_CMPOK
AnnaBridge 157:e7ca05fa8600 362 #define LPTIM_FLAG_EXTTRIG LPTIM_ISR_EXTTRIG
AnnaBridge 157:e7ca05fa8600 363 #define LPTIM_FLAG_ARRM LPTIM_ISR_ARRM
AnnaBridge 157:e7ca05fa8600 364 #define LPTIM_FLAG_CMPM LPTIM_ISR_CMPM
AnnaBridge 157:e7ca05fa8600 365 /**
AnnaBridge 157:e7ca05fa8600 366 * @}
AnnaBridge 157:e7ca05fa8600 367 */
AnnaBridge 157:e7ca05fa8600 368
AnnaBridge 157:e7ca05fa8600 369 /** @defgroup LPTIM_Interrupts_Definition Interrupts definition
AnnaBridge 157:e7ca05fa8600 370 * @{
AnnaBridge 157:e7ca05fa8600 371 */
AnnaBridge 157:e7ca05fa8600 372 #define LPTIM_IT_DOWN LPTIM_IER_DOWNIE
AnnaBridge 157:e7ca05fa8600 373 #define LPTIM_IT_UP LPTIM_IER_UPIE
AnnaBridge 157:e7ca05fa8600 374 #define LPTIM_IT_ARROK LPTIM_IER_ARROKIE
AnnaBridge 157:e7ca05fa8600 375 #define LPTIM_IT_CMPOK LPTIM_IER_CMPOKIE
AnnaBridge 157:e7ca05fa8600 376 #define LPTIM_IT_EXTTRIG LPTIM_IER_EXTTRIGIE
AnnaBridge 157:e7ca05fa8600 377 #define LPTIM_IT_ARRM LPTIM_IER_ARRMIE
AnnaBridge 157:e7ca05fa8600 378 #define LPTIM_IT_CMPM LPTIM_IER_CMPMIE
AnnaBridge 157:e7ca05fa8600 379 /**
AnnaBridge 157:e7ca05fa8600 380 * @}
AnnaBridge 157:e7ca05fa8600 381 */
AnnaBridge 157:e7ca05fa8600 382
AnnaBridge 157:e7ca05fa8600 383 /**
AnnaBridge 157:e7ca05fa8600 384 * @}
AnnaBridge 157:e7ca05fa8600 385 */
AnnaBridge 157:e7ca05fa8600 386
AnnaBridge 157:e7ca05fa8600 387 /* Exported macro ------------------------------------------------------------*/
AnnaBridge 157:e7ca05fa8600 388
AnnaBridge 157:e7ca05fa8600 389 /** @defgroup LPTIM_Exported_Macros LPTIM Exported Macros
AnnaBridge 157:e7ca05fa8600 390 * @{
AnnaBridge 157:e7ca05fa8600 391 */
AnnaBridge 157:e7ca05fa8600 392
AnnaBridge 157:e7ca05fa8600 393 /** @brief Reset LPTIM handle state
AnnaBridge 157:e7ca05fa8600 394 * @param __HANDLE__: LPTIM handle
AnnaBridge 157:e7ca05fa8600 395 * @retval None
AnnaBridge 157:e7ca05fa8600 396 */
AnnaBridge 157:e7ca05fa8600 397 #define __HAL_LPTIM_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_LPTIM_STATE_RESET)
AnnaBridge 157:e7ca05fa8600 398
AnnaBridge 157:e7ca05fa8600 399 /**
AnnaBridge 157:e7ca05fa8600 400 * @brief Enable/Disable the LPTIM peripheral.
AnnaBridge 157:e7ca05fa8600 401 * @param __HANDLE__: LPTIM handle
AnnaBridge 157:e7ca05fa8600 402 * @retval None
AnnaBridge 157:e7ca05fa8600 403 */
AnnaBridge 157:e7ca05fa8600 404 #define __HAL_LPTIM_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (LPTIM_CR_ENABLE))
AnnaBridge 157:e7ca05fa8600 405 #define __HAL_LPTIM_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(LPTIM_CR_ENABLE))
AnnaBridge 157:e7ca05fa8600 406
AnnaBridge 157:e7ca05fa8600 407 /**
AnnaBridge 157:e7ca05fa8600 408 * @brief Starts the LPTIM peripheral in Continuous or in single mode.
AnnaBridge 157:e7ca05fa8600 409 * @param __HANDLE__: DMA handle
AnnaBridge 157:e7ca05fa8600 410 * @retval None
AnnaBridge 157:e7ca05fa8600 411 */
AnnaBridge 157:e7ca05fa8600 412 #define __HAL_LPTIM_START_CONTINUOUS(__HANDLE__) ((__HANDLE__)->Instance->CR |= LPTIM_CR_CNTSTRT)
AnnaBridge 157:e7ca05fa8600 413 #define __HAL_LPTIM_START_SINGLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= LPTIM_CR_SNGSTRT)
AnnaBridge 157:e7ca05fa8600 414
AnnaBridge 157:e7ca05fa8600 415
AnnaBridge 157:e7ca05fa8600 416 /**
AnnaBridge 157:e7ca05fa8600 417 * @brief Writes the passed parameter in the Autoreload register.
AnnaBridge 157:e7ca05fa8600 418 * @param __HANDLE__: LPTIM handle
AnnaBridge 157:e7ca05fa8600 419 * @param __VALUE__ : Autoreload value
AnnaBridge 157:e7ca05fa8600 420 * @retval None
AnnaBridge 157:e7ca05fa8600 421 */
AnnaBridge 157:e7ca05fa8600 422 #define __HAL_LPTIM_AUTORELOAD_SET(__HANDLE__ , __VALUE__) ((__HANDLE__)->Instance->ARR = (__VALUE__))
AnnaBridge 157:e7ca05fa8600 423
AnnaBridge 157:e7ca05fa8600 424 /**
AnnaBridge 157:e7ca05fa8600 425 * @brief Writes the passed parameter in the Compare register.
AnnaBridge 157:e7ca05fa8600 426 * @param __HANDLE__: LPTIM handle
AnnaBridge 157:e7ca05fa8600 427 * @param __VALUE__ : Compare value
AnnaBridge 157:e7ca05fa8600 428 * @retval None
AnnaBridge 157:e7ca05fa8600 429 */
AnnaBridge 157:e7ca05fa8600 430 #define __HAL_LPTIM_COMPARE_SET(__HANDLE__ , __VALUE__) ((__HANDLE__)->Instance->CMP = (__VALUE__))
AnnaBridge 157:e7ca05fa8600 431
AnnaBridge 157:e7ca05fa8600 432 /**
AnnaBridge 157:e7ca05fa8600 433 * @brief Checks whether the specified LPTIM flag is set or not.
AnnaBridge 157:e7ca05fa8600 434 * @param __HANDLE__: LPTIM handle
AnnaBridge 157:e7ca05fa8600 435 * @param __FLAG__ : LPTIM flag to check
AnnaBridge 157:e7ca05fa8600 436 * This parameter can be a value of:
AnnaBridge 157:e7ca05fa8600 437 * @arg LPTIM_FLAG_DOWN : Counter direction change up Flag.
AnnaBridge 157:e7ca05fa8600 438 * @arg LPTIM_FLAG_UP : Counter direction change down to up Flag.
AnnaBridge 157:e7ca05fa8600 439 * @arg LPTIM_FLAG_ARROK : Autoreload register update OK Flag.
AnnaBridge 157:e7ca05fa8600 440 * @arg LPTIM_FLAG_CMPOK : Compare register update OK Flag.
AnnaBridge 157:e7ca05fa8600 441 * @arg LPTIM_FLAG_EXTTRIG : External trigger edge event Flag.
AnnaBridge 157:e7ca05fa8600 442 * @arg LPTIM_FLAG_ARRM : Autoreload match Flag.
AnnaBridge 157:e7ca05fa8600 443 * @arg LPTIM_FLAG_CMPM : Compare match Flag.
AnnaBridge 157:e7ca05fa8600 444 * @retval The state of the specified flag (SET or RESET).
AnnaBridge 157:e7ca05fa8600 445 */
AnnaBridge 157:e7ca05fa8600 446 #define __HAL_LPTIM_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR &(__FLAG__)) == (__FLAG__))
AnnaBridge 157:e7ca05fa8600 447
AnnaBridge 157:e7ca05fa8600 448 /**
AnnaBridge 157:e7ca05fa8600 449 * @brief Clears the specified LPTIM flag.
AnnaBridge 157:e7ca05fa8600 450 * @param __HANDLE__: LPTIM handle.
AnnaBridge 157:e7ca05fa8600 451 * @param __FLAG__ : LPTIM flag to clear.
AnnaBridge 157:e7ca05fa8600 452 * This parameter can be a value of:
AnnaBridge 157:e7ca05fa8600 453 * @arg LPTIM_FLAG_DOWN : Counter direction change up Flag.
AnnaBridge 157:e7ca05fa8600 454 * @arg LPTIM_FLAG_UP : Counter direction change down to up Flag.
AnnaBridge 157:e7ca05fa8600 455 * @arg LPTIM_FLAG_ARROK : Autoreload register update OK Flag.
AnnaBridge 157:e7ca05fa8600 456 * @arg LPTIM_FLAG_CMPOK : Compare register update OK Flag.
AnnaBridge 157:e7ca05fa8600 457 * @arg LPTIM_FLAG_EXTTRIG : External trigger edge event Flag.
AnnaBridge 157:e7ca05fa8600 458 * @arg LPTIM_FLAG_ARRM : Autoreload match Flag.
AnnaBridge 157:e7ca05fa8600 459 * @arg LPTIM_FLAG_CMPM : Compare match Flag.
AnnaBridge 157:e7ca05fa8600 460 * @retval None.
AnnaBridge 157:e7ca05fa8600 461 */
AnnaBridge 157:e7ca05fa8600 462 #define __HAL_LPTIM_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__))
AnnaBridge 157:e7ca05fa8600 463
AnnaBridge 157:e7ca05fa8600 464 /**
AnnaBridge 157:e7ca05fa8600 465 * @brief Enable the specified LPTIM interrupt.
AnnaBridge 157:e7ca05fa8600 466 * @param __HANDLE__ : LPTIM handle.
AnnaBridge 157:e7ca05fa8600 467 * @param __INTERRUPT__ : LPTIM interrupt to set.
AnnaBridge 157:e7ca05fa8600 468 * This parameter can be a value of:
AnnaBridge 157:e7ca05fa8600 469 * @arg LPTIM_IT_DOWN : Counter direction change up Interrupt.
AnnaBridge 157:e7ca05fa8600 470 * @arg LPTIM_IT_UP : Counter direction change down to up Interrupt.
AnnaBridge 157:e7ca05fa8600 471 * @arg LPTIM_IT_ARROK : Autoreload register update OK Interrupt.
AnnaBridge 157:e7ca05fa8600 472 * @arg LPTIM_IT_CMPOK : Compare register update OK Interrupt.
AnnaBridge 157:e7ca05fa8600 473 * @arg LPTIM_IT_EXTTRIG : External trigger edge event Interrupt.
AnnaBridge 157:e7ca05fa8600 474 * @arg LPTIM_IT_ARRM : Autoreload match Interrupt.
AnnaBridge 157:e7ca05fa8600 475 * @arg LPTIM_IT_CMPM : Compare match Interrupt.
AnnaBridge 157:e7ca05fa8600 476 * @retval None.
AnnaBridge 157:e7ca05fa8600 477 */
AnnaBridge 157:e7ca05fa8600 478 #define __HAL_LPTIM_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER |= (__INTERRUPT__))
AnnaBridge 157:e7ca05fa8600 479
AnnaBridge 157:e7ca05fa8600 480 /**
AnnaBridge 157:e7ca05fa8600 481 * @brief Disable the specified LPTIM interrupt.
AnnaBridge 157:e7ca05fa8600 482 * @param __HANDLE__ : LPTIM handle.
AnnaBridge 157:e7ca05fa8600 483 * @param __INTERRUPT__ : LPTIM interrupt to set.
AnnaBridge 157:e7ca05fa8600 484 * This parameter can be a value of:
AnnaBridge 157:e7ca05fa8600 485 * @arg LPTIM_IT_DOWN : Counter direction change up Interrupt.
AnnaBridge 157:e7ca05fa8600 486 * @arg LPTIM_IT_UP : Counter direction change down to up Interrupt.
AnnaBridge 157:e7ca05fa8600 487 * @arg LPTIM_IT_ARROK : Autoreload register update OK Interrupt.
AnnaBridge 157:e7ca05fa8600 488 * @arg LPTIM_IT_CMPOK : Compare register update OK Interrupt.
AnnaBridge 157:e7ca05fa8600 489 * @arg LPTIM_IT_EXTTRIG : External trigger edge event Interrupt.
AnnaBridge 157:e7ca05fa8600 490 * @arg LPTIM_IT_ARRM : Autoreload match Interrupt.
AnnaBridge 157:e7ca05fa8600 491 * @arg LPTIM_IT_CMPM : Compare match Interrupt.
AnnaBridge 157:e7ca05fa8600 492 * @retval None.
AnnaBridge 157:e7ca05fa8600 493 */
AnnaBridge 157:e7ca05fa8600 494 #define __HAL_LPTIM_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER &= (~(__INTERRUPT__)))
AnnaBridge 157:e7ca05fa8600 495
AnnaBridge 157:e7ca05fa8600 496 /**
AnnaBridge 157:e7ca05fa8600 497 * @brief Checks whether the specified LPTIM interrupt is set or not.
AnnaBridge 157:e7ca05fa8600 498 * @param __HANDLE__ : LPTIM handle.
AnnaBridge 157:e7ca05fa8600 499 * @param __INTERRUPT__ : LPTIM interrupt to check.
AnnaBridge 157:e7ca05fa8600 500 * This parameter can be a value of:
AnnaBridge 157:e7ca05fa8600 501 * @arg LPTIM_IT_DOWN : Counter direction change up Interrupt.
AnnaBridge 157:e7ca05fa8600 502 * @arg LPTIM_IT_UP : Counter direction change down to up Interrupt.
AnnaBridge 157:e7ca05fa8600 503 * @arg LPTIM_IT_ARROK : Autoreload register update OK Interrupt.
AnnaBridge 157:e7ca05fa8600 504 * @arg LPTIM_IT_CMPOK : Compare register update OK Interrupt.
AnnaBridge 157:e7ca05fa8600 505 * @arg LPTIM_IT_EXTTRIG : External trigger edge event Interrupt.
AnnaBridge 157:e7ca05fa8600 506 * @arg LPTIM_IT_ARRM : Autoreload match Interrupt.
AnnaBridge 157:e7ca05fa8600 507 * @arg LPTIM_IT_CMPM : Compare match Interrupt.
AnnaBridge 157:e7ca05fa8600 508 * @retval Interrupt status.
AnnaBridge 157:e7ca05fa8600 509 */
AnnaBridge 157:e7ca05fa8600 510
AnnaBridge 157:e7ca05fa8600 511 #define __HAL_LPTIM_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->IER & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
AnnaBridge 157:e7ca05fa8600 512
AnnaBridge 157:e7ca05fa8600 513 /**
AnnaBridge 157:e7ca05fa8600 514 * @brief Enable interrupt on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 515 * @retval None
AnnaBridge 157:e7ca05fa8600 516 */
AnnaBridge 157:e7ca05fa8600 517 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_IT() (EXTI->IMR |= LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 518
AnnaBridge 157:e7ca05fa8600 519 /**
AnnaBridge 157:e7ca05fa8600 520 * @brief Disable interrupt on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 521 * @retval None
AnnaBridge 157:e7ca05fa8600 522 */
AnnaBridge 157:e7ca05fa8600 523 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_IT() (EXTI->IMR &= ~(LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 157:e7ca05fa8600 524
AnnaBridge 157:e7ca05fa8600 525 /**
AnnaBridge 157:e7ca05fa8600 526 * @brief Enable event on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 527 * @retval None.
AnnaBridge 157:e7ca05fa8600 528 */
AnnaBridge 157:e7ca05fa8600 529 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_EVENT() (EXTI->EMR |= LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 530
AnnaBridge 157:e7ca05fa8600 531 /**
AnnaBridge 157:e7ca05fa8600 532 * @brief Disable event on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 533 * @retval None.
AnnaBridge 157:e7ca05fa8600 534 */
AnnaBridge 157:e7ca05fa8600 535 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_EVENT() (EXTI->EMR &= ~(LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 157:e7ca05fa8600 536
AnnaBridge 157:e7ca05fa8600 537 /**
AnnaBridge 157:e7ca05fa8600 538 * @brief Enable falling edge trigger on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 539 * @retval None.
AnnaBridge 157:e7ca05fa8600 540 */
AnnaBridge 157:e7ca05fa8600 541 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_FALLING_EDGE() (EXTI->FTSR |= LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 542
AnnaBridge 157:e7ca05fa8600 543 /**
AnnaBridge 157:e7ca05fa8600 544 * @brief Disable falling edge trigger on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 545 * @retval None.
AnnaBridge 157:e7ca05fa8600 546 */
AnnaBridge 157:e7ca05fa8600 547 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_FALLING_EDGE() (EXTI->FTSR &= ~(LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 157:e7ca05fa8600 548
AnnaBridge 157:e7ca05fa8600 549 /**
AnnaBridge 157:e7ca05fa8600 550 * @brief Enable rising edge trigger on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 551 * @retval None.
AnnaBridge 157:e7ca05fa8600 552 */
AnnaBridge 157:e7ca05fa8600 553 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE() (EXTI->RTSR |= LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 554
AnnaBridge 157:e7ca05fa8600 555 /**
AnnaBridge 157:e7ca05fa8600 556 * @brief Disable rising edge trigger on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 557 * @retval None.
AnnaBridge 157:e7ca05fa8600 558 */
AnnaBridge 157:e7ca05fa8600 559 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_RISING_EDGE() (EXTI->RTSR &= ~(LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT))
AnnaBridge 157:e7ca05fa8600 560
AnnaBridge 157:e7ca05fa8600 561 /**
AnnaBridge 157:e7ca05fa8600 562 * @brief Enable rising & falling edge trigger on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 563 * @retval None.
AnnaBridge 157:e7ca05fa8600 564 */
AnnaBridge 157:e7ca05fa8600 565 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_RISING_FALLING_EDGE() do{__HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE();\
AnnaBridge 157:e7ca05fa8600 566 __HAL_LPTIM_WAKEUPTIMER_EXTI_ENABLE_FALLING_EDGE();\
AnnaBridge 157:e7ca05fa8600 567 }while(0)
AnnaBridge 157:e7ca05fa8600 568
AnnaBridge 157:e7ca05fa8600 569 /**
AnnaBridge 157:e7ca05fa8600 570 * @brief Disable rising & falling edge trigger on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 571 * @retval None.
AnnaBridge 157:e7ca05fa8600 572 */
AnnaBridge 157:e7ca05fa8600 573 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_RISING_FALLING_EDGE() do{__HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_RISING_EDGE();\
AnnaBridge 157:e7ca05fa8600 574 __HAL_LPTIM_WAKEUPTIMER_EXTI_DISABLE_FALLING_EDGE();\
AnnaBridge 157:e7ca05fa8600 575 }while(0)
AnnaBridge 157:e7ca05fa8600 576
AnnaBridge 157:e7ca05fa8600 577 /**
AnnaBridge 157:e7ca05fa8600 578 * @brief Check whether the LPTIM Wake-up Timer associated Exti line interrupt flag is set or not.
AnnaBridge 157:e7ca05fa8600 579 * @retval Line Status.
AnnaBridge 157:e7ca05fa8600 580 */
AnnaBridge 157:e7ca05fa8600 581 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_GET_FLAG() (EXTI->PR & LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 582
AnnaBridge 157:e7ca05fa8600 583 /**
AnnaBridge 157:e7ca05fa8600 584 * @brief Clear the LPTIM Wake-up Timer associated Exti line flag.
AnnaBridge 157:e7ca05fa8600 585 * @retval None.
AnnaBridge 157:e7ca05fa8600 586 */
AnnaBridge 157:e7ca05fa8600 587 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_CLEAR_FLAG() (EXTI->PR = LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 588
AnnaBridge 157:e7ca05fa8600 589 /**
AnnaBridge 157:e7ca05fa8600 590 * @brief Generate a Software interrupt on the LPTIM Wake-up Timer associated Exti line.
AnnaBridge 157:e7ca05fa8600 591 * @retval None.
AnnaBridge 157:e7ca05fa8600 592 */
AnnaBridge 157:e7ca05fa8600 593 #define __HAL_LPTIM_WAKEUPTIMER_EXTI_GENERATE_SWIT() (EXTI->SWIER |= LPTIM_EXTI_LINE_WAKEUPTIMER_EVENT)
AnnaBridge 157:e7ca05fa8600 594
AnnaBridge 157:e7ca05fa8600 595 /**
AnnaBridge 157:e7ca05fa8600 596 * @}
AnnaBridge 157:e7ca05fa8600 597 */
AnnaBridge 157:e7ca05fa8600 598
AnnaBridge 157:e7ca05fa8600 599
AnnaBridge 157:e7ca05fa8600 600 /* Include LPTIM HAL Extension module */
AnnaBridge 157:e7ca05fa8600 601 #include "stm32l0xx_hal_lptim_ex.h"
AnnaBridge 157:e7ca05fa8600 602
AnnaBridge 157:e7ca05fa8600 603 /* Exported functions --------------------------------------------------------*/
AnnaBridge 157:e7ca05fa8600 604
AnnaBridge 157:e7ca05fa8600 605 /** @defgroup LPTIM_Exported_Functions LPTIM Exported Functions
AnnaBridge 157:e7ca05fa8600 606 * @{
AnnaBridge 157:e7ca05fa8600 607 */
AnnaBridge 157:e7ca05fa8600 608 /* Initialization/de-initialization functions ********************************/
AnnaBridge 157:e7ca05fa8600 609
AnnaBridge 157:e7ca05fa8600 610 /** @defgroup LPTIM_Exported_Functions_Group1 Initialization/de-initialization functions
AnnaBridge 157:e7ca05fa8600 611 * @{
AnnaBridge 157:e7ca05fa8600 612 */
AnnaBridge 157:e7ca05fa8600 613 HAL_StatusTypeDef HAL_LPTIM_Init(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 614 HAL_StatusTypeDef HAL_LPTIM_DeInit(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 615
AnnaBridge 157:e7ca05fa8600 616
AnnaBridge 157:e7ca05fa8600 617 /* MSP functions *************************************************************/
AnnaBridge 157:e7ca05fa8600 618
AnnaBridge 157:e7ca05fa8600 619 void HAL_LPTIM_MspInit(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 620 void HAL_LPTIM_MspDeInit(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 621
AnnaBridge 157:e7ca05fa8600 622 /**
AnnaBridge 157:e7ca05fa8600 623 * @}
AnnaBridge 157:e7ca05fa8600 624 */
AnnaBridge 157:e7ca05fa8600 625
AnnaBridge 157:e7ca05fa8600 626 /* Start/Stop operation functions *********************************************/
AnnaBridge 157:e7ca05fa8600 627
AnnaBridge 157:e7ca05fa8600 628 /** @defgroup LPTIM_Exported_Functions_Group2 LPTIM Start-Stop operation functions
AnnaBridge 157:e7ca05fa8600 629 * @{
AnnaBridge 157:e7ca05fa8600 630 */
AnnaBridge 157:e7ca05fa8600 631
AnnaBridge 157:e7ca05fa8600 632 /* ################################# PWM Mode ################################*/
AnnaBridge 157:e7ca05fa8600 633 /* Blocking mode: Polling */
AnnaBridge 157:e7ca05fa8600 634 HAL_StatusTypeDef HAL_LPTIM_PWM_Start(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Pulse);
AnnaBridge 157:e7ca05fa8600 635 HAL_StatusTypeDef HAL_LPTIM_PWM_Stop(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 636 /* Non-Blocking mode: Interrupt */
AnnaBridge 157:e7ca05fa8600 637 HAL_StatusTypeDef HAL_LPTIM_PWM_Start_IT(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Pulse);
AnnaBridge 157:e7ca05fa8600 638 HAL_StatusTypeDef HAL_LPTIM_PWM_Stop_IT(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 639
AnnaBridge 157:e7ca05fa8600 640 /* ############################# One Pulse Mode ##############################*/
AnnaBridge 157:e7ca05fa8600 641 /* Blocking mode: Polling */
AnnaBridge 157:e7ca05fa8600 642 HAL_StatusTypeDef HAL_LPTIM_OnePulse_Start(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Pulse);
AnnaBridge 157:e7ca05fa8600 643 HAL_StatusTypeDef HAL_LPTIM_OnePulse_Stop(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 644 /* Non-Blocking mode: Interrupt */
AnnaBridge 157:e7ca05fa8600 645 HAL_StatusTypeDef HAL_LPTIM_OnePulse_Start_IT(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Pulse);
AnnaBridge 157:e7ca05fa8600 646 HAL_StatusTypeDef HAL_LPTIM_OnePulse_Stop_IT(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 647
AnnaBridge 157:e7ca05fa8600 648 /* ############################## Set once Mode ##############################*/
AnnaBridge 157:e7ca05fa8600 649 /* Blocking mode: Polling */
AnnaBridge 157:e7ca05fa8600 650 HAL_StatusTypeDef HAL_LPTIM_SetOnce_Start(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Pulse);
AnnaBridge 157:e7ca05fa8600 651 HAL_StatusTypeDef HAL_LPTIM_SetOnce_Stop(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 652 /* Non-Blocking mode: Interrupt */
AnnaBridge 157:e7ca05fa8600 653 HAL_StatusTypeDef HAL_LPTIM_SetOnce_Start_IT(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Pulse);
AnnaBridge 157:e7ca05fa8600 654 HAL_StatusTypeDef HAL_LPTIM_SetOnce_Stop_IT(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 655
AnnaBridge 157:e7ca05fa8600 656 /* ############################### Encoder Mode ##############################*/
AnnaBridge 157:e7ca05fa8600 657 /* Blocking mode: Polling */
AnnaBridge 157:e7ca05fa8600 658 HAL_StatusTypeDef HAL_LPTIM_Encoder_Start(LPTIM_HandleTypeDef *hlptim, uint32_t Period);
AnnaBridge 157:e7ca05fa8600 659 HAL_StatusTypeDef HAL_LPTIM_Encoder_Stop(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 660 /* Non-Blocking mode: Interrupt */
AnnaBridge 157:e7ca05fa8600 661 HAL_StatusTypeDef HAL_LPTIM_Encoder_Start_IT(LPTIM_HandleTypeDef *hlptim, uint32_t Period);
AnnaBridge 157:e7ca05fa8600 662 HAL_StatusTypeDef HAL_LPTIM_Encoder_Stop_IT(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 663
AnnaBridge 157:e7ca05fa8600 664 /* ############################# Time out Mode ##############################*/
AnnaBridge 157:e7ca05fa8600 665 /* Blocking mode: Polling */
AnnaBridge 157:e7ca05fa8600 666 HAL_StatusTypeDef HAL_LPTIM_TimeOut_Start(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Timeout);
AnnaBridge 157:e7ca05fa8600 667 HAL_StatusTypeDef HAL_LPTIM_TimeOut_Stop(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 668 /* Non-Blocking mode: Interrupt */
AnnaBridge 157:e7ca05fa8600 669 HAL_StatusTypeDef HAL_LPTIM_TimeOut_Start_IT(LPTIM_HandleTypeDef *hlptim, uint32_t Period, uint32_t Timeout);
AnnaBridge 157:e7ca05fa8600 670 HAL_StatusTypeDef HAL_LPTIM_TimeOut_Stop_IT(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 671
AnnaBridge 157:e7ca05fa8600 672 /* ############################## Counter Mode ###############################*/
AnnaBridge 157:e7ca05fa8600 673 /* Blocking mode: Polling */
AnnaBridge 157:e7ca05fa8600 674 HAL_StatusTypeDef HAL_LPTIM_Counter_Start(LPTIM_HandleTypeDef *hlptim, uint32_t Period);
AnnaBridge 157:e7ca05fa8600 675 HAL_StatusTypeDef HAL_LPTIM_Counter_Stop(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 676 /* Non-Blocking mode: Interrupt */
AnnaBridge 157:e7ca05fa8600 677 HAL_StatusTypeDef HAL_LPTIM_Counter_Start_IT(LPTIM_HandleTypeDef *hlptim, uint32_t Period);
AnnaBridge 157:e7ca05fa8600 678 HAL_StatusTypeDef HAL_LPTIM_Counter_Stop_IT(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 679
AnnaBridge 157:e7ca05fa8600 680 /**
AnnaBridge 157:e7ca05fa8600 681 * @}
AnnaBridge 157:e7ca05fa8600 682 */
AnnaBridge 157:e7ca05fa8600 683
AnnaBridge 157:e7ca05fa8600 684 /* Reading operation functions ************************************************/
AnnaBridge 157:e7ca05fa8600 685
AnnaBridge 157:e7ca05fa8600 686 /** @defgroup LPTIM_Exported_Functions_Group3 LPTIM Read operation functions
AnnaBridge 157:e7ca05fa8600 687 * @{
AnnaBridge 157:e7ca05fa8600 688 */
AnnaBridge 157:e7ca05fa8600 689 uint32_t HAL_LPTIM_ReadCounter(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 690 uint32_t HAL_LPTIM_ReadAutoReload(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 691 uint32_t HAL_LPTIM_ReadCompare(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 692 /**
AnnaBridge 157:e7ca05fa8600 693 * @}
AnnaBridge 157:e7ca05fa8600 694 */
AnnaBridge 157:e7ca05fa8600 695
AnnaBridge 157:e7ca05fa8600 696 /* LPTIM IRQ functions *******************************************************/
AnnaBridge 157:e7ca05fa8600 697 /** @defgroup LPTIM_Exported_Functions_Group4 LPTIM IRQ handler
AnnaBridge 157:e7ca05fa8600 698 * @{
AnnaBridge 157:e7ca05fa8600 699 */
AnnaBridge 157:e7ca05fa8600 700 void HAL_LPTIM_IRQHandler(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 701
AnnaBridge 157:e7ca05fa8600 702 /* CallBack functions ********************************************************/
AnnaBridge 157:e7ca05fa8600 703 void HAL_LPTIM_CompareMatchCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 704 void HAL_LPTIM_AutoReloadMatchCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 705 void HAL_LPTIM_TriggerCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 706 void HAL_LPTIM_CompareWriteCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 707 void HAL_LPTIM_AutoReloadWriteCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 708 void HAL_LPTIM_DirectionUpCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 709 void HAL_LPTIM_DirectionDownCallback(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 710 /**
AnnaBridge 157:e7ca05fa8600 711 * @}
AnnaBridge 157:e7ca05fa8600 712 */
AnnaBridge 157:e7ca05fa8600 713 /* Peripheral State functions ************************************************/
AnnaBridge 157:e7ca05fa8600 714 /** @defgroup LPTIM_Exported_Functions_Group5 Peripheral State functions
AnnaBridge 157:e7ca05fa8600 715 * @{
AnnaBridge 157:e7ca05fa8600 716 */
AnnaBridge 157:e7ca05fa8600 717
AnnaBridge 157:e7ca05fa8600 718 HAL_LPTIM_StateTypeDef HAL_LPTIM_GetState(LPTIM_HandleTypeDef *hlptim);
AnnaBridge 157:e7ca05fa8600 719
AnnaBridge 157:e7ca05fa8600 720 /**
AnnaBridge 157:e7ca05fa8600 721 * @}
AnnaBridge 157:e7ca05fa8600 722 */
AnnaBridge 157:e7ca05fa8600 723
AnnaBridge 157:e7ca05fa8600 724 /**
AnnaBridge 157:e7ca05fa8600 725 * @}
AnnaBridge 157:e7ca05fa8600 726 */
AnnaBridge 157:e7ca05fa8600 727
AnnaBridge 157:e7ca05fa8600 728 /**
AnnaBridge 157:e7ca05fa8600 729 * @}
AnnaBridge 157:e7ca05fa8600 730 */
AnnaBridge 157:e7ca05fa8600 731
AnnaBridge 157:e7ca05fa8600 732 /**
AnnaBridge 157:e7ca05fa8600 733 * @}
AnnaBridge 157:e7ca05fa8600 734 */
AnnaBridge 157:e7ca05fa8600 735
AnnaBridge 157:e7ca05fa8600 736 #ifdef __cplusplus
AnnaBridge 157:e7ca05fa8600 737 }
AnnaBridge 157:e7ca05fa8600 738 #endif
AnnaBridge 157:e7ca05fa8600 739
AnnaBridge 157:e7ca05fa8600 740 #endif /* __STM32L0xx_HAL_LPTIM_H */
AnnaBridge 157:e7ca05fa8600 741
AnnaBridge 157:e7ca05fa8600 742 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
AnnaBridge 157:e7ca05fa8600 743