新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > Cortex-M3的中斷優先級的分組方式

        Cortex-M3的中斷優先級的分組方式

        作者: 時間:2016-11-11 來源:網絡 收藏
        Cortex-M3中斷優先級分組方式最多可以有有8種,因為CM3強制規定:SubPriority至少要占一個位(如果沒有該強制規定,那么CM3分組方式最多有9種)。

        我們知道:STM32把指定中斷優先級的寄存器的MSB4位有效,共有以下5種分組方式:
        第0組方式:所有4位用于響應優先級
        第1組方式:最高1位用于搶占式優先級,最低3位用于響應優先級
        第2組方式:最高2位用于搶占式優先級,最低2位用于響應優先級
        第3組方式:最高3位用于搶占式優先級,最低1位用于響應優先級
        第4組方式:所有4位用于搶占式優先級

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

        在MISC.H里面有:


        #define NVIC_PriorityGroup_0 ((uint32_t)0x700) /* 0 bits for pre-emption priority
        4 bits for subpriority */
        #define NVIC_PriorityGroup_1 ((uint32_t)0x600) /* 1 bits for pre-emption priority
        3 bits for subpriority */
        #define NVIC_PriorityGroup_2 ((uint32_t)0x500) /* 2 bits for pre-emption priority
        2 bits for subpriority */
        #define NVIC_PriorityGroup_3 ((uint32_t)0x400) /* 3 bits for pre-emption priority
        1 bits for subpriority */
        #define NVIC_PriorityGroup_4 ((uint32_t)0x300) /* 4 bits for pre-emption priority
        0 bits for subpriority */



        我們發現:第4組方式是“所有4位用于搶占式優先級”,那么這是不是與"SubPriority至少要占一個位"相沖突呢?


        答案:當然不沖突了!因為雖然STM32的"優先級配置寄存器"沒有使用bit3、bit2、bit1、bit0,但是卻允許從它們中分組(分組位置由應用程序中斷及復位控制寄存器(AIRCR)的[10:8]決定)。


        =========================


        第0組采用的分組方式是


        bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0


        第1組采用的分組方式是


        bit7bit6 bit5 bit4 bit3 bit2 bit1 bit0


        第2組采用的分組方式是


        bit7 bit6bit5 bit4 bit3 bit2 bit1 bit0


        第3組采用的分組方式是


        bit7 bit6 bit5bit4 bit3 bit2 bit1 bit0


        第4組采用的分組方式是


        bit7 bit6 bit5 bit4bit3 bit2 bit1 bit0



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 洞口县| 海原县| 景宁| 修水县| 柘荣县| 抚宁县| 万宁市| 石楼县| 灵璧县| 古田县| 锦屏县| 双江| 商洛市| 武定县| 贵定县| 新宁县| 久治县| 遂溪县| 乐陵市| 呼和浩特市| 惠水县| 石城县| 玉门市| 永仁县| 沛县| 通江县| 辽源市| 上思县| 新巴尔虎右旗| 武强县| 息烽县| 临城县| 莆田市| 武山县| 万年县| 屯昌县| 新兴县| 平罗县| 罗平县| 华阴市| 遵义县|