首先澄清我是嵌入式技术的新手。我正在使用恩智浦LPC1769主板。有些日子我一直在寻找一个关于如何使用看门狗从深度睡眠模式唤醒但我找不到它的例子。
我从UM10360中读到了关于看门狗定时器的第21.1章以及关于功率控制的4.8。
对于看门狗我尝试写这个:
void WatchDog_Init(uint32_t TimeOut)
{
// Set the watchdog timer constant reload value
LPC_WDT->WDTC =TimeOut * 256 * 4; // timeout value
// Setup the Watchdog time operating mode in WDMOD register
LPC_WDT->WDMOD = 0x5; // Watch dog enabled, reset disable , watchdog cleared by software.
// Enable watchdow by writting 0xAA followed by 0x55 to WDFEED register
// Reload the watchdog timer with the WDTC value.
LPC_WDT->WDFEED = 0xAA;
LPC_WDT->WDFEED = 0x55;
if ( ! LPC_WDT->WDCLKSEL | ( 1 << 31) )
{
// Select internal IRC oscillator to be able to wake up from deep-sleep mode
LPC_WDT->WDCLKSEL &= ~(0x11);
}
NVIC_EnableIRQ(WDT_IRQn);
}
void WDT_IRQHandler(void)
{
// //LPC_WDT->WDMOD &= ~WDTOF; /* clear the time-out interrupt flag */
// LPC_WDT->WDMOD |= ( 0 << 2); /* clear the time-out interrupt flag */
if ( LPC_WDT->WDMOD & 1 << 2 )
{
m_count++;
// TODO: Wake up CPU!
// Disable WatchDog Interrupt
// or the watchdog interrupt request will be generated indefinitely...
// NOT WORKING :S
LPC_WDT->WDMOD &= ~(0x4);
NVIC_DisableIRQ(WDT_IRQn);
}
}
虽然我在无限循环中停止WDT_IRQn
板条目。
要将电路板设置为深度睡眠模式,我尝试:
// Set device in deep sleep mode....
LPC_SC->PCONP |= 11; // Enable PM1 and PM0
if ( LPC_SC->PCONP & 0x3 == 0x3)
{
PRINT_DEBUG("Well!");
}
if ( (LPC_SC->PCONP & ( 1 << ENTER_SLEEP_MODE_CHECK ))>>ENTER_SLEEP_MODE_CHECK)
{
// Successfully entering to deep-sleep mode
__WFI;
}
答案 0 :(得分:2)
通常不会使用看门狗作为唤醒机制。相反,您需要专门用于通用计时器(例如,您引用的规范的第21章)。数据表甚至提到他们包含“无重置模式”的原因:
看门狗中断的目的是允许调试看门狗活动,而不会在看门狗溢出时重置设备。
所以,一旦你从中醒来,唯一的选择就是禁用中断,此时你再也无法用这种机制唤醒了。
但是,你的ISR代码是有缺陷的,因为你永远不会进入你的第一个条件。你应该把它改成:
void WDT_IRQHandler(void)
{
NVIC_DisableIRQ(WDT_IRQn);
}
从此中断返回后,CPU应该处于唤醒状态,并且应该在使其进入休眠状态的__WFI;
之后执行下一条指令。