3

首先澄清一下,我是嵌入式技术的新手。我正在使用 NXP 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;
}
4

1 回答 1

2

一般来说,人们不会使用看门狗作为唤醒机制。相反,您希望为此专用一个通用计时器(例如,您引用的规范的第 21 章)。数据表甚至提到了它们包含“无复位模式”的原因:

看门狗中断的目的是在看门狗溢出时允许调试看门狗活动而无需重置设备。

因此,一旦您从中醒来,唯一的选择就是禁用中断,此时您将永远无法再次使用这种机制唤醒。

但是,您的 ISR 代码是有缺陷的,因为您永远不会进入您的第一个条件。您应该将其更改为:

void WDT_IRQHandler(void)
{
    NVIC_DisableIRQ(WDT_IRQn);
}

从这个中断返回后,CPU 应该是清醒的,并且应该执行它之后的下一条指令__WFI;,使其进入睡眠状态。

于 2013-05-06T20:57:08.417 回答