当前位置: 首页 > news >正文

ARM子程序和栈

微处理器中的栈由栈指针指向存储器中的栈顶来实现,当数据项入栈时,栈
指针向上移动,当数据项出栈时,栈指针向下移动。

实现栈时需要做出两个决定:一是当数据项进栈时是向低位地址方向向上生
长(图a和图b)还是向高位地址方向向下生长(图c和图d),另一个决定是
栈指针时指向当前位置栈顶的数据项(图a和图c)还是指向栈顶上的第一个
空白位置(图b和图d)

术语TOS表示栈顶(top of stack)指明了栈中的下一个数据项,用栈来保存子程序调用后的返回地址
在这里插入图片描述
下图描述了一个栈指针指向栈顶项的栈。当一个项被进栈,栈指针递减,当
一个项出栈,栈指针递增:
在这里插入图片描述

用栈指针SP来定义入栈和出栈操作:

在这里插入图片描述

注意栈指针按照4个字节递增或递减,因为存储器按照字节编址,栈的数据项长为一个字(4个字节)。

子程序调用和返回

可以通过先将返回地址入栈,然后跳转到分支目标地址处来实现子程序调用。
该操作在CISC处理器中由JSR target或BSR target指令来实现。ARM没有实现这
一操作,需通过下述指令来实现:

	; 假设栈朝低地址方向生长且SP指向栈的下一个数据项 SUB	r13,r13,#4	; 栈指针先递减STR	r15,[r13]	; 返回地址入栈B	Target		; 跳转到目标地址…			; 在这里返回

一旦执行完子程序中的代码,就会执行子程序返回指令RTS,且PC将恢复到指令BSR Proc_A被取出来之后的那个点。RTS指令的作用是:
RTS: [PC] <- [[Sp]] ; 把栈中的返回地址复制到PC
[SP] <- [SP] + 4 ; 调整栈指针

栈将向上移动4个字节,因为每个地址都是4个字节。ARM不支持基于栈的子
程序返回机制,则代码应写为:
LDR r12,[r13],#+4 ; 取出保存的PC,栈指针后递增
SUB r15,r12,#4 ; 修正PC并将其加载到r15中以返回

注意:必须修改保存的PC,因为它指向实际返回地址之后4字节的位置(由于
ARM的整数流水线),然后将PC加载到r15,强制从子程序中返回。

尽管上面子程序调用的方法可以工作,但有一个更好的使用ARM块移动指令的机制:

STMIA	   sp!,{r6,lr}	; r6与链接寄存器入栈
...			; 这里是子程序代码
LDMDB   sp!,{r6,pc}	; r6出栈并取出PC,返回地址出栈,送到PC以返回

相关文章:

  • 互联网大厂Java求职面试:AI大模型与云原生架构设计深度解析
  • 项目实战-基于信号处理与SVM机器学习的声音情感识别系统
  • 基于Boost库、Jsoncpp、cppjieba、cpp-httplib等构建Boost搜索引擎
  • Python生活手册-正则表达式:从快递单到咖啡订单的文本魔法
  • 25:三大分类器原理
  • 004-nlohmann/json 快速认识-C++开源库108杰
  • 期末项目Python
  • [特殊字符]Git 操作实战:如何将本地项目提交到远程 Gitee 仓库
  • Windows11 VS code 安装 Cline 调用 Github MCP 配置过程坑点汇总
  • 【platform push 提示 Invalid source ref: HEAD】
  • 青听音乐 1.0.6| 全网音乐免费听,无损下载,4条音源,界面简洁无广告
  • flink监控指标
  • LintCode第766题,LintCode第1141题,LintCode第478题
  • 《OmniMeetProTrack 全维会议链智能追录系统 软件设计文档》
  • Oracle OCP认证考试考点详解083系列09
  • java CompletableFuture 异步编程工具用法1
  • Model Context Protocol (MCP)笔记
  • uniapp中用canvas绘制简单柱形图,小容量,不用插件——简单使用canvas
  • 五一作业-day04
  • 五一の自言自语 2025/5/5
  • 公积金利率降至历史最低!多项房地产利好政策落地,购房者置业成本又降了
  • 象屿集团:对去化压力大、市场有效需求不足区域坚决暂停投资,打造多元上市路径
  • 山东莒县农商银行去年收入、利润下降,资本充足率等指标增长
  • 蓝佛安:中方将采取更加积极有为的宏观政策,有信心实现今年5%左右增长目标
  • 上千游客深夜滞留张家界大喊退票?当地通报情况并致歉
  • 新华每日电讯“关爱青年成长”三连评:青春应有多样的精彩