2014-08-30 00:19:16 +08:00
|
|
|
/**
|
|
|
|
*****************************************************************************
|
|
|
|
* @file cmem7_wdg.c
|
|
|
|
*
|
|
|
|
* @brief CMEM7 watchdog source file
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @version V1.0
|
|
|
|
* @date 3. September 2013
|
|
|
|
*
|
|
|
|
* @note
|
|
|
|
*
|
|
|
|
*****************************************************************************
|
|
|
|
* @attention
|
|
|
|
*
|
|
|
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
|
|
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
|
|
|
* TIME. AS A RESULT, CAPITAL-MICRO SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
|
|
|
|
* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
|
|
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
|
|
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
|
|
|
*
|
|
|
|
* <h2><center>© COPYRIGHT 2013 Capital-micro </center></h2>
|
|
|
|
*****************************************************************************
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "cmem7_wdg.h"
|
|
|
|
|
|
|
|
static uint32_t wdg_GetClock() {
|
|
|
|
return SYSTEM_CLOCK_FREQ / (1 << (GLOBAL_CTRL->CLK_SEL_0_b.WDG_CLK + 1));
|
|
|
|
}
|
|
|
|
|
2015-05-13 08:50:14 +08:00
|
|
|
void WDG_DeInit(void){
|
|
|
|
SOFT_RESET->SOFTRST_b.WDT_n = 0;
|
|
|
|
SOFT_RESET->SOFTRST_b.WDT_n = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void WDG_Init(uint8_t trigger, uint16_t ResetMillSecond) {
|
2014-08-30 00:19:16 +08:00
|
|
|
assert_param(IS_WDG_TRIGGER_MODE(trigger));
|
|
|
|
|
|
|
|
WDG->INT_CTRL_b.TRIGGER_MODE = trigger;
|
2015-05-13 08:50:14 +08:00
|
|
|
WDG->LEN = ((uint64_t)wdg_GetClock()) * ResetMillSecond / 1000;
|
2014-08-30 00:19:16 +08:00
|
|
|
}
|
|
|
|
|
2015-05-13 08:50:14 +08:00
|
|
|
void WDG_ITConfig(uint8_t Int, BOOL Enable) {
|
2014-08-30 00:19:16 +08:00
|
|
|
assert_param(IS_WDG_INT(Int));
|
|
|
|
|
|
|
|
WDG->CTRL_b.INT_LEN = Int;
|
|
|
|
WDG->INT_CTRL_b.MASK = !Enable;
|
|
|
|
}
|
|
|
|
|
2015-05-13 08:50:14 +08:00
|
|
|
BOOL WDG_GetITStatus() {
|
2014-08-30 00:19:16 +08:00
|
|
|
return (WDG->INT_STA_b.STA == 1) ? TRUE : FALSE;
|
|
|
|
}
|
|
|
|
|
2015-05-13 08:50:14 +08:00
|
|
|
void WDG_ClearITPendingBit() {
|
2014-08-30 00:19:16 +08:00
|
|
|
WDG->INT_STA_b.STA = 1;
|
|
|
|
}
|
|
|
|
|
2015-05-13 08:50:14 +08:00
|
|
|
void WDG_Cmd(BOOL Enable) {
|
2014-08-30 00:19:16 +08:00
|
|
|
WDG->CTRL_b.EN = Enable;
|
|
|
|
}
|
|
|
|
|