共2条
1/1 1 跳转至页
EasyARM2100 关于EasyARM2100开发板的问题

问
在该开发板附带的向量中断例子中的main()函数说明中提到了在startup.s文件中使能IRQ中断(清零CPSR的I位),在用户手册中也说要手动清零CPSR的I位,请问这是怎么回事,能稍微详悉解释一下吗?GPSR是什么(在说明书里面没有看到有这个寄存器的说明,所以估计不是寄存器),I位又是哪一位?如何在startup.s中改?
答 1:
CPSR是程序状态寄存器,它控制和反映当前处理器的模式和状态具体可以参看ARM相关文档,或者下载《基础教程》第三章课件。
;Build the SVC stack
;设置中断模式堆栈
MSR CPSR_c, #0xd2
LDR SP, StackIrq
;Build the FIQ stack
;设置快速中断模式堆栈
MSR CPSR_c, #0xd1
LDR SP, StackFiq
;Build the DATAABORT stack
;设置中止模式堆栈
MSR CPSR_c, #0xd7
LDR SP, StackAbt
;Build the UDF stack
;设置未定义模式堆栈
MSR CPSR_c, #0xdb
LDR SP, StackUnd
;Build the SYS stack
;设置系统模式堆栈
MSR CPSR_c, #0xdf <----改为“0x5f”即可在进入main函数时打开中断
LDR SP, =StackUsr-32
;Build the SVC stack
;设置中断模式堆栈
MSR CPSR_c, #0xd2
LDR SP, StackIrq
;Build the FIQ stack
;设置快速中断模式堆栈
MSR CPSR_c, #0xd1
LDR SP, StackFiq
;Build the DATAABORT stack
;设置中止模式堆栈
MSR CPSR_c, #0xd7
LDR SP, StackAbt
;Build the UDF stack
;设置未定义模式堆栈
MSR CPSR_c, #0xdb
LDR SP, StackUnd
;Build the SYS stack
;设置系统模式堆栈
MSR CPSR_c, #0xdf <----改为“0x5f”即可在进入main函数时打开中断
LDR SP, =StackUsr-32
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
“我踩过的那些坑”主题活动——第002期 | |
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |