2 ******************************************************************************
3 * @file stm32f1xx_ll_pwr.h
4 * @author MCD Application Team
7 * @brief Header file of PWR LL module.
8 ******************************************************************************
11 * <h2><center>© COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
13 * Redistribution and use in source and binary forms, with or without modification,
14 * are permitted provided that the following conditions are met:
15 * 1. Redistributions of source code must retain the above copyright notice,
16 * this list of conditions and the following disclaimer.
17 * 2. Redistributions in binary form must reproduce the above copyright notice,
18 * this list of conditions and the following disclaimer in the documentation
19 * and/or other materials provided with the distribution.
20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
21 * may be used to endorse or promote products derived from this software
22 * without specific prior written permission.
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35 ******************************************************************************
38 /* Define to prevent recursive inclusion -------------------------------------*/
39 #ifndef __STM32F1xx_LL_PWR_H
40 #define __STM32F1xx_LL_PWR_H
46 /* Includes ------------------------------------------------------------------*/
47 #include "stm32f1xx.h"
49 /** @addtogroup STM32F1xx_LL_Driver
55 /** @defgroup PWR_LL PWR
59 /* Private types -------------------------------------------------------------*/
60 /* Private variables ---------------------------------------------------------*/
61 /* Private constants ---------------------------------------------------------*/
62 /* Private macros ------------------------------------------------------------*/
63 /* Exported types ------------------------------------------------------------*/
64 /* Exported constants --------------------------------------------------------*/
65 /** @defgroup PWR_LL_Exported_Constants PWR Exported Constants
69 /** @defgroup PWR_LL_EC_CLEAR_FLAG Clear Flags Defines
70 * @brief Flags defines which can be used with LL_PWR_WriteReg function
73 #define LL_PWR_CR_CSBF PWR_CR_CSBF /*!< Clear standby flag */
74 #define LL_PWR_CR_CWUF PWR_CR_CWUF /*!< Clear wakeup flag */
79 /** @defgroup PWR_LL_EC_GET_FLAG Get Flags Defines
80 * @brief Flags defines which can be used with LL_PWR_ReadReg function
83 #define LL_PWR_CSR_WUF PWR_CSR_WUF /*!< Wakeup flag */
84 #define LL_PWR_CSR_SBF PWR_CSR_SBF /*!< Standby flag */
85 #define LL_PWR_CSR_PVDO PWR_CSR_PVDO /*!< Power voltage detector output flag */
86 #define LL_PWR_CSR_EWUP1 PWR_CSR_EWUP /*!< Enable WKUP pin 1 */
92 /** @defgroup PWR_LL_EC_MODE_PWR Mode Power
95 #define LL_PWR_MODE_STOP_MAINREGU 0x00000000U /*!< Enter Stop mode when the CPU enters deepsleep */
96 #define LL_PWR_MODE_STOP_LPREGU (PWR_CR_LPDS) /*!< Enter Stop mode (with low power Regulator ON) when the CPU enters deepsleep */
97 #define LL_PWR_MODE_STANDBY (PWR_CR_PDDS) /*!< Enter Standby mode when the CPU enters deepsleep */
102 /** @defgroup PWR_LL_EC_REGU_MODE_DS_MODE Regulator Mode In Deep Sleep Mode
105 #define LL_PWR_REGU_DSMODE_MAIN 0x00000000U /*!< Voltage Regulator in main mode during deepsleep mode */
106 #define LL_PWR_REGU_DSMODE_LOW_POWER (PWR_CR_LPDS) /*!< Voltage Regulator in low-power mode during deepsleep mode */
111 /** @defgroup PWR_LL_EC_PVDLEVEL Power Voltage Detector Level
114 #define LL_PWR_PVDLEVEL_0 (PWR_CR_PLS_LEV0) /*!< Voltage threshold detected by PVD 2.2 V */
115 #define LL_PWR_PVDLEVEL_1 (PWR_CR_PLS_LEV1) /*!< Voltage threshold detected by PVD 2.3 V */
116 #define LL_PWR_PVDLEVEL_2 (PWR_CR_PLS_LEV2) /*!< Voltage threshold detected by PVD 2.4 V */
117 #define LL_PWR_PVDLEVEL_3 (PWR_CR_PLS_LEV3) /*!< Voltage threshold detected by PVD 2.5 V */
118 #define LL_PWR_PVDLEVEL_4 (PWR_CR_PLS_LEV4) /*!< Voltage threshold detected by PVD 2.6 V */
119 #define LL_PWR_PVDLEVEL_5 (PWR_CR_PLS_LEV5) /*!< Voltage threshold detected by PVD 2.7 V */
120 #define LL_PWR_PVDLEVEL_6 (PWR_CR_PLS_LEV6) /*!< Voltage threshold detected by PVD 2.8 V */
121 #define LL_PWR_PVDLEVEL_7 (PWR_CR_PLS_LEV7) /*!< Voltage threshold detected by PVD 2.9 V */
125 /** @defgroup PWR_LL_EC_WAKEUP_PIN Wakeup Pins
128 #define LL_PWR_WAKEUP_PIN1 (PWR_CSR_EWUP) /*!< WKUP pin 1 : PA0 */
138 /* Exported macro ------------------------------------------------------------*/
139 /** @defgroup PWR_LL_Exported_Macros PWR Exported Macros
143 /** @defgroup PWR_LL_EM_WRITE_READ Common write and read registers Macros
148 * @brief Write a value in PWR register
149 * @param __REG__ Register to be written
150 * @param __VALUE__ Value to be written in the register
153 #define LL_PWR_WriteReg(__REG__, __VALUE__) WRITE_REG(PWR->__REG__, (__VALUE__))
156 * @brief Read a value in PWR register
157 * @param __REG__ Register to be read
158 * @retval Register value
160 #define LL_PWR_ReadReg(__REG__) READ_REG(PWR->__REG__)
169 /* Exported functions --------------------------------------------------------*/
170 /** @defgroup PWR_LL_Exported_Functions PWR Exported Functions
174 /** @defgroup PWR_LL_EF_Configuration Configuration
179 * @brief Enable access to the backup domain
180 * @rmtoll CR DBP LL_PWR_EnableBkUpAccess
183 __STATIC_INLINE
void LL_PWR_EnableBkUpAccess(void)
185 SET_BIT(PWR
->CR
, PWR_CR_DBP
);
189 * @brief Disable access to the backup domain
190 * @rmtoll CR DBP LL_PWR_DisableBkUpAccess
193 __STATIC_INLINE
void LL_PWR_DisableBkUpAccess(void)
195 CLEAR_BIT(PWR
->CR
, PWR_CR_DBP
);
199 * @brief Check if the backup domain is enabled
200 * @rmtoll CR DBP LL_PWR_IsEnabledBkUpAccess
201 * @retval State of bit (1 or 0).
203 __STATIC_INLINE
uint32_t LL_PWR_IsEnabledBkUpAccess(void)
205 return (READ_BIT(PWR
->CR
, PWR_CR_DBP
) == (PWR_CR_DBP
));
209 * @brief Set voltage Regulator mode during deep sleep mode
210 * @rmtoll CR LPDS LL_PWR_SetRegulModeDS
211 * @param RegulMode This parameter can be one of the following values:
212 * @arg @ref LL_PWR_REGU_DSMODE_MAIN
213 * @arg @ref LL_PWR_REGU_DSMODE_LOW_POWER
216 __STATIC_INLINE
void LL_PWR_SetRegulModeDS(uint32_t RegulMode
)
218 MODIFY_REG(PWR
->CR
, PWR_CR_LPDS
, RegulMode
);
222 * @brief Get voltage Regulator mode during deep sleep mode
223 * @rmtoll CR LPDS LL_PWR_GetRegulModeDS
224 * @retval Returned value can be one of the following values:
225 * @arg @ref LL_PWR_REGU_DSMODE_MAIN
226 * @arg @ref LL_PWR_REGU_DSMODE_LOW_POWER
228 __STATIC_INLINE
uint32_t LL_PWR_GetRegulModeDS(void)
230 return (uint32_t)(READ_BIT(PWR
->CR
, PWR_CR_LPDS
));
234 * @brief Set Power Down mode when CPU enters deepsleep
235 * @rmtoll CR PDDS LL_PWR_SetPowerMode\n
236 * @rmtoll CR LPDS LL_PWR_SetPowerMode
237 * @param PDMode This parameter can be one of the following values:
238 * @arg @ref LL_PWR_MODE_STOP_MAINREGU
239 * @arg @ref LL_PWR_MODE_STOP_LPREGU
240 * @arg @ref LL_PWR_MODE_STANDBY
243 __STATIC_INLINE
void LL_PWR_SetPowerMode(uint32_t PDMode
)
245 MODIFY_REG(PWR
->CR
, (PWR_CR_PDDS
| PWR_CR_LPDS
), PDMode
);
249 * @brief Get Power Down mode when CPU enters deepsleep
250 * @rmtoll CR PDDS LL_PWR_GetPowerMode\n
251 * @rmtoll CR LPDS LL_PWR_GetPowerMode
252 * @retval Returned value can be one of the following values:
253 * @arg @ref LL_PWR_MODE_STOP_MAINREGU
254 * @arg @ref LL_PWR_MODE_STOP_LPREGU
255 * @arg @ref LL_PWR_MODE_STANDBY
257 __STATIC_INLINE
uint32_t LL_PWR_GetPowerMode(void)
259 return (uint32_t)(READ_BIT(PWR
->CR
, (PWR_CR_PDDS
| PWR_CR_LPDS
)));
263 * @brief Configure the voltage threshold detected by the Power Voltage Detector
264 * @rmtoll CR PLS LL_PWR_SetPVDLevel
265 * @param PVDLevel This parameter can be one of the following values:
266 * @arg @ref LL_PWR_PVDLEVEL_0
267 * @arg @ref LL_PWR_PVDLEVEL_1
268 * @arg @ref LL_PWR_PVDLEVEL_2
269 * @arg @ref LL_PWR_PVDLEVEL_3
270 * @arg @ref LL_PWR_PVDLEVEL_4
271 * @arg @ref LL_PWR_PVDLEVEL_5
272 * @arg @ref LL_PWR_PVDLEVEL_6
273 * @arg @ref LL_PWR_PVDLEVEL_7
276 __STATIC_INLINE
void LL_PWR_SetPVDLevel(uint32_t PVDLevel
)
278 MODIFY_REG(PWR
->CR
, PWR_CR_PLS
, PVDLevel
);
282 * @brief Get the voltage threshold detection
283 * @rmtoll CR PLS LL_PWR_GetPVDLevel
284 * @retval Returned value can be one of the following values:
285 * @arg @ref LL_PWR_PVDLEVEL_0
286 * @arg @ref LL_PWR_PVDLEVEL_1
287 * @arg @ref LL_PWR_PVDLEVEL_2
288 * @arg @ref LL_PWR_PVDLEVEL_3
289 * @arg @ref LL_PWR_PVDLEVEL_4
290 * @arg @ref LL_PWR_PVDLEVEL_5
291 * @arg @ref LL_PWR_PVDLEVEL_6
292 * @arg @ref LL_PWR_PVDLEVEL_7
294 __STATIC_INLINE
uint32_t LL_PWR_GetPVDLevel(void)
296 return (uint32_t)(READ_BIT(PWR
->CR
, PWR_CR_PLS
));
300 * @brief Enable Power Voltage Detector
301 * @rmtoll CR PVDE LL_PWR_EnablePVD
304 __STATIC_INLINE
void LL_PWR_EnablePVD(void)
306 SET_BIT(PWR
->CR
, PWR_CR_PVDE
);
310 * @brief Disable Power Voltage Detector
311 * @rmtoll CR PVDE LL_PWR_DisablePVD
314 __STATIC_INLINE
void LL_PWR_DisablePVD(void)
316 CLEAR_BIT(PWR
->CR
, PWR_CR_PVDE
);
320 * @brief Check if Power Voltage Detector is enabled
321 * @rmtoll CR PVDE LL_PWR_IsEnabledPVD
322 * @retval State of bit (1 or 0).
324 __STATIC_INLINE
uint32_t LL_PWR_IsEnabledPVD(void)
326 return (READ_BIT(PWR
->CR
, PWR_CR_PVDE
) == (PWR_CR_PVDE
));
330 * @brief Enable the WakeUp PINx functionality
331 * @rmtoll CSR EWUP LL_PWR_EnableWakeUpPin
332 * @param WakeUpPin This parameter can be one of the following values:
333 * @arg @ref LL_PWR_WAKEUP_PIN1
336 __STATIC_INLINE
void LL_PWR_EnableWakeUpPin(uint32_t WakeUpPin
)
338 SET_BIT(PWR
->CSR
, WakeUpPin
);
342 * @brief Disable the WakeUp PINx functionality
343 * @rmtoll CSR EWUP LL_PWR_DisableWakeUpPin
344 * @param WakeUpPin This parameter can be one of the following values:
345 * @arg @ref LL_PWR_WAKEUP_PIN1
348 __STATIC_INLINE
void LL_PWR_DisableWakeUpPin(uint32_t WakeUpPin
)
350 CLEAR_BIT(PWR
->CSR
, WakeUpPin
);
354 * @brief Check if the WakeUp PINx functionality is enabled
355 * @rmtoll CSR EWUP LL_PWR_IsEnabledWakeUpPin
356 * @param WakeUpPin This parameter can be one of the following values:
357 * @arg @ref LL_PWR_WAKEUP_PIN1
358 * @retval State of bit (1 or 0).
360 __STATIC_INLINE
uint32_t LL_PWR_IsEnabledWakeUpPin(uint32_t WakeUpPin
)
362 return (READ_BIT(PWR
->CSR
, WakeUpPin
) == (WakeUpPin
));
370 /** @defgroup PWR_LL_EF_FLAG_Management FLAG_Management
375 * @brief Get Wake-up Flag
376 * @rmtoll CSR WUF LL_PWR_IsActiveFlag_WU
377 * @retval State of bit (1 or 0).
379 __STATIC_INLINE
uint32_t LL_PWR_IsActiveFlag_WU(void)
381 return (READ_BIT(PWR
->CSR
, PWR_CSR_WUF
) == (PWR_CSR_WUF
));
385 * @brief Get Standby Flag
386 * @rmtoll CSR SBF LL_PWR_IsActiveFlag_SB
387 * @retval State of bit (1 or 0).
389 __STATIC_INLINE
uint32_t LL_PWR_IsActiveFlag_SB(void)
391 return (READ_BIT(PWR
->CSR
, PWR_CSR_SBF
) == (PWR_CSR_SBF
));
395 * @brief Indicate whether VDD voltage is below the selected PVD threshold
396 * @rmtoll CSR PVDO LL_PWR_IsActiveFlag_PVDO
397 * @retval State of bit (1 or 0).
399 __STATIC_INLINE
uint32_t LL_PWR_IsActiveFlag_PVDO(void)
401 return (READ_BIT(PWR
->CSR
, PWR_CSR_PVDO
) == (PWR_CSR_PVDO
));
405 * @brief Clear Standby Flag
406 * @rmtoll CR CSBF LL_PWR_ClearFlag_SB
409 __STATIC_INLINE
void LL_PWR_ClearFlag_SB(void)
411 SET_BIT(PWR
->CR
, PWR_CR_CSBF
);
415 * @brief Clear Wake-up Flags
416 * @rmtoll CR CWUF LL_PWR_ClearFlag_WU
419 __STATIC_INLINE
void LL_PWR_ClearFlag_WU(void)
421 SET_BIT(PWR
->CR
, PWR_CR_CWUF
);
428 #if defined(USE_FULL_LL_DRIVER)
429 /** @defgroup PWR_LL_EF_Init De-initialization function
432 ErrorStatus
LL_PWR_DeInit(void);
436 #endif /* USE_FULL_LL_DRIVER */
446 #endif /* defined(PWR) */
456 #endif /* __STM32F1xx_LL_PWR_H */
458 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/