hc32l196_lvd.h 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. /******************************************************************************
  2. * Copyright (C) 2017, Huada Semiconductor Co.,Ltd All rights reserved.
  3. *
  4. * This software is owned and published by:
  5. * Huada Semiconductor Co.,Ltd ("HDSC").
  6. *
  7. * BY DOWNLOADING, INSTALLING OR USING THIS SOFTWARE, YOU AGREE TO BE BOUND
  8. * BY ALL THE TERMS AND CONDITIONS OF THIS AGREEMENT.
  9. *
  10. * This software contains source code for use with HDSC
  11. * components. This software is licensed by HDSC to be adapted only
  12. * for use in systems utilizing HDSC components. HDSC shall not be
  13. * responsible for misuse or illegal use of this software for devices not
  14. * supported herein. HDSC is providing this software "AS IS" and will
  15. * not be responsible for issues arising from incorrect user implementation
  16. * of the software.
  17. *
  18. * Disclaimer:
  19. * HDSC MAKES NO WARRANTY, EXPRESS OR IMPLIED, ARISING BY LAW OR OTHERWISE,
  20. * REGARDING THE SOFTWARE (INCLUDING ANY ACOOMPANYING WRITTEN MATERIALS),
  21. * ITS PERFORMANCE OR SUITABILITY FOR YOUR INTENDED USE, INCLUDING,
  22. * WITHOUT LIMITATION, THE IMPLIED WARRANTY OF MERCHANTABILITY, THE IMPLIED
  23. * WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE, AND THE IMPLIED
  24. * WARRANTY OF NONINFRINGEMENT.
  25. * HDSC SHALL HAVE NO LIABILITY (WHETHER IN CONTRACT, WARRANTY, TORT,
  26. * NEGLIGENCE OR OTHERWISE) FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT
  27. * LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION,
  28. * LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING FROM USE OR
  29. * INABILITY TO USE THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY DIRECT,
  30. * INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES OR LOSS OF DATA,
  31. * SAVINGS OR PROFITS,
  32. * EVEN IF Disclaimer HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  33. * YOU ASSUME ALL RESPONSIBILITIES FOR SELECTION OF THE SOFTWARE TO ACHIEVE YOUR
  34. * INTENDED RESULTS, AND FOR THE INSTALLATION OF, USE OF, AND RESULTS OBTAINED
  35. * FROM, THE SOFTWARE.
  36. *
  37. * This software may be replicated in part or whole for the licensed use,
  38. * with the restriction that this Disclaimer and Copyright notice must be
  39. * included with each copy of this software, whether used in part or whole,
  40. * at all times.
  41. */
  42. /******************************************************************************/
  43. /** \file lvd.h
  44. **
  45. ** Headerfile for Low Voltage Detector functions
  46. **
  47. ** - 2017-06-28 Alex First Version
  48. **
  49. ******************************************************************************/
  50. #ifndef __LVD_H__
  51. #define __LVD_H__
  52. /******************************************************************************
  53. * Include files
  54. ******************************************************************************/
  55. #include "ddl.h"
  56. /* C binding of definitions if building with C++ compiler */
  57. #ifdef __cplusplus
  58. extern "C"
  59. {
  60. #endif
  61. /**
  62. ******************************************************************************
  63. ** \defgroup LvdGroup Low Voltage Detector (LVD)
  64. **
  65. ******************************************************************************/
  66. //@{
  67. /******************************************************************************
  68. * Global type definitions
  69. ******************************************************************************/
  70. /**
  71. ******************************************************************************
  72. ** \brief LVD监测电压源选择
  73. **
  74. ** \note
  75. ******************************************************************************/
  76. typedef enum en_lvd_input_src
  77. {
  78. LvdInputSrcMskVCC = 0u<<2, ///< Vcc
  79. LvdInputSrcMskPC13 = 1u<<2, ///< PC13
  80. LvdInputSrcMskPB08 = 2u<<2, ///< PB08
  81. LvdInputSrcMskPB07 = 3u<<2, ///< PB07
  82. }en_lvd_input_src_t;
  83. /**
  84. ******************************************************************************
  85. ** \brief LVD阈值电压选择
  86. **
  87. ** \note
  88. ******************************************************************************/
  89. typedef enum en_lvd_threshold
  90. {
  91. LvdMskTH1_8V = 0u<<4, ///< 1.8V
  92. LvdMskTH1_9V = 1u<<4, ///< 1.9V
  93. LvdMskTH2_0V = 2u<<4, ///< 2.0V
  94. LvdMskTH2_1V = 3u<<4, ///< 2.1V
  95. LvdMskTH2_2V = 4u<<4, ///< 2.2V
  96. LvdMskTH2_3V = 5u<<4, ///< 2.3V
  97. LvdMskTH2_4V = 6u<<4, ///< 2.4V
  98. LvdMskTH2_5V = 7u<<4, ///< 2.5V
  99. LvdMskTH2_6V = 8u<<4, ///< 2.6V
  100. LvdMskTH2_7V = 9u<<4, ///< 2.7V
  101. LvdMskTH2_8V = 10u<<4, ///< 2.8V
  102. LvdMskTH2_9V = 11u<<4, ///< 2.9V
  103. LvdMskTH3_0V = 12u<<4, ///< 3.0V
  104. LvdMskTH3_1V = 13u<<4, ///< 3.1V
  105. LvdMskTH3_2V = 14u<<4, ///< 3.2V
  106. LvdMskTH3_3V = 15u<<4, ///< 3.3V
  107. }en_lvd_threshold_t;
  108. /**
  109. ******************************************************************************
  110. ** \brief LVD输出滤波时间
  111. **
  112. ** \note
  113. ******************************************************************************/
  114. typedef enum en_lvd_filter_time
  115. {
  116. LvdFilterMsk7us = 0u<<9, ///< 7us
  117. LvdFilterMsk14us = 1u<<9, ///< 14us
  118. LvdFilterMsk28us = 2u<<9, ///< 28us
  119. LvdFilterMsk112us = 3u<<9, ///< 112us
  120. LvdFilterMsk450us = 4u<<9, ///< 450us
  121. LvdFilterMsk1_8ms = 5u<<9, ///< 1.8ms
  122. LvdFilterMsk7_2ms = 6u<<9, ///< 7.3ms
  123. LvdFilterMsk28_8ms = 7u<<9, ///< 28.8ms
  124. }en_lvd_filter_time_t;
  125. /**
  126. ******************************************************************************
  127. ** \brief LVD中断触发方式
  128. **
  129. ** \note
  130. ******************************************************************************/
  131. typedef enum en_lvd_irq_type
  132. {
  133. LvdIrqMskRiseFall = 3u<<12, ///< 上升/下降沿触发
  134. LvdIrqMskHigh = 1u<<14, ///< 高电平触发
  135. LvdIrqMskRise = 1u<<13, ///< 上升沿触发
  136. LvdIrqMskFall = 1u<<12, ///< 下降沿触发
  137. }en_lvd_irq_type_t;
  138. /**
  139. ******************************************************************************
  140. ** \brief LVD触发动作选择
  141. **
  142. ** \note
  143. ******************************************************************************/
  144. typedef enum en_lvd_act
  145. {
  146. LvdActMskReset = 1u<<1, ///< 系统复位
  147. LvdActMskInt = 0u, ///< NVIC中断
  148. }en_lvd_act_t;
  149. /**
  150. ******************************************************************************
  151. ** \brief LVD数字滤波使能配置
  152. **
  153. ** \note
  154. ******************************************************************************/
  155. typedef enum en_lvd_filter
  156. {
  157. LvdFilterMskEnable = 1u<<8, ///< 数字滤波使能
  158. LvdFilterMskDisable = 0u, ///< 数字滤波禁止
  159. }en_lvd_filter_t;
  160. /**
  161. ******************************************************************************
  162. ** \brief LVD配置
  163. ** \note
  164. ******************************************************************************/
  165. typedef struct stc_lvd_cfg
  166. {
  167. en_lvd_act_t enAct; ///< LVD触发动作
  168. en_lvd_input_src_t enInputSrc; ///< LVD输入电压源
  169. en_lvd_threshold_t enThreshold; ///< LVD监测电压
  170. en_lvd_filter_t enFilter; ///< 是否使用输出滤波
  171. en_lvd_filter_time_t enFilterTime; ///< 输出滤波时间
  172. en_lvd_irq_type_t enIrqType; ///< 中断触发方式
  173. }stc_lvd_cfg_t;
  174. /******************************************************************************
  175. * Global definitions
  176. ******************************************************************************/
  177. /******************************************************************************
  178. * Local type definitions ('typedef')
  179. ******************************************************************************/
  180. /******************************************************************************
  181. * Global variable definitions ('extern')
  182. ******************************************************************************/
  183. /******************************************************************************
  184. * Global function prototypes (definition in C source)
  185. ******************************************************************************/
  186. //irq enable/disable
  187. void Lvd_EnableIrq(void);
  188. void Lvd_DisableIrq(void);
  189. // irq function
  190. void Lvd_ClearIrq(void);
  191. boolean_t Lvd_GetIrqStat(void);
  192. // fliter function
  193. boolean_t Lvd_GetFilterResult(void);
  194. //init/deinit function
  195. void Lvd_Init(stc_lvd_cfg_t *pstcCfg);
  196. //LVD function enable/disable
  197. void Lvd_Enable(void);
  198. void Lvd_Disable(void);
  199. //@} // LvdGroup
  200. #ifdef __cplusplus
  201. }
  202. #endif
  203. #endif /* __LVD_H__ */
  204. /******************************************************************************
  205. * EOF (not truncated)
  206. ******************************************************************************/