关于中断向量表的问题

[复制链接]
 楼主| 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

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

5

主题

14

帖子

1

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