mini 2440 test 的Delay函數(shù)分析
void Delay(int time)
{
}
1)
預(yù)分頻值和分割值分別由TCFG0,TCFG1來確定。
rTCFG0 &= ~(0xff<<8);
rTCFG0 |= 3<<8;
rTCFG1 &= ~(0xf<<12);
rTCFG1 |= 0<<12;
預(yù)分頻為3,分割值為2,又已知PCLK=50Mhz
因此可以計算出計數(shù)器輸入時鐘頻率6.25Mhz。
2)初始值的設(shè)定了是由TCMPB3和TCNTB3來完成了
TCMPB3一定要小于TCNTB3。
TCMPB3在定時的過程中不變,然后TCNTB3開始減計數(shù),直到與TCMPB3相等時觸發(fā)中斷,通過設(shè)定就可以重新轉(zhuǎn)載TCNTB3。
我們可以比較一下rTCNTB3與計數(shù)器的輸入時鐘,可以發(fā)現(xiàn)rTCNTB3的頻率是輸入時鐘的1000分之一,(因為包括0)。因此我們可以這樣等價的認(rèn)為rTCNTB3 = 1000CCLK,
然后我們看上面的定時的時序,rTCNTB3開始減計數(shù),直到減到500與rTCMPB3相等,觸發(fā)中斷,然后rTCNTB3再減一以后繼續(xù)裝載。
2)
rTCON[16,17,18,19]控制Timer3
rTCON &= ~(0xf<<16);
3)
由于Delay程序只是軟件定時,因此設(shè)計了一個while循環(huán)來完成定時的功能。具體實現(xiàn)如下:
while(time--) {
while(rTCNTO3>=val>>1);
while(rTCNTO3
};
最外層的WHILE只是DELAY的次數(shù),然后看里面的兩個WHILE,TCNTO3是個BUFFER,用來讀TCNTB3,其實也就等同于 TCNTB3,while(rTCNTO3>=val>>1);就是等到rTCNTO3
并且rTCMPB3 = val>>1;
while(rTCNTO3>=val>>1)也就等同于
while(rTCNTO3>=rTCMPB3 );
所以,rTCNTB3開始減計數(shù),當(dāng)?shù)扔谝院?,再減1則進(jìn)入下一個語句的while(rTCNTO3
然后開始下一個time--
4)實現(xiàn)的延遲時間的計算
通過以上的分析,可以得到延遲時間的頻率:CCLK/2
時間是0.32ms
該文讓我多少能夠理解val = (PCLK>>3)/1000-1;一句中減1的理由,也許是
計數(shù)的時候要計上0,至于是否如此,未曾驗證。
本文引用地址:http://cafeforensic.com/article/201611/318986.htm認(rèn)為時鐘頻率為50M/3+1/2=6.25M沒錯,但是計數(shù)50M/8000次,那么計數(shù)周期應(yīng)
該是1/6.25*50/8000=1ms才對。
評論