形象化的理解STM32的NVIC.请香版和高手指正.

[复制链接]
 楼主| wu0232 发表于 2008-11-20 21:40 | 显示全部楼层 |阅读模式
ic, STM32, vi, IO, AN
绕来绕去终于大概明白了。

STM32有43个channel的settable的中断源;AIRC(Application Interrupt and Reset Register)寄存器中有用于指定优先级的4 bits。这4个bits用于分配preemption优先级和sub优先级,在STM32的固件库中定义如下
/* Preemption Priority Group -------------------------------------------------*/
#define NVIC_PriorityGroup_0         ((u32)0x700) /* 0 bits for pre-emption priority
                                                     4 bits for subpriority */
#define NVIC_PriorityGroup_1         ((u32)0x600) /* 1 bits for pre-emption priority
                                                     3 bits for subpriority */
#define NVIC_PriorityGroup_2         ((u32)0x500) /* 2 bits for pre-emption priority
                                                     2 bits for subpriority */
#define NVIC_PriorityGroup_3         ((u32)0x400) /* 3 bits for pre-emption priority
                                                     1 bits for subpriority */
#define NVIC_PriorityGroup_4         ((u32)0x300) /* 4 bits for pre-emption priority
                                                     0 bits for subpriority */

形象化的理解是:

你是上帝,
造了43个人,这么多人要分社会阶级和社会阶层了;
因为“阶级”的词性比较重;"阶层"比较中性,
所以preemption优先级->阶级;每个阶级内部,有一些阶层,sub优先级->阶层;

如果按照NVIC_PriorityGroup_4这么分,就分为了16个阶级(1个阶层就是1个preemption优先级),0个阶层;高阶级的人,可以打断低阶级的正在做事的人(嵌套),最多可以完成1个中断和15级嵌套。
每个阶级(每个preemption优先级),你来指定这43人中,谁进入该阶级;一个人叫EXTI0_IRQChannel,你指定他进入“阶级8”,则
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 8; // 指定抢占式优先级别1,可取0-15

另外,在同一阶级内部,一个人在做事的时候,另外一个人不能打断他;(preemption优先级别相同的中断源之间没有嵌套关系)
还有,如果他们两个同时想做事,因为没有阶层,那么就根据Vector table中的物理排序,让排名靠前的人去做;

又有1个人SPI1_IRQChannel,设定如下
NVIC_InitStructure.NVIC_IRQChannel = SPI1_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; // 指定抢占式优先级别1,可取0-15

SPI1_IRQChannel的阶级高,EXTI0_IRQChannel做事的时候可以打断(嵌套)。



如果按照NVIC_PriorityGroup_3这么分,就分为了8个阶级(1个阶级是1个preemption优先级),每个阶级内有2个阶层(sub优先级);高阶级的人,可以打断低阶级的正在做事的人(嵌套),最多可以完成1个中断和7级嵌套。

每个阶级(每个preemption优先级),你来指定这43人中,谁进入该阶级;一个人叫EXTI0_IRQChannel,你指定他进入“阶级3”,则:
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; // 指定抢占式优先级别1,可取0-7
还需要指定他的阶层:
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; // 指定响应优先级别0,可取0-1

另有1个人叫EXTI9_5_IRQChannel,他的阶级和阶层设定如下
NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3; // 指定抢占式优先级别0,可取0-7
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; // 指定响应优先级别1

那么这两个人是同一阶级的兄弟,一个人在做事的时候,另外一个人不能打断他;(preemption优先级别相同的中断源之间没有嵌套关系)
如果他们两个同时想做事,因为前者的阶层高,所以前者优先。

还有一个人叫USART1_IRQChannel,他的阶级和阶层设定如下
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2; // 指定抢占式优先级别0,可取0-7
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; // 指定响应优先级别1

USART1_IRQChannel的优先级最高,当前面两个人做事的时候,他都可以打断(嵌套)。

以下的类推。
 楼主| wu0232 发表于 2008-11-20 22:01 | 显示全部楼层

继续

如果按照NVIC_PriorityGroup_0这么分,那么没有阶级,只有16个阶层了。

需要给各个人指定阶层编号。sub优先级的范围0-15

当一个人做事的时候,另外的人不能打断他(就没有嵌套了);当多人同时想做事的时候,按照阶层编号的排序,排名靠前的先做事。
阶层编号一样的人同时想做事,那么按照Vector Table硬件排序,排名靠前的先做。
 楼主| wu0232 发表于 2008-11-20 22:03 | 显示全部楼层

请斑竹和高手指正

呵呵。想了一下午+一晚上~~~~~~~~~~`
香水城 发表于 2008-11-20 22:11 | 显示全部楼层

STM32(Cortex-M3)中的优先级概念

楼主看过这片博客吗?

STM32(Cortex-M3)中的优先级概念
 楼主| wu0232 发表于 2008-11-20 22:14 | 显示全部楼层

很仔细地看过

EXTI0_IRQChannel和EXTI9_5_IRQChannel都是从你的例子当中顺过来的呢~~


ps:你觉得我的理解对不?
香水城 发表于 2008-11-20 22:17 | 显示全部楼层

那篇博客中好像没有提到EXTI0_IRQChannel和EXTI9_5_IRQChannel

我们说的是否不是同一篇**?
香水城 发表于 2008-11-20 22:23 | 显示全部楼层

哈哈,谢谢啦,我的记性太差了

 楼主| wu0232 发表于 2008-11-20 22:26 | 显示全部楼层

哼哼。贵人多忘事。

赶快瞅瞅我的理解对不对?

我检查了又检查

发现我真的是太聪明了~~

嘿嘿
香水城 发表于 2008-11-20 22:35 | 显示全部楼层

你这个阶级那个阶层的,看得我够累的

如果你认为这样比喻好理解,也不算错。

哈哈,还是让网友们评判吧。
 楼主| wu0232 发表于 2008-11-20 22:46 | 显示全部楼层

嘿嘿

我怎么觉得阶级和阶层好理解呢?

看来深深地被灌输了...

hoho

没错就好.终于搞清楚了.
HWM 发表于 2008-11-21 08:13 | 显示全部楼层

LZ理解的不错

不过那不是“STM32的NVIC”而是“Cortex-M3的NVIC”,凡采用ARM的Cortex-M3核的玩意儿都遵循NVIC。这也是Cortex-M3的一大特色,即确定了中断系统的实现细节。
发表于 2008-11-21 08:45 | 显示全部楼层

看在你打那么多字的份上,顶一下...

dayboy635 发表于 2008-12-18 23:27 | 显示全部楼层

有点迷糊

43个中断,一共就16个级别,这么分配呢???一直郁闷呢,香主赶快救援啊
zyok 发表于 2008-12-19 00:10 | 显示全部楼层

LS的,谁告诉了你不同的中断优先级必须不同?

zero_cm 发表于 2008-12-20 09:47 | 显示全部楼层

迷糊

搞不懂,刚入手
linfuchi 发表于 2010-6-9 09:52 | 显示全部楼层
谢谢!
nongfuxu 发表于 2010-9-19 18:02 | 显示全部楼层
学无止境,LZ**受益匪浅.
conw2043 发表于 2010-11-29 14:50 | 显示全部楼层
通俗易懂,顶死!
lixiaoxu2meng 发表于 2010-11-29 15:46 | 显示全部楼层
mark:)
dfsa 发表于 2010-11-29 17:14 | 显示全部楼层
还是挺形象的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

26

主题

130

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部