打印

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

[复制链接]
8109|27
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
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)中的优先级概念

使用特权

评论回复
5
wu0232|  楼主 | 2008-11-20 22:14 | 只看该作者

很仔细地看过

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


ps:你觉得我的理解对不?

使用特权

评论回复
6
香水城| | 2008-11-20 22:17 | 只看该作者

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

我们说的是否不是同一篇**?

使用特权

评论回复
7
香水城| | 2008-11-20 22:23 | 只看该作者

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

使用特权

评论回复
8
wu0232|  楼主 | 2008-11-20 22:26 | 只看该作者

哼哼。贵人多忘事。

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

我检查了又检查

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

嘿嘿

使用特权

评论回复
9
香水城| | 2008-11-20 22:35 | 只看该作者

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

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

哈哈,还是让网友们评判吧。

使用特权

评论回复
10
wu0232|  楼主 | 2008-11-20 22:46 | 只看该作者

嘿嘿

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

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

hoho

没错就好.终于搞清楚了.

使用特权

评论回复
11
HWM| | 2008-11-21 08:13 | 只看该作者

LZ理解的不错

不过那不是“STM32的NVIC”而是“Cortex-M3的NVIC”,凡采用ARM的Cortex-M3核的玩意儿都遵循NVIC。这也是Cortex-M3的一大特色,即确定了中断系统的实现细节。

使用特权

评论回复
12
| | 2008-11-21 08:45 | 只看该作者

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

使用特权

评论回复
13
dayboy635| | 2008-12-18 23:27 | 只看该作者

有点迷糊

43个中断,一共就16个级别,这么分配呢???一直郁闷呢,香主赶快救援啊

使用特权

评论回复
14
zyok| | 2008-12-19 00:10 | 只看该作者

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

使用特权

评论回复
15
zero_cm| | 2008-12-20 09:47 | 只看该作者

迷糊

搞不懂,刚入手

使用特权

评论回复
16
linfuchi| | 2010-6-9 09:52 | 只看该作者
谢谢!

使用特权

评论回复
17
nongfuxu| | 2010-9-19 18:02 | 只看该作者
学无止境,LZ**受益匪浅.

使用特权

评论回复
18
conw2043| | 2010-11-29 14:50 | 只看该作者
通俗易懂,顶死!

使用特权

评论回复
19
lixiaoxu2meng| | 2010-11-29 15:46 | 只看该作者
mark:)

使用特权

评论回复
20
dfsa| | 2010-11-29 17:14 | 只看该作者
还是挺形象的

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

26

主题

130

帖子

1

粉丝