當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀] 8051系列MCU的基本結(jié)構(gòu)包括:32個(gè)I/O口(4組8bit端口);兩個(gè)16位定時(shí)計(jì)數(shù)器;全雙工串行通信;5個(gè)中斷源(2個(gè)外部中斷、2個(gè)定時(shí)/計(jì)數(shù)器中斷、1個(gè)串口輸入/輸出中斷),兩級(jí)中斷優(yōu)先級(jí);128字節(jié)內(nèi)置RAM

8051系列MCU的基本結(jié)構(gòu)包括:32個(gè)I/O口(4組8bit端口);兩個(gè)16位定時(shí)計(jì)數(shù)器;全雙工串行通信;5個(gè)中斷源(2個(gè)外部中斷、2個(gè)定時(shí)/計(jì)數(shù)器中斷、1個(gè)串口輸入/輸出中斷),兩級(jí)中斷優(yōu)先級(jí);128字節(jié)內(nèi)置RAM;獨(dú)立的64K字節(jié)可尋址數(shù)據(jù)和代碼區(qū)。中斷發(fā)生后,MCU轉(zhuǎn)到5個(gè)中斷入口處之一,然后執(zhí)行相應(yīng)的中斷服務(wù)
處理程序。中斷程序的入口地址被編譯器放在中斷向量中,中斷向量位于程序代碼段的最低地址處,注意這里的串口輸入/輸出中斷共用一個(gè)中斷向量。8051的中斷向量表如下:
中斷源中斷向量
---------------------------
上電復(fù)位0000H
外部中斷00003H
定時(shí)器0溢出000BH
外部中斷10013H
定時(shí)器1溢出001BH
串行口中斷0023H
定時(shí)器2溢出002BH

interruptusing都是C51的關(guān)鍵字。C51中斷過程通過使用interrupt關(guān)鍵字和中斷號(hào)(0到31)來實(shí)現(xiàn)。中斷號(hào)指明編譯器中斷程序的入口地址中斷序號(hào)對(duì)應(yīng)著8051中斷使能寄存器IE中的使能位,對(duì)應(yīng)關(guān)系如下:
IE寄存器C51中的8051的
的使能位中斷號(hào)中斷源
--------------------------------
IE.00外部中斷0
IE.11定時(shí)器0溢出
IE.22外部中斷1
IE.33定時(shí)器1溢出
IE.44串口中斷
IE.55定時(shí)器2溢出

有了這一聲明,編譯器不需理會(huì)寄存器組參數(shù)的使用和對(duì)累加器A、狀態(tài)寄存器、寄存器B、數(shù)據(jù)指針和默認(rèn)的寄存器的保護(hù)。只要在中斷程序中用到,編譯器會(huì)把它們壓棧,在中斷程序結(jié)束時(shí)將他們出棧。C51支持所有5個(gè)8051標(biāo)準(zhǔn)中斷從0到4和在8051系列(增強(qiáng)型)中多達(dá)27個(gè)中斷源。
using關(guān)鍵字用來指定中斷服務(wù)程序使用的寄存器組。用法是:using后跟一個(gè)0到3的數(shù),對(duì)應(yīng)著4組工作寄存器。一旦指定工作寄存器組,默認(rèn)的工作寄存器組就不會(huì)被壓棧,這將節(jié)省32個(gè)處理周期,因?yàn)槿霔:统鰲6夹枰?個(gè)處理周期。這一做法的缺點(diǎn)是所有調(diào)用中斷的過程都必須使用指定的同一個(gè)寄存器組,否則參數(shù)傳遞會(huì)發(fā)生錯(cuò)誤。因此對(duì)于using,在使用中需靈活取舍。

關(guān)于using:
您在文中說明“這一做法的缺點(diǎn)是所有調(diào)用中斷的過程都必須使用指定的同一個(gè)寄存器組”是不是這個(gè)意思?
舉個(gè)例子來說:
定義一個(gè)函數(shù)
voidfunc(unsignedchari){
...
if(++i==0x12){
...
}
...
}
有如下一個(gè)中斷函數(shù)
voidint_0(void)interrupt0using1{
....
}
在默認(rèn)狀態(tài)下,func使用寄存器組0(BANK0),那么當(dāng)int_0調(diào)用func時(shí)是否存在當(dāng)傳遞參數(shù)時(shí)會(huì)造成參數(shù)傳遞錯(cuò)誤?
謝謝!

如果在中斷服務(wù)函數(shù)ISR中使用寄存器,那么必須處理好using的使用問題:
1、中斷服務(wù)函數(shù)使用using指定與主函數(shù)不同的寄存器組(主函數(shù)一般使用Registerbank0)。
2、中斷優(yōu)先級(jí)相同的ISR可用using指定相同的寄存器組,但優(yōu)先級(jí)不同的ISR必須使用不同的寄存器組,在ISR中被調(diào)用的函數(shù)也要使用using指定與中斷函數(shù)相同的寄存器組。
3、如果不用using指定,在ISR的入口,C51默認(rèn)選擇寄存器組0,這相當(dāng)于中斷服務(wù)程序的入口首先執(zhí)行指令:
MOVPSW#0
這點(diǎn)保證了,沒使用using指定的高優(yōu)先級(jí)中斷??梢灾袛嗍褂貌煌募拇嫫鹘M的低優(yōu)先級(jí)中斷。
4、使用using關(guān)鍵字給中斷指定寄存器組,這樣直接切換寄存器組而不必進(jìn)行大量的PUSH和POP操作,可以節(jié)省RAM空間,加速M(fèi)CU執(zhí)行時(shí)間。寄存器組的切換,總的來說比較容易出錯(cuò),要對(duì)內(nèi)存的使用情況有比較清晰的認(rèn)識(shí),其正確性要由你自己來保證。特別在程序中有直接地址訪問的時(shí)候,一定要小心謹(jǐn)慎!至于“什么時(shí)候要用到寄存器組切換”,一種情況是:當(dāng)你試圖讓兩個(gè)(或以上)作業(yè)同時(shí)運(yùn)行,而且它們的現(xiàn)場需要一些隔離的時(shí)候,就會(huì)用上了。在ISR或使用實(shí)時(shí)操作系統(tǒng)RTOS中,寄存器非常有用。
寄存器組使用的原則:
1、8051的最低32個(gè)字節(jié)分成4組8寄存器。分別為寄存器R0到R7。寄存器組由PSW的低兩位選擇。在ISR中,MCU可以切換到一個(gè)不同的寄存器組。對(duì)寄存器組的訪問不可位尋址,C51編譯器規(guī)定使用using或禁止中斷的函數(shù)(#pragmadISAble)均不能返回bit類型的值。
2、主程序(main函數(shù))使用一組,如bank0;低中斷優(yōu)先級(jí)的所有中斷均使用第二組,如bank1;高中斷優(yōu)先級(jí)的所有中斷均使用再另外一組,如bank2。顯然,同級(jí)別的中斷使用同一組寄存器不會(huì)有問題,因?yàn)椴粫?huì)發(fā)生中斷嵌套;而高優(yōu)先級(jí)的中斷則要使用與低優(yōu)先級(jí)中斷不同的一組,因?yàn)橛锌赡艹霈F(xiàn)在低優(yōu)先級(jí)中斷中發(fā)生高優(yōu)先級(jí)中斷的情況。編譯器會(huì)自動(dòng)判斷何時(shí)可使用絕對(duì)寄存器存取。
3、在ISR中調(diào)用其它函數(shù),必須和中斷使用相同的寄存器組。當(dāng)沒用NOAREGS命令做明確的聲明,編譯器將使用絕對(duì)寄存器尋址方式訪問函數(shù)選定(即用using或REGISTERBANK指定)的寄存器組,當(dāng)函數(shù)假定的和實(shí)際所選的寄存器組不同時(shí),將產(chǎn)生不可預(yù)知的結(jié)果,從而可能出現(xiàn)參數(shù)傳遞錯(cuò)誤,返回值可能會(huì)在錯(cuò)誤的寄存器組中。
舉一例子:當(dāng)需要在中斷內(nèi)和中斷外調(diào)用同一個(gè)函數(shù),假定按照程序的流程控制,不會(huì)出現(xiàn)函數(shù)的遞歸調(diào)用現(xiàn)象,這樣的調(diào)用會(huì)不會(huì)出現(xiàn)問題?若確定不會(huì)發(fā)生重入情況,則有以下兩種情況:
1、如果ISR和主程序使用同一寄存器組(主程序缺省使用BANK0,若ISR沒有使用using為其指定寄存器區(qū),則缺省也使用BANK0),則不需其他設(shè)置。
2、如果ISR和主程序使用不同的寄存器組(主程序缺省使用BANK0,ISR使用using指定了其他BANK),則被調(diào)用函數(shù)必須放在:
#pragmaNOAREGS
#pragmaAREGS
控制參數(shù)對(duì)中,指定編譯器不要對(duì)該函數(shù)使用絕對(duì)寄存器尋址方式;或者也可在Options->C51,選中“Don'tuseabsoluteregisteraCCesses”,使所有代碼均不使用絕對(duì)寄存器尋址方式(這樣,執(zhí)行效率將稍有降低)。不論以上的哪一種情況,編譯器均會(huì)給出重入警告,需手工更改OVERLAY參數(shù),做重入說明。
3、還有一種辦法:如果被調(diào)用函數(shù)的代碼不是很長,還是將該函數(shù)復(fù)制一份,用不同的函數(shù)名代替,這種情況適合ROM有足夠多余的空間。
因此,對(duì)using關(guān)鍵字的使用,如果沒把握,寧可不用,交給編譯系統(tǒng)自己去處理好了。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉