外设系统的内部控制单元WDT

记录三个MCU外设系统的内部控制单元:WDT,Timer和RTC

1 WDT

1.1 定义

  WDT:whatch dog timer。如何证明如果系统正常运作,可以每隔一定的时间执行某一段代码,如果那段代码没有被执行,那么就说明代码或者系统死掉了。可以这么理解,那段要规律执行的代码就是狗,规律的去执行它,就是喂狗的行为,如果一段时间不去喂养,狗就死了,系统也就死了。所以说,WDT是用来监测系统是否正常运转的,如果系统跑飞了,狗死了,WDT就复位一次系统。

图:WATCHDOG在MCU中的位置

从图中可以看出,WDT复位的有:BVICRESETn,CM3Core和System Components(总线互联矩阵和内存保护单元MPU),但是WDT是不会复位系统调试模块的。

1.2 电路设计

  FRC:Free Running Counter,这是一个32位的,自动减一的计数器。

图:Timer的框图结构

图:寄存器参考分布

WDOGLOAD寄存器:存储一个初始值,之后不断减一,最小值是1;

WDOGVALUE寄存器:上报作用,指示当前值;

WDOGCONTROL寄存器:软件通过控制该寄存器,来控制看门狗的一些功能部件

相关的寄存器设置,可以找一个MCU的寄存器手册,手册基本上可以当做SPEC来参考。

2 WDT的跨时钟域的设计难点

//------------------------------------------------------------------------------
// Load enable register
//------------------------------------------------------------------------------
// The load_en pulse needs to be sampled into the WDOGCLK domain even if PCLK
// is subsequently disabled.

  // load_req_tog_p is toggled if a new load request is received and there are no
  //  pending load requests. This prevents multiple toggles before the next
  //  WDOGCLK edge.
  assign load_tog_en = load_en_reg & (~load_req_w); // New load request and none pending

  // load_tog_en high toggles LoadReqTog on next PCLK
  always @ (negedge PRESETn or posedge PCLK)
    begin : p_load_req_tog_p_seq
      if (~PRESETn)
        load_req_tog_p <= 1'b0;
      else
        if (load_tog_en)
          load_req_tog_p <= (~load_req_tog_p);
    end

  // Register LoadReqTog into WDOGCLK domain
  always @(negedge WDOGRESn or posedge WDOGCLK)
  begin : p_load_req_tog_w_seq
    if (~WDOGRESn)
      load_req_tog_w <= 1'b0;
    else
      if (WDOGCLKEN)
        load_req_tog_w <= load_req_tog_p;
  end

  // load_req_w goes high on the PCLK edge after load_tog_en and low on the next
  //  valid WDOGCLK edge
  assign load_req_w = load_req_tog_p ^ load_req_tog_w;

猜你喜欢

转载自www.cnblogs.com/yiwenbo/p/10971986.html
今日推荐