www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]直接訪問寄存器和端口定義sfr P0 0x80sfr P1 0x81sfr ADCON; 0xDEsbit EA 0x9F操作ADCON = 0x08;P1 = 0xFF;io_status = P0 ;EA = 1;在使用了interrupt 1 關(guān)鍵字之后,會自動生成中斷向量在 ISR中不能 與其他 “

直接訪問寄存器和端口

定義

sfr P0 0x80

sfr P1 0x81

sfr ADCON; 0xDE

sbit EA 0x9F

操作

ADCON = 0x08;

P1 = 0xFF;

io_status = P0 ;

EA = 1;

在使用了interrupt 1 關(guān)鍵字之后,會自動生成中斷向量

在 ISR中不能 與其他 “后臺循環(huán)代碼”(the background loop code) 共享局部變量,因?yàn)檫B接器會復(fù)用 在RAM中這些變量的位置 ,所以它們會有不同的意義,這取決于當(dāng)前使用的不同的函數(shù)復(fù)用變量對RAM有限的51來講很重要。所以,這些函數(shù)希望按照一定的順序執(zhí)行 而不被中斷。

void timer0_int(void) interrupt 1 using 2

{

unsigned char temp1;

unsigned char temp2;

executable C statements;

}

“interrupt”聲明表向量生成在(8*n+3),這里,n就是interrupt參數(shù)后的那個數(shù)字這里,在08H的代碼區(qū)域 生成LJMP timer0_int這樣一條指令。

“using” tells the compiler to switch register banks on entry to an interrupt routine. This “context” switch is the fastest way of

providing a fresh registerbank for an interrupt routine’s local data and is to be preferred to stacking registers for very time-criticalroutines. Note that interrupts of the same priority can share a register bank, since there is no risk that they will interrupt each other.

“using” 告訴編譯器 在進(jìn)入51danpi中斷處理器 去切換寄存器的bank。這個”contet”切換是為中斷處理程序的局部變量提供一個新鮮的寄存器bank最快的方式。對時序要求嚴(yán)格的程序,是首選的stack寄存器(保存寄存器到stack)方式。

注意:同樣優(yōu)先級別的中斷可以共享寄存器bank,因?yàn)樗麄兠看螌⒅袛鄾]有危險(xiǎn)。

If a USING 1 is added to the timer1 interrupt function prototype, the pushing of registers is replaced by a simple MOV to PSW to switch registerbanks. Unfortunately, while the interrupt entry is speeded up, the direct register addressing used on entry to sys_interp fails. This is because C51 has not yet been told that the registerbank has been changed. If no working registers are used and no other function is called, the optimizer eliminiates teh code to switch register banks.

如果在timer1的中斷函數(shù)原型中使用using 1, 寄存器的pushing將被MOV to PSW切換寄存器bank 所替換。

不幸的是,當(dāng)一個中斷入口被加速時。用在入口的 直接寄存器尋址將失敗。這是因?yàn)?C51沒有告訴 寄存器bank已經(jīng)改變。如果不工作的寄存器將被使用,如果沒有其他函數(shù)被調(diào)用,優(yōu)化器…..

Logically, with an interrupt routine, parameters cannot be passed to it or returned. When the interrupt occurs, compiler-inserted code is run which pushes the accumulator, B,DPTR and the PSW (program status word) onto the stack. Finally, on exiting the interrupt routine, the items previously stored on the stack are restored and the closing “}” causes a RETI to be used rather than a normal RET.

邏輯上,一個中斷服務(wù)程序,不能傳遞參數(shù)進(jìn)去,也不可返回值。當(dāng)中斷發(fā)生時,編譯器插入的代碼被運(yùn)行,它將累加器,B,DPTR和PSW(程序狀態(tài)字)入棧。最后,在退出中斷程序時,預(yù)先存儲在棧中 被恢復(fù)。最后的”}”結(jié)束符號將插入RETI到中斷程序的最后,為了用 Keil C語言創(chuàng)建一個中斷服務(wù)程序(ISR),利用 interrupt 關(guān)鍵詞和正確的中斷號聲明一個static void函數(shù)。Keil C編譯器自動生成中斷向量,以及中斷程序的進(jìn)口、出口代碼。Interrupt 函數(shù)屬性標(biāo)志著該函數(shù)為ISR。可用using屬性指定ISR使用哪一個寄存器區(qū),這是可選的。有效的寄存器區(qū)范圍為1到3。

中斷源的矢量位置

中斷源 Keil中斷編號 矢量地址

最高優(yōu)先級 6 0x0033

外部中斷0 0 0x0003

定時器0溢出 1 0x000B

外部中斷1 2 0x0013

定時器1溢出 3 0x001B

串口 4 0x0023

定時器2溢出 5 0x002B

DMA 7 0x003B

硬件斷點(diǎn) 8 0x0043

JTAG 9 0x004B

軟件斷點(diǎn) 10 0x0053

監(jiān)視定時器 12 0x0063

1.函數(shù)在調(diào)用前定義與在調(diào)用后定義產(chǎn)生的代碼是有很大差別的(特別是在優(yōu)化級別大于3級時)。(本人也不太清楚為什么,大概因?yàn)樵谡{(diào)用前定義則調(diào)用函數(shù)已經(jīng)知道被調(diào)用函數(shù)對寄存器的使用情況,則可對函數(shù)本身進(jìn)行優(yōu)化;而在調(diào)用后進(jìn)行定義則函數(shù)不知被調(diào)用函數(shù)對寄存器的使用情況,它默認(rèn)被調(diào)用函數(shù)對寄存器(ACC、 B、 DPH、 DPL、 PSW、 R0、 R1、 R2、 R3、R 4、 R5、, R6、 R7)都已經(jīng)改變,因此不在這些寄存器中存入有效的數(shù)據(jù))

2.函數(shù)調(diào)用函數(shù)時除在堆棧中存入返回地址之外,不在堆棧中保存其它任何寄存器。(ACC、 B、 DPH、 DPL、 PSW、 R0、 R1、 R2、 R3、R 4、 R5、, R6、 R7)的內(nèi)容。(除非被調(diào)用函數(shù)使用了using特性)

3.中斷函數(shù)是一個例外,它會計(jì)算自身及它所調(diào)用的函數(shù)對寄存器(ACC、 B、 DPH、 DPL、 PSW、 R0、 R1、 R2、 R3、R 4、 R5、, R6、 R7)的改變,并保存相應(yīng)它認(rèn)為被改變了的寄存器。

4.使用C寫程序時,盡量少使用using n (n=0,1,2,3)特性。(這個特性在本人使用的過程中存在一些問題,不知算不算是一個小bug)

默認(rèn)keil c51中的函數(shù)使用的是0寄存器組,當(dāng)中斷函數(shù)使用using n時,n = 1,2,3或許是對的,但n=0時,程序就已經(jīng)存在了bug(只有中斷函數(shù)及其所調(diào)用的函數(shù)并沒有改變R0 —- R7的值時,這個bug不會表現(xiàn)出來)

一個結(jié)論是,在中斷函數(shù)中如果使用了using n,則中斷不再保存R0—-R7的值。由此可以推論出,一個高優(yōu)先級的中斷函數(shù)及一個低優(yōu)先級的中斷函數(shù)同時使用了using n,(n = 0,1,2,3)當(dāng)n相同時,這個存在的bug 是多么的隱蔽。(這恰是使人想象不到的)

使用不同寄存器組的函數(shù)(特殊情況外)不能相互調(diào)用”using”關(guān)鍵字告訴編譯器切換register bank

如果中斷程序不重要,using關(guān)鍵字能忽略。如果一個函數(shù)被從中斷程序調(diào)用,而此中斷強(qiáng)制使用using,當(dāng)編譯一個被調(diào)用的函數(shù)時,編譯器必須告訴它

1)在函數(shù)前 必須用偽指令

#pragma NOAREGS

在進(jìn)入函數(shù)

#pragma RESTORE

或者

#pragmas AREGS

這樣就不會使用 “絕對地址定位”

2)#pragma REGISTERBANK(n)

用這個指定告訴當(dāng)前使用的bank

用NOAREGS指令 移除 MOV R7,AR7

中斷服務(wù)例程

void timer0_int(void) interrupt 1 using 1

{

unsigned char temp1 ;

unsigned char temp2 ;

}

被調(diào)用的函數(shù)

#pragma SAVE // Rember current registerbank

#pragma REGISTERBANK(1) // Tel C51 base address of current registerbank.

void func(char x)

{

// Called from interrupt routine

// with “using1”

}

#pragma RESTORE // Put back to original registerbank

如果中斷服務(wù)例程使用了using,被中斷服務(wù)例程 調(diào)用的函數(shù)一定要REGISTERBANK(n),一個被ISR調(diào)用的函數(shù)也可能被后臺程序調(diào)用為了函數(shù)”reentrant(可重入8051 系列MCU的基本結(jié)構(gòu)包括:32 個I/O 口(4 組8 bit 端口);兩個16 位定時計(jì)數(shù)器;全雙工串行通信;6 個中斷源(2 個外部中斷、2 個定時/計(jì)數(shù)器中斷、1 個串口輸入/輸出中斷),兩級中斷優(yōu)先級;128 字節(jié)內(nèi)置RAM;獨(dú)立的 64K 字節(jié)可尋址數(shù)據(jù)和代碼區(qū)。中斷發(fā)生后,MCU 轉(zhuǎn)到5個中斷入口處之一,然后執(zhí)行相應(yīng)的中斷服務(wù)處理程序。中斷程序的入口地址被編譯器放在中斷向量中,中斷向量位于程序代碼段的最低地址處,注意這里的串口輸入/輸出中斷共用一個中斷向量。8051的中斷向量表如下:

中斷源 中斷向量

—————————

上電復(fù)位 0000H

外部中斷0 0003H

定時器0 溢出 000BH

外部中斷1 0013H

定時器1 溢出 001BH

串行口中斷 0023H

定時器2 溢出 002BH

interrupt 和 using 都是C5 的關(guān)鍵字。C51中斷過程通過使用interrupt關(guān)鍵字和中斷號(0 到 31)來實(shí)現(xiàn)。中斷號指明編譯器中斷程序的入口地址中斷序號對應(yīng)著8051中斷使能寄存器IE 中的使能位,對應(yīng)關(guān)系如下:

IE寄存器 C51中的 8051的

的使能位 中斷號 中斷源

——————————–

IE.0 0 外部中斷0

IE.1 1 定時器0 溢出

IE.2 2 外部中斷1

IE.3 3 定時器1 溢出

IE.4 4 串口中斷

IE.5 5 定時器2 溢出

有了這一聲明,編譯器不需理會寄存器組參數(shù)的使用和對累加器A、狀態(tài)寄存器、寄存器B、數(shù)據(jù)指針和默認(rèn)的寄存器的保護(hù)。只要在中斷程序中用到,編譯器會把它們壓棧,在中斷程序結(jié)束時將他們出棧。C51 支持所有 5 個 8051 標(biāo)準(zhǔn)中斷從 0 到 4 和在 8051 系列(增強(qiáng)型)中多達(dá) 27 個中斷源。

using 關(guān)鍵字用來指定中斷服務(wù)程序使用的寄存器組。用法是:using 后跟一個0 到3 的數(shù),對應(yīng)著 4 組工作寄存器。一旦指定工作寄存器組,默認(rèn)的工作寄存器組就不會被壓棧,這將節(jié)省 32 個處理周期,因?yàn)槿霔:统鰲6夹枰?2 個處理周期。這一做法的缺點(diǎn)是所有調(diào)用中斷的過程都必須使用指定的同一個寄存器組,否則參數(shù)傳遞會發(fā)生錯誤。因此對于using,在使用中需靈活取舍。

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

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

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

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

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

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

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(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)易近期正在縮減他們對日本游戲市場的投資。

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

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

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

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

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

要點(diǎn): 有效應(yīng)對環(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日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(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)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

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