當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]關(guān)于ARM核異常與中斷處理機(jī)制研究

一.ARM處理器異常及其對(duì)應(yīng)的模式

  當(dāng)一個(gè)異常發(fā)生時(shí),ARM處理器總是切換到ARM狀態(tài)(即非Thumb狀態(tài))。Thumb指令集沒有包含進(jìn)行異常處理時(shí)需要的一些指令,因此在異常中斷時(shí),還是要使用ARM指令。

  

 

  每種異常都導(dǎo)致內(nèi)核進(jìn)入一種特定的模式。此外,可以通過修改cpsr,進(jìn)入任何ARM處理器模式。用戶和系統(tǒng)模式是僅有的可不通過相應(yīng)異常進(jìn)入的2中模式。

  當(dāng)一個(gè)異常導(dǎo)致模式的改變時(shí),內(nèi)核自動(dòng)的:

  把cpsr保存到相應(yīng)異常模式下的spsr

  把pc保存到相應(yīng)模式下的lr

  設(shè)置cpsr為相應(yīng)異常模式

  設(shè)置pc為相應(yīng)異常處理程序的入口地址

  二.向量表

  異常發(fā)生時(shí),ARM跳轉(zhuǎn)地址組成的表。

  

 

  三.異常優(yōu)先級(jí)

  復(fù)位異常是優(yōu)先級(jí)最高的異常,一旦復(fù)位異常產(chǎn)生,總是會(huì)發(fā)生復(fù)位異常。注意:當(dāng)一條不屬于ARM或Thumb指令集的指令到達(dá)流水線的執(zhí)行階段時(shí),若此時(shí)沒有其它異常發(fā)生,就會(huì)產(chǎn)生未定義指令異常。ARM處理器會(huì)“詢問”協(xié)處理器,看它能否將其作為一條協(xié)處理器指令來處理。由于協(xié)處理器在流水線之后,所以指令確認(rèn)可以在內(nèi)核的執(zhí)行階段進(jìn)行。如果這條指令不屬于任何一個(gè)協(xié)處理器,則會(huì)產(chǎn)生未定義指令異常。

  

 

  四.中斷

  中斷延時(shí)是指:從外部請(qǐng)求信號(hào)發(fā)出到取出對(duì)應(yīng)的中斷服務(wù)程序(ISR)的第一條指令,這期間的間隔時(shí)間。

  

 

  五.中斷源及其識(shí)別方法

  S3C2440A有60個(gè)中斷源,IRQ有兩種中斷識(shí)別方法:向量中斷和非向量中斷。FIQ只有非向量中斷。在IRQ各個(gè)中斷源中的某一個(gè)中斷源的中斷請(qǐng)求被響應(yīng)時(shí),CPU轉(zhuǎn)至0x18處自動(dòng)加載一條轉(zhuǎn)移指令轉(zhuǎn)至相應(yīng)中斷源的固定中斷向量處。IRQ各個(gè)中斷源的向量地址是固定的,每個(gè)占用一個(gè)字單元。IRQ各個(gè)中斷源若采用非向量中斷,任意一個(gè)中斷源發(fā)出中斷請(qǐng)求,都認(rèn)為發(fā)生了IRQ中斷請(qǐng)求,并自動(dòng)轉(zhuǎn)入IRQ中斷服務(wù)程序執(zhí)行。IRQ中斷服務(wù)程序主要功能是將軟件設(shè)定的中斷向量表中相應(yīng)的中斷源服務(wù)程序入口地址送給PC,并轉(zhuǎn)其執(zhí)行。在非向量中斷模式下,一般在IRQ處放置一條轉(zhuǎn)移指令:B IsrIRQ 。其中,IsrIRQ為所有IRQ中斷服務(wù)程序的總?cè)肟诘刂?,也是非向量中斷模式的中斷源判別及散轉(zhuǎn)程序。

  

[!--empirenews.page--]
六.中斷堆棧設(shè)計(jì)

 

  在堆棧設(shè)計(jì)時(shí),須確定2點(diǎn):

  位置

  決定了在存儲(chǔ)器映射中,堆棧從何處開始。大多數(shù)基于ARM系統(tǒng)設(shè)計(jì)的堆棧是采用向下遞減式的,棧頂位于存儲(chǔ)器的高端地址。

  堆棧大小

  依賴于處理程序的類型-嵌套的還是非嵌套的。一個(gè)嵌套中斷處理程序需要更多的存儲(chǔ)器空間,因?yàn)槎褩㈦S中斷嵌套的深度而增加。

  

 

  第一種方式A,說明了一個(gè)傳統(tǒng)的堆棧安排,中斷的堆棧位于代碼段之下。第二種方式B,中斷堆棧在用戶堆棧之上,位于存儲(chǔ)器的頂端。B優(yōu)于A之處是,B在堆棧溢出時(shí)不會(huì)破壞向量表,因此系統(tǒng)在確認(rèn)堆棧溢出后,還有機(jī)會(huì)糾正自己的錯(cuò)誤。每一種處理器模式都要建立一個(gè)堆棧,這是在處理器每次復(fù)位時(shí)完成的。因?yàn)橄到y(tǒng)復(fù)位是從管理模式開始的,所以不用再切換到管理模式,而其他模式堆棧的建立要切換到相應(yīng)模式。用于模式堆棧-通常是最后設(shè)置的,因?yàn)楫?dāng)處理器處于用戶模式時(shí),沒有直接修改cpsr的方法。由于系統(tǒng)模式和用戶模式共享寄存器,所以可以強(qiáng)制處理器進(jìn)入系統(tǒng)模式來設(shè)置用戶模式堆棧。

  七.中斷處理方法

  1)非嵌套中斷處理

  最簡單的中斷處理是非嵌套的:只有當(dāng)控制權(quán)回到被中斷的任務(wù)或過程時(shí),才允許再次相應(yīng)中斷。由于一個(gè)非嵌套的中斷處理程序在一個(gè)時(shí)段內(nèi)只能為一個(gè)中斷處理程序服務(wù),所以這種形式的中斷處理程序不適合需要為多個(gè)不同優(yōu)先級(jí)中斷服務(wù)的復(fù)雜嵌入式系統(tǒng)。

  

 

  2)嵌套中斷處理

  在處理程序完成當(dāng)前中斷的服務(wù)前重新允許中斷,可以實(shí)現(xiàn)中斷嵌套。嵌套的中斷處理程序入口代碼與簡單的非嵌套中斷處理程序類似。不同之處在于,在推出時(shí),處理程序要測(cè)試被ISR更新過的一個(gè)標(biāo)志。這個(gè)標(biāo)志表明,是否需要做進(jìn)一步的處理,如果不要求更多的處理,那么這個(gè)中斷服務(wù)例程就完成了,處理程序也可以退出;如果需要進(jìn)一步處理,處理程序可能要采取若干措施:重新允許中斷,并/或執(zhí)行一次上下文切換。重新允許中斷包括把IRQ模式切換到SVC或系統(tǒng)模式。在IRQ模式下,不能簡單的允許中斷,因?yàn)檫@可能會(huì)導(dǎo)致鏈接寄存器r14_irq遭到破壞,特別是在執(zhí)行完BL后即發(fā)生一次中斷。執(zhí)行上下文切換包括復(fù)位(清空)IRQ堆棧,因?yàn)楫?dāng)IRQ堆棧中還有數(shù)據(jù)的時(shí),處理程序不會(huì)執(zhí)行上下文切換。所有保存在IRQ堆棧的寄存器必須轉(zhuǎn)移到任務(wù)堆棧,典型地是放在管理模式堆棧上。然后,其余的寄存器也必須被保存到任務(wù)堆棧。在那里,他們會(huì)被轉(zhuǎn)移到堆棧中一個(gè)稱為堆棧幀的保留存儲(chǔ)塊上。

  

 

  如下恢復(fù)現(xiàn)場(chǎng)的指令:

  LDMFD R13!,(R0~R3,PC)^

  這里,寄存器列表后(其中必須包括PC)的后面的“^”表示這是一條特殊形式的指令。在從存儲(chǔ)器裝入PC的同時(shí),CPSR也得到恢復(fù)。

本站聲明: 本文章由作者或相關(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ì)日本游戲市場(chǎng)的投資。

關(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ù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭優(yōu)勢(shì)...

關(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)場(chǎng) 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)閉