歡迎您光臨本站 登入註冊首頁

概述

  MC68HC08系列有一個複位狀態寄存器,負責記錄6種複位標誌位:上電複位、引腳複位、看門狗複位、非法指令複位、非法地址複位和欠壓複位。SPMC65系列有一個系統控制寄存器,負責記錄5種複位標誌位……


  MC68HC08系列有一個複位狀態寄存器,負責記錄6種複位標誌位:上電複位、引腳複位、看門狗複位、非法指令複位、非法地址複位和欠壓複位。SPMC65系列有一個系統控制寄存器,負責記錄5種複位標誌位:上電複位、外部複位、看門狗複位、非法地址複位和欠壓複位。51兼容的P89LPC900系列有一個複位源寄存器,負責記錄6種複位標誌位:欠壓複位、上電複位、外部複位、看門狗複位、軟體複位和UART收到間隔字元複位(主要作為進入ISP監控程序的途徑之一)。就連初學者很常用的 AT89S51/52和P89C52X2,也在其電源控制寄存器PCON中增設了一個上電標誌位POF。
1 複位標誌位的設置方法
  傳統的80C51單片機沒有設計複位標誌位的記錄功能,這應該說是一種遺憾,那麼能否通過一定的技術手段來彌補這個缺憾呢?這裡給廣大80C51單片機用戶提供一種啟示和引導。
  實現複位標誌位的記錄肯定需要一定的硬體電路支持,而這種電路的設計不存在固定模式。筆者利用一片MAX813L設計了一種支撐電路,如圖1所示,僅供讀者參考。

圖1 80C51設置複位標誌的支撐電路
  在圖1中,應用了一個4輸入端「與非」門G1和一個按鈕開關SW1,還佔用了80C51的5條I/O引腳P1.0~P1.4以及一個外部中斷源 INT0,並且預先通過初始化軟體設置INT0為唯一的高級中斷源,下降沿觸發方式有效,開放總中斷使能位EA。平時G1因各輸入端都維持在高電平上,因而其輸出端也保持高電平。電路中利用了一個海量電容器C1作為儲存能量的器件,扮演著備用電池的角色。由於二極體D1的存在,在主電源斷電期間,C1僅為單片機供電,應該讓這時的80C51進入耗能最低的停機狀態(PD模式)。
  在圖1電路的基礎上配合必要的用戶軟體,就可以在7種不同複位源引起複位之後保存6個標誌位來記錄7種複位標誌,以下分別進行講解。可以事先在RAM的位定址區間分配一個位元組,例如20H單元,用於記錄6個複位標誌位,如表1所列。
表1 用戶定義的系統複位標誌寄存器(SRFR)

  假設該寄存器定名為SRFR(System Reset Flag Register),位元組地址為20H,8位當中僅利用了6位,bit5~bit0分別記錄人工複位、欠壓複位、看門狗複位、非法地址複位、軟硬體複位和軟體複位。
  ① MRST:人工複位。當複位按鈕SW1被按下時引發INT0中斷;在中斷服務程序中檢測輸入引腳P1.4的狀態。如果P1.4=0,則置位MRST,記錄下曾經發生了一次人工複位操作。然後進行一次主動的複位操作,方法是從輸出腳P1.0輸出一個低電平給MAX813L的輸入引腳MR,經 MAX813L延時后從輸出端RESET送出高電平複位信號給80C51,令其進行一次硬體複位操作。
  ② LVR:欠壓複位。當上游電源電壓開始跌麻哀且下降到MAX813L的PFI檢測門限以下,輸出端PFO送出低電平,引發INT0中斷;在中斷服務程序中檢測輸入引腳P1.3的狀態。如果P1.3=0,則置位LVR,記錄下曾經發生了一次欠壓複位操作;然後進行一次主動的複位操作(方法同上),或者令單片機進入停機狀態,以便節省能耗和保持數據,以及等待主電源的恢復。
  ③ WDR:看門狗複位。當發生看門狗溢出時,MAX813L的輸出端WDO送出低電平,引發INT0中斷;在中斷服務程序中檢測輸入引腳P1.2的狀態。如果 P1.2=0,則置位WDR,記錄下曾經發生了一次看門狗複位操作;然後進行一次主動的複位操作(方法同上)。喂狗操作利用了一個I/O引腳P1.1。
  ④ IAR:非法地址複位。當發生非法地址時,80C51的輸出端PSEN送出低電平瞬時脈衝,也會引發一次INT0中斷;在中斷服務程序中檢測輸入引腳 P1.4~P1.2的狀態。如果P1.4~P1.2=111,則置位IAR,表示發生了一次非法地址複位操作;然後進行一次主動的複位操作(方法同上)。
  ⑤ SHR: 軟硬體複位。當發生了軟體陷阱的捕捉事件,或者軟體看門狗的溢出事件時,可以直接置位SHR,代表發生了一次軟硬體複位操作;然後進行一次主動的複位操作(方法同上)。如果利用T0作軟體WDT,則應該同時設置INT0和T0中斷源為高級中斷。
  ⑥ SWR: 軟體複位。當發生了軟體陷阱的捕捉事件,或者軟體看門狗的溢出事件時,也可以直接置位SWR,代表發生了一次軟體複位操作;然後調用軟體複位程序SWRST即可。軟體複位程序的編寫方法如下:
SWRST:;定義軟體複位程序的實際入口地址
  CLREA;首先關閉中斷源總使能位
  SETBF0;設置一個軟體複位標誌位
  MOVP0,#0FFH;設定通用埠P0為高阻輸入狀態
  MOVP1,#0FFH;設定通用埠P1為高阻輸入狀態
  MOVP2,#0FFH;設定通用埠P2為高阻輸入狀態
  MOVP3,#0FFH;設定通用埠P3為高阻輸入狀態
  MOVPSW,#00H;設定程序狀態字寄存器為原始值
  ;(根據需要還可初始化其他SFR)
  MOVDPTR,#SWR0;為RETI準備彈出地址,而又不改變
  ;執行順序
  PUSHDPL;壓棧低位元組,在先
  PUSHDPH;壓棧高位元組,在後
  RETI;中斷返回指令,清除高級中斷激活觸
  ;發器
SWR0:
  CLRA;準備複位地址
  PUSHACC;壓棧低位元組00H
  PUSHACC;壓棧高位元組00H
  RETI;清除低級中斷激活觸發器,並跳到
  ;0000H
  ⑦ POR:電源上電複位。雖然在用戶定義的系統複位標誌寄存器(SRFR)中,沒有直接設置一個POR標誌位,但是如果檢測以上6個標誌位同時為0,則表明此前進行的是一次上電複位。理由是,經過實驗驗證(實驗所用的單片機型號為SST89C58),在每次初次加電時,包含RAM的20H單元在內的80C51內部 RAM區間(00H~7FH),其內容全部自動清零;在每次RST引腳複位(或者軟體複位)時,其內容維持不變。而各個SFR無論是上電複位還是RST引腳複位時,均被還原為原始值(又稱複位值),如表2所列。

[admin via 研發互助社區 ] 80C51複位標誌位的設置與應用研究已經有2977次圍觀

http://cocdig.com/docs/show-post-374.html