共2条
1/1 1 跳转至页
请高手给我这段程序加注释啊~~~
问
因为ARM处理器有7种执行状态,每一种状态的堆栈指针寄存器(SP)都是独立的(System和User三项式使用相同SP寄存器)。因此,对程序中需要用到的每一种模式都要给SP寄存器定义一个堆栈地址。方法是改变状态寄存器(CPSR)内的状态位,使处理器切换到不同的状态,然后给SP赋值。这里列出的代码定义了三种模式的SP指针,其中,I_Bit表示IRQ的中断禁止位;F_Bit表示FIQ的中断禁止位:
@;Set up SVC stack to be 4K on top of zero-init data
LDR r1,=installStack
ADDSP,r1,#2048
@;Set up IRQ and FIQ stacks
MOV r0,#(Mode_IRQ32|I_Bit)
MSRcpsr,r0
MOV r0,r0
ADDSP,r1,#2048*2
MOV r0,#(Mode_FIQ32|I_Bit |F_Bit)
MSR cpsr,r0
MOV r0,r0
ADDSP,r1,#2048*3
一般堆栈的大小要根据需要而定,但是要尽可能给堆栈分配快速和高带宽的存储器。堆栈性能的提高对系统性能的影响是非常明显的。
答 1: 212121顶 答 2: re@;Set up SVC stack to be 4K on top of zero-init data
LDR r1,=installStack //installstack应该是stack基地址
ADDSP,r1,#2048 //设置svc的栈指针installstack+2048
@;Set up IRQ and FIQ stacks
MOV r0,#(Mode_IRQ32|I_Bit) //设IRQ模式,并禁止中断 的值
MSRcpsr,r0 //将上面的值写入CPSR做模式切换
MOV r0,r0 //空操作,类似于NOP指令
ADDSP,r1,#2048*2 //这时的sp就是IRQ模式的sp了,为installstack+2048*2
MOV r0,#(Mode_FIQ32|I_Bit |F_Bit)//设FIQ模式,并禁止中断和快中断
MSR cpsr,r0 //将上面的值写入CPSR做模式切换
MOV r0,r0 //空操作,类似于NOP指令
ADDSP,r1,#2048*3 //这时的sp即使FIQ模式的sp了,为installstack+2048*3
答 3: 好啊~~ 答 4: 我爱你我爱死拉 高手
@;Set up SVC stack to be 4K on top of zero-init data
LDR r1,=installStack
ADDSP,r1,#2048
@;Set up IRQ and FIQ stacks
MOV r0,#(Mode_IRQ32|I_Bit)
MSRcpsr,r0
MOV r0,r0
ADDSP,r1,#2048*2
MOV r0,#(Mode_FIQ32|I_Bit |F_Bit)
MSR cpsr,r0
MOV r0,r0
ADDSP,r1,#2048*3
一般堆栈的大小要根据需要而定,但是要尽可能给堆栈分配快速和高带宽的存储器。堆栈性能的提高对系统性能的影响是非常明显的。
答 1: 212121顶 答 2: re@;Set up SVC stack to be 4K on top of zero-init data
LDR r1,=installStack //installstack应该是stack基地址
ADDSP,r1,#2048 //设置svc的栈指针installstack+2048
@;Set up IRQ and FIQ stacks
MOV r0,#(Mode_IRQ32|I_Bit) //设IRQ模式,并禁止中断 的值
MSRcpsr,r0 //将上面的值写入CPSR做模式切换
MOV r0,r0 //空操作,类似于NOP指令
ADDSP,r1,#2048*2 //这时的sp就是IRQ模式的sp了,为installstack+2048*2
MOV r0,#(Mode_FIQ32|I_Bit |F_Bit)//设FIQ模式,并禁止中断和快中断
MSR cpsr,r0 //将上面的值写入CPSR做模式切换
MOV r0,r0 //空操作,类似于NOP指令
ADDSP,r1,#2048*3 //这时的sp即使FIQ模式的sp了,为installstack+2048*3
答 3: 好啊~~ 答 4: 我爱你我爱死拉 高手
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 | |
【FRDM-MCXN947评测】核间通信MUTEX被打赏50分 |