您好,登錄后才能下訂單哦!
小編給大家分享一下SylixOS Lite版本中斷優先級設置的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
1.非Lite版本中斷關閉方式
SylixOS向用戶提供arch層關中斷的接口,其接口名稱為archIntDisable(),調用該函數將禁用所有外設的中斷。
在ARM體系結構體中,對于ARM系列、Cortex-A系列的芯片,arch層接口archIntDisable()的實現方式如程序清單1.1所示。
程序清單1.1 非Lite版本的arch層中斷關閉方式
FUNC_DEF(archIntDisable) MRS R0 , CPSR ORR R1 , R0, #0x80 MSR CPSR_c, R1 MRS R2 , CPSR AND R2 , R2, #0x80 CMP R2 , #0x80 BNE archIntDisable BX LR FUNC_END()
上述代碼由匯編語言實現,可以看出archIntDisable函數主要是將CPSR寄存器中的中斷失能位置1,以達到屏蔽所有中斷的作用。
2.Lite版本中斷關閉方式
但在ARM Cortex-M、Cortex-A系列的芯片中,并不存在CPSR寄存器,它提供BASEPRI中斷屏蔽寄存器,SylixOS采用中斷優先級的方式屏蔽arch層中斷,其archIntDisable接口的實現方式如程序清單2.1所示。
程序清單2.1 Lite版本的arch層中斷關閉方式
FUNC_DEF(archIntDisable) MRS R0 , BASEPRI MOV R1 , #LW_CFG_CORTEX_M_INT_MASK MSR BASEPRI, R1 BX LR FUNC_END()
Lite版本中arch層關中斷的方式是根據中斷優先級掩碼進行屏蔽,其宏定義LW_CFG_CORTEX_M_INT_MASK即表示中斷優先級掩碼,SylixOS默認設置為2,即當調用archIntDisable函數時,中斷優先級大于2的中斷號將被屏蔽,中斷優先級小于2的中斷號將無法被屏蔽。
因此在Lite版本的BSP中,需要將各個外設器件的中斷優先級設置為大于2,這樣才能關閉所有中斷,否則SylixOS可能在一些需要關閉中斷的關鍵代碼處由于關不住某一外設中斷而導致錯誤。
設置外設中斷優先級的接口定義如程序清單2.2所示,各個驅動外設可以根據實際情況進行設置。
程序清單2.2 設置中斷優先級函數
#include <SylixOS.h> ULONG API_InterVectorSetPriority (ULONG ulVector, UINT uiPrio);
看完了這篇文章,相信你對“SylixOS Lite版本中斷優先級設置的示例分析”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。