新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM中斷處理的研究

        ARM中斷處理的研究

        作者: 時間:2011-07-12 來源:網絡 收藏
        3 任務切換

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

          有操作系統的嵌入式系統中,的發生要求保存全部寄存器的內容到任務的棧中,它不是基于安全的考慮是因為可能會導致任務的切換。任務切換發生時所有任務的寄存器的值都要保存到該任務的棧中。下個任務的上下文將從該任務棧中得以恢復到器的寄存器中。下面就本問題作出分析并給出實現的程序代碼。從圖1寄存器的保存可知,中斷發生后任務的CPSR和PC兩寄存器的值在IRQ模式的SPSR和LR中,所以不能簡單地切換到任務運行的模式中,否則被中斷任務返回時的CPSR和PC將不可見(因為它們保存在IRQ模式的專用寄存器中,在其他模式中無法操作)。此時,可以考慮設置一些變量區作為媒介,將其予以轉存到任務運行模式的棧中去。

          下面假設任務切換是在SVC模式中運行的。結合上面的分析,可以有圖3所示的保存任務切換的示意圖(虛線是壓棧保存,實線是彈棧恢復;LR_Frame和SPSR_Frame是變量區)。

          

        保存任務切換的示意圖

          結合圖3任務切換中斷中的步驟,可以用匯編語言寫出相對應的中斷處理程序:

          

        程序

          

        程序

          4 可重入性中斷

          如果希望在處理中斷時仍能響應其他中斷請求以此來縮短中斷延時,就必須設計可重人性中斷。可重入性中斷是處理多個中斷的一種方法,但它也同時帶來新的問題。在IRQ中斷模式中,如果直接重新允許了IRQ中斷,此時因為執行一條BL指令而將子程序返回的地址保存在LR_irq中,而在此間中斷發生了。新來的中斷會將其返回地址裝入LR_irq中,此時舊中斷子程序的返回地址必將被覆蓋從而導致系統紊亂。此種情形是無法通過將LR_irq壓棧來解決的,如程序語句:

          

        程序

          但是仍不能排除在保存LR之前中斷發生的可能性。要解決上述LR_irq被破壞的問題,就必須切換處理器的模式,常見的是切換到SVC處理模式。在SVC模式中,通過BL調用子程序時會將返回地址保存在LR_SVC之中。此時新中斷發生(因為它會將返回地址保存到LR_irq而不是LR_SVC),不會破壞舊中斷中子程序返回地址了。有了基于上述的原理分析再來編寫可重入性中斷的代碼就思路清晰了。但是為了保證處理的高效性,盡可能地及早允許中斷以縮短延時,在保存完LR_irq和SPSR_irq后,就馬上切換到SVC模式中并重新允許中斷,如圖4所示(虛線是壓棧保存,實線是彈棧恢復)。

          

        可重入中斷處理上下文保存示意圖

          結合圖4中的處理步驟,可以比較清晰地寫出可重入中斷處理的匯編語言程序:

          

        程序

        上一頁 1 2 下一頁

        關鍵詞: 研究 處理 中斷 ARM

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 古浪县| 偃师市| 雅江县| 维西| 墨脱县| 正安县| 信阳市| 棋牌| 石城县| 永胜县| 新乐市| 晋中市| 德惠市| 庄河市| 浮山县| 巩留县| 东丽区| 龙陵县| 信阳市| 太湖县| 连山| 天等县| 韶山市| 资溪县| 巴楚县| 宁远县| 和田县| 广德县| 洛南县| 贵溪市| 松潘县| 广灵县| 平潭县| 营山县| 唐山市| 长治市| 新野县| 开江县| 会理县| 宜宾县| 都江堰市|