SWM341_wdt.c 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /******************************************************************************************************************************************
  2. * 文件名称: SWM341_wdt.c
  3. * 功能说明: SWM341单片机的WDT看门狗功能驱动库
  4. * 技术支持: http://www.synwit.com.cn/e/tool/gbook/?bid=1
  5. * 注意事项:
  6. * 版本日期: V1.0.0 2016年1月30日
  7. * 升级记录:
  8. *
  9. *
  10. *******************************************************************************************************************************************
  11. * @attention
  12. *
  13. * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS WITH CODING INFORMATION
  14. * REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. AS A RESULT, SYNWIT SHALL NOT BE HELD LIABLE
  15. * FOR ANY DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE CONTENT
  16. * OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING INFORMATION CONTAINED HEREIN IN CONN-
  17. * -ECTION WITH THEIR PRODUCTS.
  18. *
  19. * COPYRIGHT 2012 Synwit Technology
  20. *******************************************************************************************************************************************/
  21. #include "SWM341.h"
  22. #include "SWM341_wdt.h"
  23. /******************************************************************************************************************************************
  24. * 函数名称: WDT_Init()
  25. * 功能说明: WDT看门狗初始化
  26. * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
  27. * uint32_t int_period 中断周期,取值1--2^16,单位1/1024秒,取值0表示关闭WDT中断功能
  28. * uint32_t rst_period 复位周期,取值1--2^16,单位1/1024秒,取值0表示关闭WDT复位功能
  29. * 输 出: 无
  30. * 注意事项: 此函数只能在芯片上电后调用一次,若需要重新配置 WDT,请调用 WDT_ReInit()
  31. ******************************************************************************************************************************************/
  32. void WDT_Init(WDT_TypeDef * WDTx, uint32_t int_period, uint32_t rst_period)
  33. {
  34. SYS->CLKEN0 |= (1 << SYS_CLKEN0_WDT_Pos);
  35. WDTx->CR &= ~WDT_CR_CKDIV_Msk;
  36. WDTx->CR |= (4 << WDT_CR_CKDIV_Pos); // 对时钟源 32 分频
  37. if(int_period == 0)
  38. {
  39. WDTx->CR &= ~(1 << WDT_CR_INTEN_Pos);
  40. NVIC_DisableIRQ(WDT_IRQn);
  41. }
  42. else
  43. {
  44. WDTx->CR |= (1 << WDT_CR_INTEN_Pos);
  45. WDTx->INTVAL = int_period;
  46. WDTx->IF = 1;
  47. NVIC_EnableIRQ(WDT_IRQn);
  48. }
  49. if(rst_period == 0)
  50. {
  51. WDTx->CR &= ~(1 << WDT_CR_RSTEN_Pos);
  52. WDTx->RSTVAL = int_period;
  53. }
  54. else
  55. {
  56. WDTx->CR |= (1 << WDT_CR_RSTEN_Pos);
  57. WDTx->RSTVAL = rst_period;
  58. }
  59. }
  60. /******************************************************************************************************************************************
  61. * 函数名称: WDT_ReInit()
  62. * 功能说明: WDT看门狗重新初始化
  63. * 输 入: 同 WDT_Init()
  64. * 输 出: 无
  65. * 注意事项: 执行 WDT_ReInit() 前请不要执行 WDT_Stop(),因为 WDT 停止状态下无法清零内部计数器
  66. ******************************************************************************************************************************************/
  67. void WDT_ReInit(WDT_TypeDef * WDTx, uint32_t int_period, uint32_t rst_period)
  68. {
  69. int i;
  70. /* WDT 已经在运行中,若新设置的 rst_period 比当前计数器值还小,WDT 需要计数到 2^16 溢出返回 0 才能触发中断和复位,
  71. 这里执行一下喂狗,保证计数器从零重新计数,避免上述问题 */
  72. WDT_Feed(WDTx);
  73. /* 等待 WDT 内部完成喂狗操作,计数器清零 */
  74. for(i = 0; i < CyclesPerUs * 300 / 4; i++) __NOP();
  75. WDT_Stop(WDTx);
  76. WDT_Init(WDTx, int_period, rst_period);
  77. }
  78. /******************************************************************************************************************************************
  79. * 函数名称: WDT_Start()
  80. * 功能说明: 启动指定WDT,开始倒计时
  81. * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
  82. * 输 出: 无
  83. * 注意事项: 无
  84. ******************************************************************************************************************************************/
  85. void WDT_Start(WDT_TypeDef * WDTx)
  86. {
  87. WDTx->CR |= (1 << WDT_CR_EN_Pos);
  88. }
  89. /******************************************************************************************************************************************
  90. * 函数名称: WDT_Stop()
  91. * 功能说明: 关闭指定WDT,停止倒计时
  92. * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
  93. * 输 出: 无
  94. * 注意事项: 无
  95. ******************************************************************************************************************************************/
  96. void WDT_Stop(WDT_TypeDef * WDTx)
  97. {
  98. WDTx->CR &= ~(1 << WDT_CR_EN_Pos);
  99. }
  100. /******************************************************************************************************************************************
  101. * 函数名称: WDT_Feed()
  102. * 功能说明: 喂狗,重新从装载值开始倒计时
  103. * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
  104. * 输 出: 无
  105. * 注意事项: 无
  106. ******************************************************************************************************************************************/
  107. void WDT_Feed(WDT_TypeDef * WDTx)
  108. {
  109. if(WDTx->CR & WDT_CR_EN_Msk) // WDT 停止状态下,不执行喂狗
  110. WDTx->FEED = 0x55;
  111. }
  112. /******************************************************************************************************************************************
  113. * 函数名称: WDT_INTClr()
  114. * 功能说明: 中断标志清除
  115. * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
  116. * 输 出: 无
  117. * 注意事项: 无
  118. ******************************************************************************************************************************************/
  119. void WDT_INTClr(WDT_TypeDef * WDTx)
  120. {
  121. WDTx->IF = 1;
  122. }
  123. /******************************************************************************************************************************************
  124. * 函数名称: WDT_INTStat()
  125. * 功能说明: 中断状态查询
  126. * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
  127. * 输 出: int32_t 1 发生中断溢出 0 未发生中断溢出
  128. * 注意事项: 无
  129. ******************************************************************************************************************************************/
  130. uint32_t WDT_INTStat(WDT_TypeDef * WDTx)
  131. {
  132. return WDTx->IF;
  133. }