謝琪林 攀枝花學(xué)院
在MCS 51 單片機(jī)的控制系統(tǒng)中, 常常要求有些定時(shí)或者延時(shí)控制。定時(shí)或者延時(shí)控制一般有如下2 種方法: 軟件延時(shí),即讓CPU 循環(huán)執(zhí)行一段時(shí)間, 以實(shí)現(xiàn)延時(shí)和硬件定時(shí), 即利用MCS 51 系列單片機(jī)硬件集成的2 個(gè)16 位可編程定時(shí)/計(jì)數(shù)器。但采用上述這兩種方法來(lái)實(shí)現(xiàn)時(shí)間控制時(shí)卻容易產(chǎn)生誤差, 對(duì)于一般低頻率的應(yīng)用中對(duì)時(shí)間控制精度要求低的場(chǎng)合來(lái)說(shuō)沒(méi)有太大的問(wèn)題, 而在高頻實(shí)時(shí)控制應(yīng)用中對(duì)時(shí)間控制精度要求高的場(chǎng)合來(lái)講問(wèn)題就凸現(xiàn)出來(lái), 必須加以糾正和補(bǔ)償。
軟件延時(shí)原理: 利用CPU 內(nèi)部定時(shí)機(jī)構(gòu), 使每執(zhí)行一條指令需要若干個(gè)指令周期的原理, 運(yùn)用軟件編程, 讓機(jī)器循環(huán)執(zhí)行一段程序, 而得到一個(gè)固定的時(shí)間段, 就將這段時(shí)間作為定時(shí)時(shí)間。軟件定時(shí)的時(shí)間長(zhǎng)短完全取決于指令的執(zhí)行時(shí)間, 此方法主要用于短時(shí)間定時(shí)。例, 采用軟件方法設(shè)置一個(gè)502μs 的定時(shí)時(shí)間, 設(shè)晶體振蕩頻率為12MHz??删幹迫缦碌淖映绦蚨斡糜谲浖〞r(shí)。
DELAY: MOV R2, #64H ; 1 個(gè)時(shí)鐘周期
DL1: NOP ; 1 個(gè)時(shí)鐘周期
NOP ;
DJNZ R2, DL1 ; 2 個(gè)時(shí)鐘周期
RET ; 1 個(gè)時(shí)鐘周期
在該程序段中, 采用減1 指令計(jì)數(shù), 計(jì)數(shù)初值100( 64H) 預(yù)先設(shè)置在寄存器R2 中, 各指令的執(zhí)行時(shí)間如程序段中的注釋所示。軟件定時(shí)的時(shí)間可由各指令的執(zhí)行時(shí)間以及循環(huán)次數(shù)100( 64H) 所確定, 計(jì)算如下:
但在很多情況下, 只考慮了循環(huán)體的執(zhí)行時(shí)間, 沒(méi)有考慮本例中的MOV、RET 指令, 即在設(shè)計(jì)延時(shí)500μs 時(shí)也采用了本程序, 這樣就有一個(gè)誤差, 誤差率是0.4%, 這個(gè)誤差非常大。另外在使用軟件定時(shí)過(guò)程中, 程序也容易被其他程序或事件打斷( 如中斷服務(wù)程序) , 這樣也會(huì)引起來(lái)較大的定時(shí)誤差, 因此必須防止程序被其他程序或事件打斷。同時(shí), 這種以犧牲CPU 的時(shí)間獲取延時(shí)的方法隨CPU 工作頻率不同而發(fā)生變化, 即定時(shí)程序的通用性差。
硬件定時(shí)原理就是利用51 單片機(jī)片內(nèi)二個(gè)16 位定時(shí)器/計(jì)數(shù)器,即定時(shí)器T0 和定時(shí)器T1, 設(shè)置為定時(shí)工作方式,定時(shí)器計(jì)數(shù)8051 片內(nèi)振蕩器輸出經(jīng)12 分頻后的脈沖, 即每個(gè)機(jī)器周期使定時(shí)器的數(shù)值加1 直至計(jì)滿(mǎn)溢出, 然后中斷CPU 的當(dāng)前操作, 執(zhí)行相應(yīng)的中斷服務(wù)程序。但在這個(gè)過(guò)程中很容易產(chǎn)生單片機(jī)定時(shí)器溢出中斷的時(shí)間誤差, 產(chǎn)生時(shí)間誤差有三個(gè)原因: 一是中斷響應(yīng)時(shí)間; 二是定時(shí)器溢出中斷信號(hào)時(shí), CPU 正在執(zhí)行某指令;三是定時(shí)器溢出中斷信號(hào)時(shí), CPU 正在執(zhí)行某中斷服務(wù)程序。
MCS 51 單片機(jī)的最短中斷響應(yīng)時(shí)間為3 個(gè)機(jī)器周期, 其中中斷請(qǐng)求標(biāo)志位查詢(xún)占1 個(gè)機(jī)器周期, 而這個(gè)機(jī)器周期又恰好是執(zhí)行指令的最后一個(gè)機(jī)器周期,在這個(gè)機(jī)器周期結(jié)束后,中斷即被響應(yīng),產(chǎn)生LCALL 指令,而執(zhí)行這條長(zhǎng)調(diào)指令需要2 個(gè)機(jī)器周期, 這樣中斷響應(yīng)共經(jīng)歷了3 個(gè)機(jī)器周期。而在這些時(shí)間中定時(shí)器繼續(xù)從0 開(kāi)始計(jì)數(shù),因此產(chǎn)生了3 個(gè)機(jī)器周期的誤差。
中斷響應(yīng)的一個(gè)前提是當(dāng)前指令執(zhí)行完畢, 若定時(shí)器的溢出中斷時(shí), CPU 正在執(zhí)行某指令,因此它不能及時(shí)響應(yīng)。當(dāng)CPU 執(zhí)行此指令后再響應(yīng)中斷所延遲的最長(zhǎng)時(shí)間為該指令的指令周期,即誤差的最大值為執(zhí)行該指令所需的時(shí)間。由于各指令都有對(duì)應(yīng)的指令周期, 因此這種誤差將因CPU 正在執(zhí)行指令的不同而不同。在8051 單片機(jī)指令系統(tǒng)中,多數(shù)指令的指令周期為1~2 個(gè)機(jī)器周期,因此最大時(shí)間誤差一般為1~2 個(gè)機(jī)器周期。若振蕩器振蕩頻率為FOSC , CPU 正在執(zhí)行指令的機(jī)器周期數(shù)為CI ,則最大時(shí)間誤差為ΔTMAX1=12/FOSC×CI (us)。例如FOSC =12MHZ , CPU 正在執(zhí)行乘法指令(CI=4) , 此時(shí)的最大時(shí)間誤差為:
定時(shí)器溢出中斷信號(hào)時(shí), 若CPU 正在執(zhí)行同級(jí)或高優(yōu)先級(jí)中斷服務(wù)程序,則它仍需繼續(xù)執(zhí)行這些程序,不能及時(shí)響應(yīng)定時(shí)器的溢出中斷請(qǐng)求,其延遲時(shí)間由中斷轉(zhuǎn)移指令周期T1、 中斷服務(wù)程序執(zhí)行時(shí)間T2、 中斷返回指令的指令周期T3 及中斷返回原斷點(diǎn)后執(zhí)行下一條指令周期T4 (如乘法指令)組成。中斷轉(zhuǎn)移指令和中斷返回指令的指令周期都分別為2 個(gè)機(jī)器周期。中斷服務(wù)程序的執(zhí)行時(shí)間為該程序所含指令的指令周期的總和。因此,最大時(shí)間誤差ΔTMAX2 為:ΔTMAX2 =(T1+ T2+T3+T4)12/FOSC=(2+T2+2+4)12/FOSC=12(T2+8)/ FOSC若設(shè)FOSC=12MHZ ,則最大時(shí)間誤差為:
ΔTMAX2=12(T2+8)/FOSC=12(T2+8)/12×106=(T2+8)×10 6(s)=T2+8(μs)由于上式中T2 一般大于8,因此,這種時(shí)間誤差一般取決于正在執(zhí)行的中斷服務(wù)程序。當(dāng)CPU 正在執(zhí)行中斷返回指令RETI、或正在讀寫(xiě)IE 或IP 指令時(shí), 這種誤差在5 個(gè)機(jī)器周期內(nèi)。
使用上述的各種修正方法后基本能得到一個(gè)比較精確額定時(shí), 針對(duì)不同情況應(yīng)采用靈活的修正方法同時(shí)也應(yīng)注意一些事項(xiàng), 例如不能采用定時(shí)器工作模式2 自動(dòng)重裝初值的方式,否則誤差會(huì)更大,并且得不到控制。另外硬件方面的因素也應(yīng)值得注意,比如應(yīng)考慮晶體自身的精度、晶體的頻率漂移誤差, 盡量選用振蕩頻率高的時(shí)鐘以減少誤差。