[DemoCode下载] 看门狗定时器唤醒掉电模式

[复制链接]
1376|2
 楼主| xinxianshi 发表于 2025-1-25 13:48 | 显示全部楼层 |阅读模式
  1. /**************************************************************************//**
  2. * [url=home.php?mod=space&uid=288409]@file[/url]     main.c
  3. * [url=home.php?mod=space&uid=895143]@version[/url]  V3.00
  4. * $Revision: 4 $
  5. * $Date: 15/09/14 4:05p $
  6. * [url=home.php?mod=space&uid=247401]@brief[/url]    Use WDT time-out interrupt event to wake-up system.
  7. * @note
  8. * Copyright (C) 2013 Nuvoton Technology Corp. All rights reserved.
  9. ******************************************************************************/
  10. #include <stdio.h>
  11. #include "M058S.h"

  12. #define PLL_CLOCK           50000000


  13. /*---------------------------------------------------------------------------------------------------------*/
  14. /* Global Interface Variables Declarations                                                                 */
  15. /*---------------------------------------------------------------------------------------------------------*/
  16. volatile uint8_t g_u8IsWDTWakeupINT = 0;


  17. /*---------------------------------------------------------------------------------------------------------*/
  18. /*  Function for System Entry to Power-down Mode                                                           */
  19. /*---------------------------------------------------------------------------------------------------------*/
  20. void PowerDownFunction(void)
  21. {
  22.     printf("System enter to power-down mode.\n\n");

  23.     /* To check if all the debug messages are finished */
  24.     UART_WAIT_TX_EMPTY(UART0);

  25.     SCB->SCR = 4;

  26.     /* To program PWRCON register, it needs to disable register protection first. */
  27.     CLK->PWRCON = (CLK->PWRCON & ~(CLK_PWRCON_PWR_DOWN_EN_Msk | CLK_PWRCON_PD_WAIT_CPU_Msk)) |
  28.                   CLK_PWRCON_PD_WAIT_CPU_Msk | CLK_PWRCON_PD_WU_INT_EN_Msk;
  29.     CLK->PWRCON |= CLK_PWRCON_PWR_DOWN_EN_Msk;

  30.     __WFI();
  31. }

  32. /**
  33. * @brief       IRQ Handler for WDT and WWDT Interrupt
  34. *
  35. * @param       None
  36. *
  37. * [url=home.php?mod=space&uid=266161]@return[/url]      None
  38. *
  39. * [url=home.php?mod=space&uid=1543424]@Details[/url]     The WDT_IRQHandler is default IRQ of WDT and WWDT, declared in startup_M058S.s.
  40. */
  41. void WDT_IRQHandler(void)
  42. {
  43.     if((WDT_GET_TIMEOUT_INT_FLAG() == 1) && (WDT_GET_TIMEOUT_WAKEUP_FLAG() == 1))
  44.     {
  45.         /* Clear WDT time-out interrupt and wake-up flag */
  46.         WDT_CLEAR_TIMEOUT_INT_FLAG();
  47.         WDT_CLEAR_TIMEOUT_WAKEUP_FLAG();

  48.         g_u8IsWDTWakeupINT = 1;

  49.         printf("WDT time-out wake-up interrupt occurred.\n");
  50.     }
  51. }

  52. void SYS_Init(void)
  53. {
  54.     /*---------------------------------------------------------------------------------------------------------*/
  55.     /* Init System Clock                                                                                       */
  56.     /*---------------------------------------------------------------------------------------------------------*/
  57.     /* Enable HIRC 22.1184MHz clock */
  58.     CLK_EnableXtalRC(CLK_PWRCON_OSC22M_EN_Msk);

  59.     /* Waiting for HIRC clock ready */
  60.     CLK_WaitClockReady(CLK_CLKSTATUS_OSC22M_STB_Msk);

  61.     /* Switch HCLK clock source to HIRC and HCLK source divide 1 */
  62.     CLK_SetHCLK(CLK_CLKSEL0_HCLK_S_HIRC, CLK_CLKDIV_HCLK(1));

  63.     /* Enable external XTAL 12MHz and LIRC 10KHz clock */
  64.     CLK_EnableXtalRC(CLK_PWRCON_XTL12M_EN_Msk | CLK_PWRCON_OSC10K_EN_Msk);

  65.     /* Waiting for external XTAL and LIRC clock ready */
  66.     CLK_WaitClockReady(CLK_CLKSTATUS_XTL12M_STB_Msk | CLK_CLKSTATUS_OSC10K_STB_Msk);

  67.     /* Set core clock as PLL_CLOCK from PLL */
  68.     CLK_SetCoreClock(PLL_CLOCK);

  69.     /* Enable peripheral clock */
  70.     CLK_EnableModuleClock(UART0_MODULE);
  71.     CLK_EnableModuleClock(WDT_MODULE);

  72.     /* Peripheral clock source */
  73.     CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UART_S_PLL, CLK_CLKDIV_UART(1));
  74.     CLK_SetModuleClock(WDT_MODULE, CLK_CLKSEL1_WDT_S_LIRC, 0);

  75.     /*---------------------------------------------------------------------------------------------------------*/
  76.     /* Init I/O Multi-function                                                                                 */
  77.     /*---------------------------------------------------------------------------------------------------------*/
  78.     /* Set P3 multi-function pins for UART0 RXD, TXD */
  79.     SYS->P3_MFP &= ~(SYS_MFP_P30_Msk | SYS_MFP_P31_Msk);
  80.     SYS->P3_MFP |= (SYS_MFP_P30_RXD | SYS_MFP_P31_TXD);
  81. }

  82. void UART0_Init(void)
  83. {
  84.     /*---------------------------------------------------------------------------------------------------------*/
  85.     /* Init UART                                                                                               */
  86.     /*---------------------------------------------------------------------------------------------------------*/
  87.     /* Reset IP */
  88.     SYS_ResetModule(UART0_RST);

  89.     /* Configure UART0 and set UART0 Baudrate */
  90.     UART_Open(UART0, 115200);
  91. }

  92. /*---------------------------------------------------------------------------------------------------------*/
  93. /*  MAIN function                                                                                          */
  94. /*---------------------------------------------------------------------------------------------------------*/
  95. int main(void)
  96. {
  97.     /* Unlock protected registers */
  98.     SYS_UnlockReg();

  99.     /* Init System, peripheral clock and multi-function I/O */
  100.     SYS_Init();

  101.     /* Init UART0 for printf */
  102.     UART0_Init();

  103.     printf("\n\nCPU [url=home.php?mod=space&uid=72445]@[/url] %d Hz\n", SystemCoreClock);
  104.     printf("+----------------------------------------------+\n");
  105.     printf("|    WDT Power-down and Wake-up Sample Code    |\n");
  106.     printf("+----------------------------------------------+\n\n");

  107.     printf("# WDT Settings:\n");
  108.     printf("  Clock source is 10 kHz; Enable interrupt; Enable Wake-up; Time-out interval is 2^16 * WDT clock.\n");
  109.     printf("# When WDT statr counting, system will generate a WDT time-out interrupt after 6.5536 ~ 6.656 s.\n");
  110.     printf("  Measure P0.0 low period to check time-out interval and system can be waken-up by WDT time-out event.\n\n");

  111.     /* Use P0.0 to check time-out period time */
  112.     GPIO_SetMode(P0, BIT0, GPIO_PMD_OUTPUT);
  113.     P00 = 1;
  114.     P00 = 0;

  115.     /* Because of all bits can be written in WDT Control Register are write-protected;
  116.        To program it needs to disable register protection first. */
  117.     SYS_UnlockReg();

  118.     /* Enable WDT wake-up function and select time-out interval to 2^16 * WDT clock then start WDT counting */
  119.     g_u8IsWDTWakeupINT = 0;
  120.     WDT_Open(WDT_TIMEOUT_2POW16, 0, FALSE, TRUE);

  121.     /* Enable WDT interrupt function */
  122.     WDT_EnableInt();

  123.     /* Enable WDT NVIC */
  124.     NVIC_EnableIRQ(WDT_IRQn);

  125.     /* System entry into Power-down Mode */
  126.     PowerDownFunction();

  127.     /* Check if WDT time-out interrupt and wake-up interrupt flag occurred */
  128.     while(1)
  129.     {
  130.         if(((CLK->PWRCON & CLK_PWRCON_PD_WU_STS_Msk) == CLK_PWRCON_PD_WU_STS_Msk) && (g_u8IsWDTWakeupINT == 1))
  131.             break;
  132.     }

  133.     P00 = 1;

  134.     /* Clear Power-down wake-up interrupt flag */
  135.     CLK->PWRCON |= CLK_PWRCON_PD_WU_STS_Msk;

  136.     /* Disable WDT counting */
  137.     WDT_Close();

  138.     while(1);
  139. }

  140. /*** (C) COPYRIGHT 2013 Nuvoton Technology Corp. ***/


 楼主| xinxianshi 发表于 2025-1-25 13:49 | 显示全部楼层
设计看门狗定时器的目的是,当系统运行到一个未知状态时,通过它来使系统复位。这种做法可以预防系统进入到无限期的死循环。此外,该看门狗定时器支持系统从Idle/Power-down模式中唤醒功能。
 楼主| xinxianshi 发表于 2025-1-25 13:50 | 显示全部楼层
特性
 18位的自由向上计数器,可满足各种看门狗定时器的超时间隔要求
 超时间隔有(24 ~ 218)个WDT_CLK时钟周期可选,如果WDT_CLK = 10 kHz,那么超时间隔
是104 ms ~ 26.3168 s
 系统复位保持时间为(1 / WDT_CLK) * 63
 支持看门狗定时器复位延时周期
 可选的复位延时周期包括(1026、130、18 或 3) * WDT_CLK个复位延时周期
 当CWDTEN (CONFIG[31] 看门狗使能)位被置为0,支持芯片上电或芯片复位后看门狗强制打
开.
 支持看门狗定时器超时唤醒功能,此时时钟源必须选择内部低速10k时钟源

5093167947b9258b86.png

您需要登录后才可以回帖 登录 | 注册

本版积分规则

102

主题

1019

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部