|
大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是Cortex-M中断向量表对齐原则。
/ J; X$ B/ v# v) W/ W今天这篇文章的内容主要来自于五年前做 Kinetis K32W 系列双核启动时的发现,最近正好有同事碰到了 ARM Cortex-M 中断向量表对齐问题,于是痞子衡想起了这事(感慨自己记性还挺好),翻出了五年前的邮件,将当时测试结果重新整理成文。: P* h, ^( G7 W. p/ U4 E- ]
前段时间痞子衡刚写了篇 《Cortex-M中断向量表原理及其重定向方法》,简单介绍了中断向量表工作机制,今天咱们接着来聊聊这个中断向量表对齐的事:2 e& N5 Z4 {2 ?( d3 J3 S' Y
一、Cortex-M中断向量表对齐原则中断向量表就是一个集中保存系统全部中断处理函数(xxxIRQHandler)地址的常量数组(函数地址要占 4 个字节,因此数组中每个元素大小为 4 字节),表中元素编号如下:
. h. j& n' b. L( x+ W1. 中断向量表第 0 - 1 个向量比较特殊,是程序初始 SP 和 PC 值2 q: ^3 H* z6 Z6 T, T9 C2 q. h2 O
2. 中断向量表第 2 - 15 个向量是系统中断,IRQ 编号为 -14 到 -1
9 x5 |8 }' P7 p/ Q3. 中断向量表第 16 个向量开始是厂商自定义外设中断,IRQ 编号为 0 到 n
, s2 u+ n# i7 ~( @) n. Y - 对于 Cortex-M0/0+/1, ARM 建议的 n 值最大为 15(实际一般厂商都会扩展)
& `5 M' N7 x- t. [& [6 W a - 对于 Cortex-M3/4/7/23, ARM 建议的 n 值最大为 239
- E) m" ^7 B' Q3 B - 对于 Cortex-M33/35P/55, ARM 建议的 n 值最大为 479 |
|