看不懂! STMFD SP, {LR}^

[复制链接]
 楼主| lihancheng 发表于 2007-5-23 19:43 | 显示全部楼层 |阅读模式
您好!<br />&nbsp;&nbsp;我这几天在看陈明计先生写的lpc2100启动代码中IRQ.s那个文件,下面一句解释百思不得其解!<br />;--------------------------------------------------------&nbsp;<br />STMFD&nbsp;&nbsp;&nbsp;SP,&nbsp;{LR}^&nbsp;&nbsp;;保存SPSR和用户状态的SP,注意不能回写<br />;--------------------------------------------------------<br />请问下:上面那条指令怎么不是保存用户模式的LR寄存器?<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;难道进入中断模式后原来用户模式的&nbsp;LR寄存器就保存的是用户模式的堆栈指针?????<br /><br />还有,程序由用户模式受中断进入中断模式后,LR_irq是不是保存的返回用户模式地址???&nbsp;那原来受保护的用户模式的LR_usr保存的是什么玩艺儿呢??<br />&nbsp;&nbsp;请您不吝赐教!!感激不尽!!
 楼主| lihancheng 发表于 2007-5-23 19:48 | 显示全部楼层

更正

哦!不好意识应改为:<br />;--------------------------------------------------------<br />STMFD&nbsp;&nbsp;&nbsp;SP,&nbsp;{LR}^&nbsp;&nbsp;;保存用户状态的SP,注意不能回写<br />;--------------------------------------------------------<br />&nbsp;问题同上
areshan 发表于 2010-12-8 10:57 | 显示全部楼层
$IRQ_Label
        SUB     LR, LR, #4                      ; 计算返回地址
        STMFD   SP!, {R0-R3, R12, LR}           ; 保存任务环境
        MRS     R3, SPSR                        ; 保存状态
        STMFD   SP, {R3, SP, LR}^   
我也遇到了这个问题没有能理解,上面的是IRQ中,发生IRQ中断后进入的IRQ模式,此时SPSR保存的是中断前(用户模式或系统模式)的CPSR,关键是STMFD   SP, {R3, SP, LR}^ 不能理解,SP没有回写,不知道R3,SP,LR能不能被写入到IRQ的堆栈中,我在KEILL下软仿真发现SP地址没有变化,很奇怪。还有后面^标号不是在有PC时才用到吗?
manager123 发表于 2012-5-24 09:01 | 显示全部楼层
进入了IRQ模式了怎么还能使用User模式下的SP呢?这里的LR不是和保存任务环境那一行的LR一样吗?都是PC的返回值!
chenjm11 发表于 2012-5-25 09:48 | 显示全部楼层
工程师在线解答
您需要登录后才可以回帖 登录 | 注册

本版积分规则

2

主题

6

帖子

0

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