打印

关于中断向量表的问题

[复制链接]
1835|1
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
wbh9527|  楼主 | 2010-3-30 20:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
;中断向量表
Reset
        LDR     PC, ResetAddr        ;复位入口,程序在系统中执行的第一条指令
        LDR     PC, UndefinedAddr    ;未定义指令异常入口地址
        LDR     PC, SWI_Addr            ;软件中断入口地址
        LDR     PC, PrefetchAddr        ;取指令中止异常入口地址
        LDR     PC, DataAbortAddr    ;取数据中止异常入口地址
        DCD     0xb9205f80            ;保留向量,值是其它中断向量累加和的补码
        LDR     PC, [PC, #-0xff0]    ;中断请求IRQ入口地址
        LDR     PC, FIQ_Addr            ;快速中断请求FIQ入口地址
为什么中断请求IRQ的入口地址是【PC,#-0XFF0】?

相关帖子

沙发
ShakaLeo| | 2010-3-31 08:21 | 只看该作者
那个地址应该正好是当前发生中断的向量寄存器。
当前的PC = 0x18+8, (ARM状态三级流水线,PC要+8)
PC-0xFF0 = 0xFFFF F030, 正是VICVectAddr的地址。
但这种写法应该只限于LPC22xx系列,对于其它的ARM并不适用。

使用特权

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

本版积分规则

5

主题

14

帖子

1

粉丝