新聞中心

        EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM中斷處理的安全性與高效性研究

        ARM中斷處理的安全性與高效性研究

        作者: 時(shí)間:2009-07-02 來(lái)源:網(wǎng)絡(luò) 收藏

        首先假設(shè)初始化代碼中已正確建立了IRQ堆棧。

        本文引用地址:http://www.104case.com/article/152438.htm


        所有已使能的查詢(xún)與服務(wù)>
        ;將同時(shí)發(fā)生的全部服務(wù),以提
        LDMFD SP!,{R0-R3,R12,R14} ;恢復(fù)上下文
        在上述保存上下文中沒(méi)有必要保存SPSR。因在非嵌套的程序中,它不會(huì)被任何順序的中斷所破壞。
        如果用C語(yǔ)言來(lái)書(shū)寫(xiě)該程序,可以使用關(guān)鍵字一IRQ來(lái)說(shuō)明,以告訴編譯器實(shí)現(xiàn)如下的操作:
        ①保存.ATPCS規(guī)定的被破壞的寄存器;
        ②保存其他中斷程序中用到的寄存器;
        ③同時(shí)將(LR-4)賦予程序計(jì)數(shù)器PC,實(shí)現(xiàn)中斷程序的返回并且恢復(fù)CPSR寄存器的內(nèi)容。
        普通中斷處理的C語(yǔ)言程序可以按如下格式編寫(xiě):


        可見(jiàn),無(wú)論是用C語(yǔ)言還是匯編語(yǔ)言來(lái)編寫(xiě),它們的工作原理都是一樣的。圖2給出了普通中斷處理過(guò)程中,寄存器的保存示意圖(虛線是壓棧保存,實(shí)線是彈棧恢復(fù))。圖中與程序處理的步驟相對(duì)應(yīng),可以幫助理解處理器上下文的保存過(guò)程。

        3 任務(wù)切換
        有操作系統(tǒng)的嵌入式系統(tǒng)中,中斷的發(fā)生要求保存全部寄存器的內(nèi)容到任務(wù)的棧中,它不是基于安全的考慮是因?yàn)榭赡苤袛鄷?huì)導(dǎo)致任務(wù)的切換。任務(wù)切換發(fā)生時(shí)所有任務(wù)的寄存器的值都要保存到該任務(wù)的棧中。下個(gè)任務(wù)的上下文將從該任務(wù)棧中得以恢復(fù)到處理器的寄存器中。下面就本問(wèn)題作出分析并給出實(shí)現(xiàn)的程序代碼。從圖1中斷處理寄存器的保存可知,中斷發(fā)生后任務(wù)的CPSR和PC兩寄存器的值在IRQ模式的SPSR和LR中,所以不能簡(jiǎn)單地切換到任務(wù)運(yùn)行的模式中,否則被中斷任務(wù)返回時(shí)的CPSR和PC將不可見(jiàn)(因?yàn)樗鼈儽4嬖贗RQ模式的專(zhuān)用寄存器中,在其他模式中無(wú)法操作)。此時(shí),可以考慮設(shè)置一些變量區(qū)作為媒介,將其予以轉(zhuǎn)存到任務(wù)運(yùn)行模式的棧中去。



        關(guān)鍵詞: 高效 研究 安全性 處理 中斷 ARM

        評(píng)論


        相關(guān)推薦

        技術(shù)專(zhuān)區(qū)

        關(guān)閉
        主站蜘蛛池模板: 新建县| 察哈| 广饶县| 仁布县| 天峻县| 衡南县| 阜宁县| 清远市| 贡山| 巴彦县| 通州市| 阳山县| 云南省| 得荣县| 荥经县| 安图县| 长岭县| 乌兰察布市| 厦门市| 怀远县| 孟村| 丹棱县| 荥阳市| 南昌市| 喀什市| 武汉市| 达拉特旗| 靖远县| 漳浦县| 江华| 奉节县| 洛阳市| 拉孜县| 凌源市| 江北区| 织金县| 祥云县| 左云县| 诸城市| 邹平县| 京山县|