stm32f10x_bkp.h 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. /**
  2. ******************************************************************************
  3. * @file stm32f10x_bkp.h
  4. * @author MCD Application Team
  5. * @version V3.4.0
  6. * @date 10/15/2010
  7. * @brief This file contains all the functions prototypes for the BKP firmware
  8. * library.
  9. ******************************************************************************
  10. * @copy
  11. *
  12. * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  13. * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  14. * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  15. * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  16. * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  17. * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  18. *
  19. * <h2><center>&copy; COPYRIGHT 2010 STMicroelectronics</center></h2>
  20. */
  21. /* Define to prevent recursive inclusion -------------------------------------*/
  22. #ifndef __STM32F10x_BKP_H
  23. #define __STM32F10x_BKP_H
  24. #ifdef __cplusplus
  25. extern "C" {
  26. #endif
  27. /* Includes ------------------------------------------------------------------*/
  28. #include "stm32f10x.h"
  29. /** @addtogroup STM32F10x_StdPeriph_Driver
  30. * @{
  31. */
  32. /** @addtogroup BKP
  33. * @{
  34. */
  35. /** @defgroup BKP_Exported_Types
  36. * @{
  37. */
  38. /**
  39. * @}
  40. */
  41. /** @defgroup BKP_Exported_Constants
  42. * @{
  43. */
  44. /** @defgroup Tamper_Pin_active_level
  45. * @{
  46. */
  47. #define BKP_TamperPinLevel_High ((uint16_t)0x0000)
  48. #define BKP_TamperPinLevel_Low ((uint16_t)0x0001)
  49. #define IS_BKP_TAMPER_PIN_LEVEL(LEVEL) (((LEVEL) == BKP_TamperPinLevel_High) || \
  50. ((LEVEL) == BKP_TamperPinLevel_Low))
  51. /**
  52. * @}
  53. */
  54. /** @defgroup RTC_output_source_to_output_on_the_Tamper_pin
  55. * @{
  56. */
  57. #define BKP_RTCOutputSource_None ((uint16_t)0x0000)
  58. #define BKP_RTCOutputSource_CalibClock ((uint16_t)0x0080)
  59. #define BKP_RTCOutputSource_Alarm ((uint16_t)0x0100)
  60. #define BKP_RTCOutputSource_Second ((uint16_t)0x0300)
  61. #define IS_BKP_RTC_OUTPUT_SOURCE(SOURCE) (((SOURCE) == BKP_RTCOutputSource_None) || \
  62. ((SOURCE) == BKP_RTCOutputSource_CalibClock) || \
  63. ((SOURCE) == BKP_RTCOutputSource_Alarm) || \
  64. ((SOURCE) == BKP_RTCOutputSource_Second))
  65. /**
  66. * @}
  67. */
  68. /** @defgroup Data_Backup_Register
  69. * @{
  70. */
  71. #define BKP_DR1 ((uint16_t)0x0004)
  72. #define BKP_DR2 ((uint16_t)0x0008)
  73. #define BKP_DR3 ((uint16_t)0x000C)
  74. #define BKP_DR4 ((uint16_t)0x0010)
  75. #define BKP_DR5 ((uint16_t)0x0014)
  76. #define BKP_DR6 ((uint16_t)0x0018)
  77. #define BKP_DR7 ((uint16_t)0x001C)
  78. #define BKP_DR8 ((uint16_t)0x0020)
  79. #define BKP_DR9 ((uint16_t)0x0024)
  80. #define BKP_DR10 ((uint16_t)0x0028)
  81. #define BKP_DR11 ((uint16_t)0x0040)
  82. #define BKP_DR12 ((uint16_t)0x0044)
  83. #define BKP_DR13 ((uint16_t)0x0048)
  84. #define BKP_DR14 ((uint16_t)0x004C)
  85. #define BKP_DR15 ((uint16_t)0x0050)
  86. #define BKP_DR16 ((uint16_t)0x0054)
  87. #define BKP_DR17 ((uint16_t)0x0058)
  88. #define BKP_DR18 ((uint16_t)0x005C)
  89. #define BKP_DR19 ((uint16_t)0x0060)
  90. #define BKP_DR20 ((uint16_t)0x0064)
  91. #define BKP_DR21 ((uint16_t)0x0068)
  92. #define BKP_DR22 ((uint16_t)0x006C)
  93. #define BKP_DR23 ((uint16_t)0x0070)
  94. #define BKP_DR24 ((uint16_t)0x0074)
  95. #define BKP_DR25 ((uint16_t)0x0078)
  96. #define BKP_DR26 ((uint16_t)0x007C)
  97. #define BKP_DR27 ((uint16_t)0x0080)
  98. #define BKP_DR28 ((uint16_t)0x0084)
  99. #define BKP_DR29 ((uint16_t)0x0088)
  100. #define BKP_DR30 ((uint16_t)0x008C)
  101. #define BKP_DR31 ((uint16_t)0x0090)
  102. #define BKP_DR32 ((uint16_t)0x0094)
  103. #define BKP_DR33 ((uint16_t)0x0098)
  104. #define BKP_DR34 ((uint16_t)0x009C)
  105. #define BKP_DR35 ((uint16_t)0x00A0)
  106. #define BKP_DR36 ((uint16_t)0x00A4)
  107. #define BKP_DR37 ((uint16_t)0x00A8)
  108. #define BKP_DR38 ((uint16_t)0x00AC)
  109. #define BKP_DR39 ((uint16_t)0x00B0)
  110. #define BKP_DR40 ((uint16_t)0x00B4)
  111. #define BKP_DR41 ((uint16_t)0x00B8)
  112. #define BKP_DR42 ((uint16_t)0x00BC)
  113. #define IS_BKP_DR(DR) (((DR) == BKP_DR1) || ((DR) == BKP_DR2) || ((DR) == BKP_DR3) || \
  114. ((DR) == BKP_DR4) || ((DR) == BKP_DR5) || ((DR) == BKP_DR6) || \
  115. ((DR) == BKP_DR7) || ((DR) == BKP_DR8) || ((DR) == BKP_DR9) || \
  116. ((DR) == BKP_DR10) || ((DR) == BKP_DR11) || ((DR) == BKP_DR12) || \
  117. ((DR) == BKP_DR13) || ((DR) == BKP_DR14) || ((DR) == BKP_DR15) || \
  118. ((DR) == BKP_DR16) || ((DR) == BKP_DR17) || ((DR) == BKP_DR18) || \
  119. ((DR) == BKP_DR19) || ((DR) == BKP_DR20) || ((DR) == BKP_DR21) || \
  120. ((DR) == BKP_DR22) || ((DR) == BKP_DR23) || ((DR) == BKP_DR24) || \
  121. ((DR) == BKP_DR25) || ((DR) == BKP_DR26) || ((DR) == BKP_DR27) || \
  122. ((DR) == BKP_DR28) || ((DR) == BKP_DR29) || ((DR) == BKP_DR30) || \
  123. ((DR) == BKP_DR31) || ((DR) == BKP_DR32) || ((DR) == BKP_DR33) || \
  124. ((DR) == BKP_DR34) || ((DR) == BKP_DR35) || ((DR) == BKP_DR36) || \
  125. ((DR) == BKP_DR37) || ((DR) == BKP_DR38) || ((DR) == BKP_DR39) || \
  126. ((DR) == BKP_DR40) || ((DR) == BKP_DR41) || ((DR) == BKP_DR42))
  127. #define IS_BKP_CALIBRATION_VALUE(VALUE) ((VALUE) <= 0x7F)
  128. /**
  129. * @}
  130. */
  131. /**
  132. * @}
  133. */
  134. /** @defgroup BKP_Exported_Macros
  135. * @{
  136. */
  137. /**
  138. * @}
  139. */
  140. /** @defgroup BKP_Exported_Functions
  141. * @{
  142. */
  143. void BKP_DeInit(void);
  144. void BKP_TamperPinLevelConfig(uint16_t BKP_TamperPinLevel);
  145. void BKP_TamperPinCmd(FunctionalState NewState);
  146. void BKP_ITConfig(FunctionalState NewState);
  147. void BKP_RTCOutputConfig(uint16_t BKP_RTCOutputSource);
  148. void BKP_SetRTCCalibrationValue(uint8_t CalibrationValue);
  149. void BKP_WriteBackupRegister(uint16_t BKP_DR, uint16_t Data);
  150. uint16_t BKP_ReadBackupRegister(uint16_t BKP_DR);
  151. FlagStatus BKP_GetFlagStatus(void);
  152. void BKP_ClearFlag(void);
  153. ITStatus BKP_GetITStatus(void);
  154. void BKP_ClearITPendingBit(void);
  155. #ifdef __cplusplus
  156. }
  157. #endif
  158. #endif /* __STM32F10x_BKP_H */
  159. /**
  160. * @}
  161. */
  162. /**
  163. * @}
  164. */
  165. /**
  166. * @}
  167. */
  168. /******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/