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
25 /******************************************************************************************************************************************
26 * 函数名称: WDT_Init()
27 * 功能说明: WDT看门狗初始化
28 * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
29 * uint32_t int_period 中断周期,取值1--2^16,单位1/1024秒,取值0表示关闭WDT中断功能
30 * uint32_t rst_period 复位周期,取值1--2^16,单位1/1024秒,取值0表示关闭WDT复位功能
31 * 输 出: 无
32 * 注意事项: 此函数只能在芯片上电后调用一次,若需要重新配置 WDT,请调用 WDT_ReInit()
33 ******************************************************************************************************************************************/
WDT_Init(WDT_TypeDef * WDTx,uint32_t int_period,uint32_t rst_period)34 void WDT_Init(WDT_TypeDef * WDTx, uint32_t int_period, uint32_t rst_period)
35 {
36 SYS->CLKEN0 |= (1 << SYS_CLKEN0_WDT_Pos);
37
38 WDTx->CR &= ~WDT_CR_CKDIV_Msk;
39 WDTx->CR |= (4 << WDT_CR_CKDIV_Pos); // 对时钟源 32 分频
40
41 if(int_period == 0)
42 {
43 WDTx->CR &= ~(1 << WDT_CR_INTEN_Pos);
44
45 NVIC_DisableIRQ(WDT_IRQn);
46 }
47 else
48 {
49 WDTx->CR |= (1 << WDT_CR_INTEN_Pos);
50
51 WDTx->INTVAL = int_period;
52
53 WDTx->IF = 1;
54 NVIC_EnableIRQ(WDT_IRQn);
55 }
56
57 if(rst_period == 0)
58 {
59 WDTx->CR &= ~(1 << WDT_CR_RSTEN_Pos);
60
61 WDTx->RSTVAL = int_period;
62 }
63 else
64 {
65 WDTx->CR |= (1 << WDT_CR_RSTEN_Pos);
66
67 WDTx->RSTVAL = rst_period;
68 }
69 }
70
71 /******************************************************************************************************************************************
72 * 函数名称: WDT_ReInit()
73 * 功能说明: WDT看门狗重新初始化
74 * 输 入: 同 WDT_Init()
75 * 输 出: 无
76 * 注意事项: 执行 WDT_ReInit() 前请不要执行 WDT_Stop(),因为 WDT 停止状态下无法清零内部计数器
77 ******************************************************************************************************************************************/
WDT_ReInit(WDT_TypeDef * WDTx,uint32_t int_period,uint32_t rst_period)78 void WDT_ReInit(WDT_TypeDef * WDTx, uint32_t int_period, uint32_t rst_period)
79 {
80 int i;
81
82 /* WDT 已经在运行中,若新设置的 rst_period 比当前计数器值还小,WDT 需要计数到 2^16 溢出返回 0 才能触发中断和复位,
83 这里执行一下喂狗,保证计数器从零重新计数,避免上述问题 */
84 WDT_Feed(WDTx);
85
86 /* 等待 WDT 内部完成喂狗操作,计数器清零 */
87 for(i = 0; i < CyclesPerUs * 300 / 4; i++) __NOP();
88
89 WDT_Stop(WDTx);
90
91 WDT_Init(WDTx, int_period, rst_period);
92 }
93
94 /******************************************************************************************************************************************
95 * 函数名称: WDT_Start()
96 * 功能说明: 启动指定WDT,开始倒计时
97 * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
98 * 输 出: 无
99 * 注意事项: 无
100 ******************************************************************************************************************************************/
WDT_Start(WDT_TypeDef * WDTx)101 void WDT_Start(WDT_TypeDef * WDTx)
102 {
103 WDTx->CR |= (1 << WDT_CR_EN_Pos);
104 }
105
106 /******************************************************************************************************************************************
107 * 函数名称: WDT_Stop()
108 * 功能说明: 关闭指定WDT,停止倒计时
109 * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
110 * 输 出: 无
111 * 注意事项: 无
112 ******************************************************************************************************************************************/
WDT_Stop(WDT_TypeDef * WDTx)113 void WDT_Stop(WDT_TypeDef * WDTx)
114 {
115 WDTx->CR &= ~(1 << WDT_CR_EN_Pos);
116 }
117
118 /******************************************************************************************************************************************
119 * 函数名称: WDT_Feed()
120 * 功能说明: 喂狗,重新从装载值开始倒计时
121 * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
122 * 输 出: 无
123 * 注意事项: 无
124 ******************************************************************************************************************************************/
WDT_Feed(WDT_TypeDef * WDTx)125 void WDT_Feed(WDT_TypeDef * WDTx)
126 {
127 if(WDTx->CR & WDT_CR_EN_Msk) // WDT 停止状态下,不执行喂狗
128 WDTx->FEED = 0x55;
129 }
130
131 /******************************************************************************************************************************************
132 * 函数名称: WDT_INTClr()
133 * 功能说明: 中断标志清除
134 * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
135 * 输 出: 无
136 * 注意事项: 无
137 ******************************************************************************************************************************************/
WDT_INTClr(WDT_TypeDef * WDTx)138 void WDT_INTClr(WDT_TypeDef * WDTx)
139 {
140 WDTx->IF = 1;
141 }
142
143 /******************************************************************************************************************************************
144 * 函数名称: WDT_INTStat()
145 * 功能说明: 中断状态查询
146 * 输 入: WDT_TypeDef * WDTx 指定要被设置的看门狗,有效值包括WDT
147 * 输 出: int32_t 1 发生中断溢出 0 未发生中断溢出
148 * 注意事项: 无
149 ******************************************************************************************************************************************/
WDT_INTStat(WDT_TypeDef * WDTx)150 uint32_t WDT_INTStat(WDT_TypeDef * WDTx)
151 {
152 return WDTx->IF;
153 }
154