找回密码
 注册
关于网站域名变更的通知
查看: 218|回复: 2
打印 上一主题 下一主题

SWI 软中断指令中,LR 中放的是异常模式下的返回地址

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2023-2-13 10:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
请问:在 SWI 软中断指令中,LR 中放的是异常模式下的返回地址,而这个地址的低 8 位和低 24 位分别是 thumb 和 ARM 指令下的立即数,这种对应的关系是如何来的 还有执行 THUMB 和 ARM 指令,LR 中放的地址最后的位应是 0 和 00,那么为什么会有swi 01;swi 03  这样的立即数呢
3 K; ~2 t. @7 \  j' e
. X( R" ?* @3 {5 H$ m; k. |

该用户从未签到

2#
发表于 2023-2-13 11:14 | 只看该作者
理解不对,可以去看一看 os_cpu_s.s 这个文件

该用户从未签到

3#
发表于 2023-2-13 13:36 | 只看该作者
软中断异常与指令未定义异常一样,也是当前指令在执行过程中就产生了异常,所以LR中保存的返回地址是当前软中断指令的下一条指令的地址,不需要人为的去修正,返回时直接将LR的值赋给PC即可。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-6-16 02:10 , Processed in 0.093750 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表