大家注意到了,上面通道0和通道3 的优先级都是0X20, 这怎么办? D1+y%Ty
// 如果优先级完全相同的多个异常同时悬起,则先响应异常编号最小的那一个。如IRQ #0会比IRQ #3 先得到响应 4AC:_+%c
而且文中还讲了 【优先级分组】,这又是什么回事? fv$&53c
其实我回头看来,这个【优先级分组】和【抢占优先级】【亚优先级】都毫无意义的。 Z7 Rf@a
如果当时用 256级即是 把【中断优先级寄存器】的8位都全用上,就没这个必要了。还什么优先级分组呢! .Y$7>NA
就是因为厂家现在【偷工减料】,才搞出这个明堂来的。 z0mMB ddaA
是这样的,在应用程序中断及复位控制寄存器(AIRCR) 中的 10:8 位【3位】是表示【优先级分组】 lJ!PgM1?l
它作用主要是用于对【中断优先级寄存器】『我们现在中用了BIT7,BIT6,BIT5三位』的功能的说明。 UqL/= ?s,
有一个表,在《Cortex-M3 权威指南》的110页, 例如我们把AIRCR的10:8 位设为【5】 , sZgV9{uk
查表可得【抢占优先级】=【7:6】,【亚优先级】=【5:0】,
\nzwz&gP
对于【中断优先级寄存器】只用了BIT7,6,5, 因此我们可以看作是 【7:6】,【5】。那4-0 可以不管。 yXgwx>
现在我们的 IRQ0=0X20, IRQ3=0X20, 也就是 【0 0 1 0 】『 bit7=0,bit6=0,bit5=1,bit4=0』 p x c\{!|
因为大家(IRQ0/IRQ3)的 【抢占优先级】=【7:6】都是0, 说明它们的中断相应级别是一样的。 ma<[/T
再继续判断它们哪个更优先的责任就要看【5】,结果连【5】都是一样的! -uoy*fQ
那就按默认: !1`2SZ+p
// 如果优先级完全相同的多个异常同时悬起,则先响应异常编号最小的那一个。如IRQ #0会比IRQ #3 先得到响应 k 7n20 `
由于CM3没有 进中断【关全局中断相应】这事,只要是中断通道打开了,就会存在 通道间的 嵌套,即是会发生 8^^A9y[O
【抢占】的情况了。
|