當(dāng)受到故障,如噪聲或系統(tǒng)錯(cuò)誤的干擾時(shí),s3c44b0x看門狗定時(shí)器能夠產(chǎn)生復(fù)位信號(hào),使CPU復(fù)位,它也可以用作一個(gè)普通的16位定時(shí)器使用,計(jì)算完產(chǎn)生中斷信號(hào)。如果用作復(fù)位信號(hào),可以產(chǎn)生一個(gè)長達(dá)128MCLK時(shí)鐘周期的復(fù)位信號(hào)。
S3C44B0X 內(nèi)部的watchdog結(jié)構(gòu)如下圖所示:
500)this.width=500;" border=0>
在S3C44B0X內(nèi)部由3個(gè)16位的特殊功能寄存器控制看門狗定時(shí)器:
WTCON Reg: 功能控制器
WTDATA Reg:數(shù)據(jù)存儲(chǔ)器
WTCNT Reg: 計(jì)數(shù)存儲(chǔ)器
16位的WTCON寄存器在S3C44B0X復(fù)位時(shí)的地址為:0x01D3_0000,可讀/寫,初始值為0x8021,各位的功能如下:【15~8】設(shè)置預(yù)分頻器值,初始值0x80 本文引用地址:http://m.butianyuan.cn/article/201611/318971.htm【7~6】保留位,但是在正常模式下必須設(shè)置為00,初始值00 【5】 0=關(guān)閉看門狗,1=打開看門狗,初始值1 【4~3】 設(shè)置除法因子,00=1/16, 01=1/32, 10=1/64, 11=1/128,初始值00 【2】中斷使能位,0=打開中斷,1=關(guān)閉中斷,初始值0,用于定時(shí)器功能,初始值0 【1】保留位,但是在正常模式下必須設(shè)置位0,初始值0 【0】復(fù)位使能位,0=關(guān)閉復(fù)位功能,1=打開復(fù)位功能,用于復(fù)位功能,初始值1 |
16位的WTDATA寄存器復(fù)位地址為:0x01D3_0004,可讀/寫,初始值為0x8000
16位的WTCNT寄存器復(fù)位地址為:0x01D3_0008,可讀/寫,初始值為0x8000
在打開看門狗后,WTDATA數(shù)據(jù)不能自動(dòng)裝入WTCNT,因此在打開前需要手段裝入。
定時(shí)器的頻率(產(chǎn)生中斷或者復(fù)位信號(hào)的周期)計(jì)算公式如下:
f=MCLK/(Prescaler +1 )/除法因子
時(shí)鐘周期為:t=1/f,即t(ns)計(jì)數(shù)一次
在Bootloader階段禁用看門狗,程序如下:
WTCON EQU 0x01d30000
...
ldr r0, =WTCON
ldr r0, =0
str r0, [r0]
...
評論