你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。
chrome
firefox
safari
ie8及以上
ST
意法半导体官网
STM32
中文官网
ST
全球论坛
登录/注册
首页
技术问答
话题
资源
创客秀
视频
标签
积分商城
每日签到
cortex-M3的压栈问题
[复制链接]
Jane
提问时间:2018-7-4 10:49 /
问答
是否解决:
我们都知道cortex-m3中断时是硬件自动压栈的,这样可以减少中断响应和恢复时间。中断硬件压栈的寄存器为xPSR, PC, LR, R12, R0-R3,为什么其他寄存器不需要压栈呢?
赞
0
收藏
0
评论
1
分享
发布时间:2018-7-4 10:49
举报
请先
登录
后回复
1个回答
随风飘扬
回答时间:2018-7-4 11:20:55
a0a.1 32b0c
Cotrex_m3权威指南中有这样一段话:
“
为啥袒护R0-R3以及R12呢,R4-R11就是下等公民?原来,在ARM上,有一套的C函数调用标准约定(《C/C++ Procedure Call Standard for the ARM Architecture》,AAPCS, Ref5)。个中原因就在它上面:它使得中断服务例程能用C语言编写,编译器优先使用入栈了的寄存器来保存中间结果。当然,如果程序过大也可能要用到R4-R11,此时编译器负责生成代码来push它们。
”
评分
参与人数
1
ST金币
+6
收起
理由
MrJiu
+ 6
赞一个!
查看全部评分
赞
2
评论
回复
支持
2
反对
0
所属标签
相似问题
关于
意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
微信公众号
手机版
快速回复
返回顶部
返回列表
“
为啥袒护R0-R3以及R12呢,R4-R11就是下等公民?原来,在ARM上,有一套的C函数调用标准约定(《C/C++ Procedure Call Standard for the ARM Architecture》,AAPCS, Ref5)。个中原因就在它上面:它使得中断服务例程能用C语言编写,编译器优先使用入栈了的寄存器来保存中间结果。当然,如果程序过大也可能要用到R4-R11,此时编译器负责生成代码来push它们。
”
评分
查看全部评分