PowerPC中断系统简介(一)
1. PowerPC中斷系統(tǒng)簡(jiǎn)介
PowerPC處理器的中斷系統(tǒng)由兩部分組成,一是內(nèi)核的中斷及異常的處理;二是中斷控制器。以P2020處理器為例,包括E500內(nèi)核中斷及異常處理系統(tǒng)和OpenPIC中斷控制器。在E500內(nèi)核中,包含兩種可以暫時(shí)中止處理器運(yùn)行當(dāng)前指令的事件、中斷和異常。其中,異常是由E500內(nèi)核產(chǎn)生的,如出現(xiàn)非法指令,訪問存儲(chǔ)器時(shí)出現(xiàn)TLB Miss等情況;而中斷通過處理器內(nèi)核的外部引腳,如int,cint和mcp信號(hào)有效時(shí)產(chǎn)生的事件。
1.1????? 內(nèi)核中斷向量
中斷向量是指中斷或者異常程序的入口地址?;?/span>603E內(nèi)核的PowerPC處理器,中斷向量為一個(gè)固定的物理地址。在這些處理器進(jìn)入中斷和異常處理程序時(shí),MMU將會(huì)被自動(dòng)關(guān)閉,因此603E內(nèi)核可以使用固定的物理地址作為中斷向量。而E500內(nèi)核在進(jìn)入中斷和異常處理程序時(shí),不能關(guān)閉MMU,因此不能使用物理地址作為中斷向量,而應(yīng)使用IVPR和IVOR寄存器保存相應(yīng)的中斷向量。
在E500內(nèi)核中,使用IVPR和IVORx寄存器共同確定中斷或者異常程序的入口地址。其中,IVPR寄存器提供中斷程序入口地址的第0~15位,IVORx提供中斷程序入口地址的第16~27位,而中斷程序的入口地址的第28~31位為0。IVORx與異常的對(duì)應(yīng)關(guān)系如圖 1.1所示:
圖 1.1 E500內(nèi)核中斷向量表
1.1????? 外部中斷處理流程
E500內(nèi)核的外部中斷由三部分組成,分別為Machine Check異常、Critical Interrupt異常和External Input異常。在E500內(nèi)核中,Machine Check異常采用邊沿觸發(fā)(edge-triggered),而Critical Interrupt異常和External Input異常使用電平觸發(fā)(level-triggered)。
在PIC中,P2020處理器設(shè)置了一些寄存器位,將中斷映射為電平或者邊沿觸發(fā),但這些中斷觸發(fā)條件需要以電平的形式傳遞給E500內(nèi)核。E500內(nèi)核在進(jìn)入中斷和中斷返回時(shí)都
要進(jìn)行程序上下文的切換。頻繁的中斷將會(huì)極大影響處理器的效率。在E500內(nèi)核中,一個(gè)完整的中斷處理流程如下:
1.???????? E500內(nèi)核捕捉到硬件中斷信號(hào)cint、int或者mcp。
2.???????? E500內(nèi)核在捕捉到硬件中斷信號(hào)后,需要做一些必要的準(zhǔn)備,之后才可以進(jìn)入外部中斷處理程序。這些準(zhǔn)備帶來了一些外部中斷處理的延時(shí),這些延時(shí)不可避免。首先E500內(nèi)核清除在指令完成隊(duì)列CQ中的所有指令,除了以下三種指令:
1)??????? 在CQ0中的對(duì)保護(hù)區(qū)域(Guarded)的讀操作指令。
2)??????? 對(duì)禁止Cache內(nèi)存區(qū)域操作的指令。
3)??????? stwcx.指令。
這些指令執(zhí)行完畢后,E500內(nèi)核才可以進(jìn)入中斷模式。在清除CQ后,E500中斷處理模塊從相應(yīng)的中斷向量處預(yù)取指令到IQ中。這些中斷的預(yù)處理過程,其主要目的是為中斷處理程序準(zhǔn)備一個(gè)“干凈”的空間,保證中斷處理程序與被中斷程序之間不相互干擾。由此可見,E500內(nèi)核進(jìn)入中斷處理程序之前,隱式地進(jìn)行了指令同步操作。
3.???????? E500內(nèi)核將中斷程序的返回地址保存在SRR0中;將程序的MSR寄存器保存在SRR1中。對(duì)于一些特殊的異常,如DSI、ISI和TLB Miss等,E500內(nèi)核還會(huì)自動(dòng)保留E500內(nèi)核的其他一些寄存器。
4.???????? E500內(nèi)核將MSR寄存器的CE、ME、DE位保留,其他位全部清零。因此E500內(nèi)核在進(jìn)行外部中斷處理程序時(shí),仍然可以被Critical中斷,Machine check中斷和調(diào)試中斷程序重入,但是不能被外部中斷立即重入。在Linux PowerPC中,外部中斷處理程序會(huì)選擇合適時(shí)機(jī)使能MSR寄存器的EE位,以支持外部中斷的重人。
5.???????? MSR中的PR、EE、IS和DS位將被清除,因此E500內(nèi)核在超級(jí)用戶模式中,運(yùn)行中斷處理程序時(shí),對(duì)程序空間和數(shù)據(jù)空間的訪問都要在地址空間0上進(jìn)行。
6.???????? E500內(nèi)核將根據(jù)IVPR,IVOR4寄存器確定中斷向量,進(jìn)行中斷程序的執(zhí)行。
7.???????? 在中斷處理程序執(zhí)行完畢后,使用rfi指令進(jìn)行中斷返回。rfi指令將從SRR1寄存器中恢復(fù)MSR寄存器的值,并從SRR0寄存器中獲得程序返回地址。rfi指令在進(jìn)行程序正文切換之前還會(huì)進(jìn)行指令和數(shù)據(jù)的同步,還給被中斷的程序一個(gè)“干凈”的空間,之后E500內(nèi)核進(jìn)行中斷返回。
轉(zhuǎn)載于:https://blog.51cto.com/13578681/2073499
總結(jié)
以上是生活随笔為你收集整理的PowerPC中断系统简介(一)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 多delegate使用
- 下一篇: 你也许不知道的Vuejs - 使用ES6