您现在的位置是:首页 > 创新技术
堆栈指针寄存器 SP 详解
智慧创新站
2024-12-14【创新技术】255人已围观
简介堆栈是一种具有“后进先出”(LIFO---LastInFirstOut)特殊访问属性的存储结构。堆栈一般使用RAM物理资源作为存储体,再加上LIFO访问接口实现。堆栈的实现方法:在随机存储器区划出一块区域作为堆栈区,数据可以一个个顺序地存入(压入)到这个区域之中,这个过程称为‘压栈’(push)。通...
堆栈是一种具有“后进先出”(LIFO---LastInFirstOut)特殊访问属性的存储结构。堆
栈一般使用RAM物理资源作为存储体,再加上LIFO访问接口实现。
堆栈的实现方法:
在随机存储器区划出一块区域作为堆栈区,数据可以一个个顺序地存入(压入)到这个区域之中,这个过程称为‘压栈’(push)。通常用一个指针(堆栈指针SP---StackPointer)实现做一次调整,SP总指向最后一个压入堆栈的数据所在的数据单元(栈顶)。从堆栈中读取数据时,按照堆栈指针指向的堆栈单元读取堆栈数据,这个过程叫做‘弹出’(pop),每弹出一个数据,SP即向相反方向做一次调整,如此就实现了后进先出的原则。
堆栈是计算机中广泛应用的技术,基于堆栈具有的数据进出LIFO特性,常应用于保存中断断点、保存子程序调用返回点、保存CPU现场数据等,也用于程序间传递参数。
ARM处理器中通常将寄存器R13作为堆栈指针(SP)。ARM处理器针对不同的模式,共有6个堆栈指针(SP),其中用户模式和系统模式共用一个SP,每种异常模式都有各自专用的R13寄存器(SP)。它们通常指向各模式所对应的专用堆栈,也就是ARM处理器允许用户程序有六个不同的堆栈空间。这些堆栈指针分别为R13、R13_svc、R13_abt、R13_und、R13_irq、R13_fiq,如表2-3堆栈指针寄存器所示。
为了更准确地描述堆栈,根据“压栈”操作时堆栈指针的增减方向,将堆栈区分为‘递增堆栈’(SP向大数值方向变化)和‘递减堆栈’(SP向小数值方向变化);又根据SP指针指向的存储单元是否含有堆栈数据,又将堆栈区分为‘满堆栈’(SP指向单元含有堆栈有效数据)和‘空堆栈’(SP指向单元不含有堆栈有效数据)。
这样两两组合共有四种堆栈方式——满递增、空递增、满递减和空递减。
ARM处理器的堆栈操作具有非常大的灵活性,对这四种类型的堆栈都支持。
ARM处理器中的R13被用作SP。当不使用堆栈时,R13也可以用做通用数据寄存器。
很赞哦!(77)
相关文章
- 国内第二家、省内首家!国家创伤医学中心科技创新基地暨北京大学人民医院青岛医院二期项目奠基
- Manz 亚智科技FOPLP封装技术再突破 为车载芯片提供生产解决方案
- 创龙杯风云突变程宇东挑落姚洪新剑指桂冠 65岁特大扭杀各路豪强
- 飞路为杭州趣然教育科技有限公司提供团建活动用车服务
- 中兴通讯申请干扰抑制方法及装置专利,能够降低干扰信号的影响
- 2200年前逆天青铜车马出土,超欧洲1500年的黑科技今天都做不到!
- 36氪首发|半年业务增长近10倍,垃圾回收科技企业「粤能环保科技」获近五千万元人民币A轮融资
- 山东豪迈机械科技股份有限公司 关于2022年度日常关联交易预计的公告
- 华灿光电0元收购格盛科技33.4%股权 加入国资阵营寻求安全感?
- arduino和单片机的区别是什么