當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]某日一工程師跟我反映,他在使用STM8S芯片開(kāi)發(fā)產(chǎn)品,用到某ADC通道,使用連續(xù)采集模式,開(kāi)啟ADC轉(zhuǎn)換結(jié)束中斷。整個(gè)中斷程序執(zhí)行時(shí)間大概200多us,因?yàn)檫B續(xù)采集轉(zhuǎn)換,在這個(gè)ISR處理過(guò)程中可能會(huì)有新的EOC標(biāo)志產(chǎn)生。他

某日一工程師跟我反映,他在使用STM8S芯片開(kāi)發(fā)產(chǎn)品,用到某ADC通道,使用連續(xù)采集模式,開(kāi)啟ADC轉(zhuǎn)換結(jié)束中斷。整個(gè)中斷程序執(zhí)行時(shí)間大概200多us,因?yàn)檫B續(xù)采集轉(zhuǎn)換,在這個(gè)ISR處理過(guò)程中可能會(huì)有新的EOC標(biāo)志產(chǎn)生。

他發(fā)現(xiàn)一個(gè)奇怪的現(xiàn)象,ADC中斷服務(wù)程序能夠不停的自己嵌套自己,仿佛進(jìn)入了遞歸嵌套,最后導(dǎo)致堆棧溢出跑飛而令系統(tǒng)復(fù)位。在調(diào)試過(guò)程中也的確能發(fā)現(xiàn)ADC中斷服務(wù)程序有連續(xù)多次入棧的情況。


后來(lái)他發(fā)現(xiàn)這個(gè)異常跟在ADC ISR中首尾分別加了一句關(guān)中斷和開(kāi)中斷語(yǔ)句有關(guān)。即在ISR的開(kāi)頭加了disableInterrupt(); ISR結(jié)尾部分加了 enableInterrupt();



如果拿掉首尾那2句開(kāi)關(guān)中斷的代碼就一切正?!,F(xiàn)在最大的疑問(wèn)就是為什么加了這兩句開(kāi)關(guān)中斷代碼會(huì)導(dǎo)致ADC中斷服務(wù)程序能自己嵌套自己?按道理說(shuō)應(yīng)該沒(méi)有影響才對(duì)啊?

關(guān)于中斷函數(shù)不少人可能會(huì)這樣寫(xiě),在ISR的首尾分別加上關(guān)中斷和開(kāi)中斷指令,尤其51系列過(guò)來(lái)的人,經(jīng)常會(huì)在進(jìn)中斷后來(lái)一句CLR EA,中斷退出之前補(bǔ)一句 SETB EA之類的指令。51系列芯片那樣寫(xiě)是沒(méi)有問(wèn)題的。

那對(duì)于STM8芯片來(lái)講,這樣寫(xiě)很可能就會(huì)出問(wèn)題。有時(shí)或許有跟上面一樣的寫(xiě)法而沒(méi)有出問(wèn)題,那是因?yàn)槟愠绦蚝?jiǎn)單沒(méi)有復(fù)雜的多中斷響應(yīng)事件,或者說(shuō)即使某時(shí)段只有單一中斷源,但在中斷響應(yīng)過(guò)程中并無(wú)新的中斷請(qǐng)求發(fā)生。

說(shuō)實(shí)在的,要解釋上面工程師的疑問(wèn),有點(diǎn)說(shuō)來(lái)話長(zhǎng)。不妨先直接說(shuō)出原因,有興趣的話就細(xì)看技術(shù)資料或下面的分析。

顯然,問(wèn)題就出在他在ISR里面做了關(guān)中斷、開(kāi)中斷的操作,隨意了改變正在執(zhí)行的中斷服務(wù)程序的中斷優(yōu)先級(jí)而導(dǎo)致的問(wèn)題。

那個(gè)disableInterrupt();函數(shù)所對(duì)應(yīng)的匯編指令就是SIM,該指令就是關(guān)閉所有可屏蔽的中斷請(qǐng)求,此時(shí)執(zhí)行程序所處中斷優(yōu)先級(jí)為L(zhǎng)3,即軟件中斷禁用級(jí)。正因?yàn)槿绱?,此時(shí)不會(huì)發(fā)生RESET/TRAP/TLI以外的中斷。

下面截圖是STM8技術(shù)手冊(cè)關(guān)于SIM指令的描述。在復(fù)位后的程序開(kāi)始使用該指令是沒(méi)用的。【為什么沒(méi)用呢,因?yàn)槌绦驈?fù)位后所處中斷優(yōu)先級(jí)就是L3。等會(huì)下面還會(huì)提到?!?/p>

紅色方框內(nèi)那句明確說(shuō)明,在中斷執(zhí)行程序的開(kāi)頭不需使用該指令【SIM】,因?yàn)楫?dāng)前中斷程序的優(yōu)先級(jí)已經(jīng)被自動(dòng)的在CC寄存器中L1,L0位設(shè)定?!镜降自趺丛O(shè)定自動(dòng)的呢,下面文字在講ITC_SPR寄存器時(shí)有描述。】


再來(lái)看看 enableInterrupt(); 其實(shí)它所對(duì)應(yīng)的匯編指令就是 RIM.該指令就是解除所有中斷屏蔽,允許各路中斷請(qǐng)求。執(zhí)行該指令后,此時(shí)執(zhí)行程序所處中斷優(yōu)先級(jí)為L(zhǎng)0,即主程序運(yùn)行級(jí)別,屬于最低優(yōu)先級(jí)別。換句話說(shuō),此時(shí)任何新的或待處理的中斷請(qǐng)求都可以中斷或打斷當(dāng)前的執(zhí)行程序。

下面是STM8相關(guān)技術(shù)手冊(cè)對(duì)RIM指令的描述。它說(shuō)該指令一般放在復(fù)位之后的主程序代碼里,并提示在WFI/HALT指令前無(wú)須使用該指令?!敬颂幉⑽磳?duì)該提示作細(xì)節(jié)展開(kāi)。它意思是說(shuō)WFI/HALT指令還具備跟RIM指令同樣的解除中斷屏蔽、允許中斷請(qǐng)求的功效?!?/p>


好,那我們結(jié)合上面案例具體分析下。

先假設(shè)上面那位工程師對(duì)ADC中斷的軟件優(yōu)先級(jí)設(shè)置為2.【當(dāng)然也可設(shè)置為3或1】

當(dāng)ADC產(chǎn)生EOC中斷請(qǐng)求進(jìn)入中斷服務(wù)程序【ISR】后,他首先來(lái)個(gè)SIM指令【即disableInterrupt();】,此時(shí)ISR程序不管剛才響應(yīng)時(shí)刻的中斷優(yōu)先級(jí)是多少,現(xiàn)在被強(qiáng)行更改變?yōu)長(zhǎng)3。從這點(diǎn)看,這個(gè)指令用得就顯得隨意或任性,在有多個(gè)中斷源的情況下,有可能無(wú)意中改變了設(shè)計(jì)者關(guān)于各個(gè)中斷響應(yīng)輕重緩急的先后秩序的初衷。

繼續(xù)回到這個(gè)話題。當(dāng)ADC ISR執(zhí)行一定時(shí)間后,在IRET返回前他又來(lái)個(gè)RIM指令。前面我們介紹了RIM指令的作用,此時(shí)ISR的中斷優(yōu)先級(jí)又由剛才的L3跳到L0,即最低軟件優(yōu)先級(jí)??纱藭r(shí)外邊侯著的新的ADC EOC中斷請(qǐng)求,它的軟件中斷優(yōu)先級(jí)一定高于L0,機(jī)會(huì)來(lái)了,不用等本次ISR執(zhí)行完,立即嵌套進(jìn)入下一輪ADC ISR 程序。每進(jìn)一次還要壓一次棧,這樣多次循環(huán)下去,直至堆棧穿底,PC亂飛,系統(tǒng)崩潰復(fù)位。

原因大致就這樣,不要想當(dāng)然、隨意地在ISR里面添加些影響執(zhí)行程序優(yōu)先級(jí)的指令,換句話說(shuō)你在使用類似SIM/RIM指令時(shí)一定要心里清楚在做什么,有什么目的,會(huì)對(duì)當(dāng)前中斷程序優(yōu)先級(jí)產(chǎn)生什么影響。

如果希望在執(zhí)行某中斷程序時(shí)不要被其它可屏蔽的中斷請(qǐng)求打斷,怎么辦呢?很簡(jiǎn)單,將相關(guān)中斷的ITC_SPR寄存器中相應(yīng)軟件優(yōu)先級(jí)位配置為L(zhǎng)3即可。當(dāng)中斷程序執(zhí)行完畢退出后再回到之前的軟件中斷優(yōu)先級(jí)。

關(guān)于STM8中斷原理,個(gè)人覺(jué)得技術(shù)資料講得不是很細(xì)致。這里根據(jù)個(gè)人的理解做了個(gè)簡(jiǎn)單的總結(jié),一起分享下。并在后面用個(gè)實(shí)例驗(yàn)證上面的分析結(jié)論。


STM8中斷可分為不可屏蔽中斷和可屏蔽中斷。不可屏蔽中斷是指RESET,TRAP,TLI.可屏蔽中斷是指那些基于GPIO的外部中斷和其它外設(shè)中斷。


中斷優(yōu)先級(jí)分硬件優(yōu)先級(jí)和軟件優(yōu)先級(jí)。硬件優(yōu)先級(jí)是固定的,參照各芯片數(shù)據(jù)手冊(cè)里的中斷矢量表的序號(hào)來(lái)定,序號(hào)越小硬件優(yōu)先級(jí)越高。各中斷源或事件的軟件中斷優(yōu)先級(jí)可以通過(guò)寄存器編程配置,其中RESET,TRAP非屏蔽中斷事件無(wú)軟件中斷優(yōu)先級(jí)。


中斷的管理主要基于兩個(gè)寄存器,一個(gè)是CCR,一個(gè)是ITC_SPRx. 其中CCR寄存器中的L1和L0位表示當(dāng)前程序執(zhí)行代碼所處中斷優(yōu)先級(jí)。ITC_SPRx.各寄存器分別對(duì)應(yīng)各個(gè)中斷服務(wù)程序的軟件中斷優(yōu)先級(jí),用戶可自行配置各中斷服務(wù)程序所處的中斷優(yōu)先級(jí)。軟件中斷優(yōu)先級(jí)分為4級(jí),從低往高依次是LEVEL0,LEVEL1,LEVEL2,LEVEL3,分別對(duì)應(yīng)CCR寄存器中的L1、L0位的10,01,00,11。

L0級(jí)即用戶主程序級(jí),就是程序處在按部就班的用戶主程序代碼執(zhí)行狀態(tài),為最低軟件優(yōu)先級(jí)。此時(shí)CCR寄存器中的L1、L0為10。

L3級(jí)又稱軟件中斷禁用級(jí)。這個(gè)地方的表述和理解可能有點(diǎn)費(fèi)勁。在L3軟件中斷優(yōu)先級(jí)狀態(tài)下,不會(huì)發(fā)生軟件中斷,即所謂的中斷關(guān)閉狀態(tài)。此時(shí)CCR寄存器中的L1、L0為11。其中,RESETTRAPTLI三個(gè)中斷源是特例,可以打斷L3優(yōu)先級(jí)狀態(tài)下的執(zhí)行程序而產(chǎn)生中斷。

總之,STM8芯片任何時(shí)刻的程序執(zhí)行總處于某一軟件中斷優(yōu)先級(jí)狀態(tài),其軟件中斷優(yōu)先級(jí)由當(dāng)前CCR寄存器中的L1、L0位決定。理解這個(gè)概念很重要。

下面截圖是對(duì)CCR寄存器描述,系統(tǒng)復(fù)位后的默認(rèn)值為0x28,對(duì)應(yīng)到L1L0就是11。即系統(tǒng)復(fù)位后中斷軟件優(yōu)先級(jí)為L(zhǎng)3,軟件中斷禁用級(jí),也就是中斷關(guān)閉狀態(tài)。這也正好印證了上面講SIM指令時(shí),芯片復(fù)位后使用SIM沒(méi)啥意義。因?yàn)樾酒瑥?fù)位后程序執(zhí)行就處于軟件中斷禁用級(jí)。



上面提到,各個(gè)可屏蔽中斷源的軟件中斷優(yōu)先級(jí)可以通過(guò)ITC_SPRx寄存器進(jìn)行配置。一共8個(gè)ITC_SPR寄存器,每個(gè)寄存器最多可以配置4個(gè)中斷源的軟件中斷優(yōu)先級(jí)。當(dāng)某中斷請(qǐng)求得到響應(yīng)時(shí),該寄存器里相應(yīng)中斷源的VECTnSPR[1:0] 兩位數(shù)據(jù)會(huì)自動(dòng)載入到CCR寄存器中的L1、L0位進(jìn)而決定該中斷服務(wù)程序所處軟件中斷優(yōu)先級(jí)。所以,在各中斷服務(wù)程序里除非有需要,不要在中斷服務(wù)程序里隨意使用類似SIM/RIM這些導(dǎo)致改變執(zhí)行程序中斷優(yōu)先級(jí)的指令。否則,程序優(yōu)先級(jí)改變了而自己可能還不知曉。


我們說(shuō)中斷,提優(yōu)先級(jí),無(wú)非就是為了擬定妥善處理多個(gè)中斷事件發(fā)生競(jìng)爭(zhēng)時(shí)的處理規(guī)則。對(duì)于STM8芯片,在同一時(shí)刻多個(gè)中斷請(qǐng)求發(fā)生時(shí),響應(yīng)規(guī)則如下:

中斷請(qǐng)求中相對(duì)最高軟件優(yōu)先級(jí)的中斷先響應(yīng);

如果軟件優(yōu)先級(jí)一樣,硬件優(yōu)先級(jí)相對(duì)最高的先響應(yīng);


當(dāng)某中斷程序正在執(zhí)行時(shí)外部又產(chǎn)生了新的中斷請(qǐng)求的處理規(guī)則:

如果新的中斷請(qǐng)求的軟件中斷優(yōu)先級(jí)高于正在執(zhí)行的中斷程服務(wù)序的中斷優(yōu)先級(jí)時(shí),當(dāng)前中斷程序?qū)⒈淮驍?,保護(hù)好當(dāng)前現(xiàn)場(chǎng)后轉(zhuǎn)而去執(zhí)行新的高優(yōu)先級(jí)中斷程序。即發(fā)生中斷程序嵌套。因?yàn)檐浖袛鄡?yōu)先級(jí)最高為3,不難理解當(dāng)正在執(zhí)行的中斷程序的優(yōu)先級(jí)為L(zhǎng)3時(shí)是不可能再被RESET,TRAP,TLI以外的中斷事件打斷的,即呈現(xiàn)軟件中斷關(guān)閉狀態(tài)。

另外,如果在中斷服務(wù)程序里使用HALT,POPCC,RIM,SIM和WFI都可能會(huì)改變當(dāng)前中斷服務(wù)程序的中斷優(yōu)先級(jí)。

當(dāng)在某ISR執(zhí)行過(guò)程中調(diào)整L1、L0的值修改軟件中斷優(yōu)先級(jí),同時(shí)該中斷請(qǐng)求標(biāo)志沒(méi)來(lái)及清除或新的中斷請(qǐng)求已經(jīng)產(chǎn)生,如果修改L1L0后的新中斷請(qǐng)求之軟件中斷優(yōu)先級(jí)高于當(dāng)前中斷服務(wù)程序的優(yōu)先級(jí),這時(shí)就會(huì)發(fā)生中斷重入,即該中斷會(huì)被重新響應(yīng),重新運(yùn)行該中斷服務(wù)程序。上面工程師遇到的異常現(xiàn)象就是這種情形。

最后,以TIM1溢出更新中斷服務(wù)程序?yàn)槔Y(jié)合具體的測(cè)試代碼一起驗(yàn)證下。此處把TIM1的溢出周期設(shè)置為2MS,TIM1中斷執(zhí)行時(shí)間大概16ms【當(dāng)然是指不被中斷的情況】,這樣設(shè)計(jì)的目的是為了保證在中斷服務(wù)程序執(zhí)行過(guò)程中有新的TIM1溢出中斷請(qǐng)求發(fā)生。中斷程序要做的事情很簡(jiǎn)單,就是將某個(gè)IO口的電平先高后底各近8MS然后退出?!境薚IM1外,測(cè)試程序也沒(méi)有別的其它中斷使能。】

不妨看看下面兩種不同情形,TIM1溢出中斷服務(wù)程序的運(yùn)行結(jié)果。

一、ISR里面不添加SIM/RIM指令時(shí)的情形。

__interrupt void TIM1_UPD_OVF_TRG_BRK_IRQHandler( void )

{

TIM1_ClearFlag(TIM1_FLAG_UPDATE);//清除TIM1更新標(biāo)志

GPIO

本站聲明: 本文章由作者或相關(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日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

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

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

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

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(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ì)日本游戲市場(chǎng)的投資。

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

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

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

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

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

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

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

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

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

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

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