首页 > 其他分享 >嵌入式:什么是ATPCS

嵌入式:什么是ATPCS

时间:2022-12-31 11:05:42浏览次数:32  
标签:ATPCS R0 什么 局部变量 嵌入式 参数 寄存器 数据 子程序

ATPCS介绍

ATPCS(ARM-Thumb Produce Call Standard)是ARM程序和Thumb程序中子程序调用的基本规则,目的是为了使单独编译的C语言程序和汇编程序之间能够相互调用。这些基本规则包括子程序调用过程中寄存器的使用规则、数据栈的使用规则和参数的传递规则。

寄存器的使用规则

子程序间通过寄存器R0~R3来传递参数,这时,寄存器R0~R3可以记作A1~A4。被调用的子程序在返回前无需恢复寄存器R0~R3的内容;

在子程序中,使用寄存器R4~R11来保存局部变量。这时,寄存器 R4~R11可以记作V1~V8。如果在子程序中使用到了寄存器V1~V8中的某些寄存器,子程序进入时必须保存这些寄存器的值,在返回前必须恢复这些寄存器的值;对于子程序中没有用到的寄存器则不必进行这些操作。在Thumb程序中,通常只能使用寄存器R4~R7来保存局部变量;

寄存器R12用作子程序间的scratch寄存器(用于保存SP,在函数返回时使用该寄存器出栈),记作ip(Intra-Procedure-call Scratch Register;内部程序调用暂存寄存器)。在子程序间的连接代码段中常有这种使用规则;

寄存器R13用作数据栈指针,记作sp。在子程序中寄存器R13不能用作其他用途。寄存器sp在进入子程序时的值和退出子程序时的值必须相等;

寄存器R14称为链接寄存器,记作lr。它用于保存子程序的返回地址。如果在子程序中保存了返回地址,寄存器R14则可以用作其他用途;

寄存器R15是程序计数器,记作pc。它不能用作其他用途。

ATPCS中各寄存器的使用规则及其名称

寄存器

别名

特殊名

使用规则

R0

a1


参数/结果/scratch寄存器1

R1

a2


参数/结果/scratch寄存器2

R2

a3


参数/结果/scratch寄存器3

R3

a4


参数/结果/scratch寄存器4

R4

v1


ARM状态局部变量寄存器1

R5

v2


ARM状态局部变量寄存器2

R6

v3


ARM状态局部变量寄存器3

R7

v4

wr

ARM状态局部变量寄存器4 Thumb状态工作寄存器

R8

v5


ARM状态局部变量寄存器5

R9

v6

sb

ARM状态局部变量寄存器6, 在支持RWPI的ATPCS中为静态基址寄存器

R10

v7

sl

ARM状态局部变量寄存器7, 在支持数据栈检查的ATPCS中为数据栈限制指针

R11

v8

fp

ARM状态局部变量寄存器8/帧指针

R12


ip

子程序内部调用的scratch寄存器

R13


sp

数据栈指针

R14


lr

连接寄存器

R15


pc

程序计数器

数据栈使用规则

满(FULL)栈

当堆栈指针指向栈顶元素,即指向最后一个入栈的数据元素时

空(EMPTY)栈

当堆栈指针指向与栈顶元素相邻的一个可用数据单元时

递减(DESCENDING)堆栈

当数据栈向内存地址减小的方向增长时

递增(ASCENDING)堆栈

当数据栈向内存地址增加的方向增长时,

  • FD (Full Descending) 满递减
  • ED (Empty Descending)空递减
  • FA (Full Ascending) 满递增
  • EA (Empty Ascending) 空递增

ATPCS规定数据栈为FD(满递减)类型。异常中断的处理程序可以使用中断程序的数据栈,但是要保证中断程序的数据栈足够大。

参数传递规则

参数个数固定的子程序参数传递规则

各个浮点参数按顺序处理;

为每个浮点参数分配FP寄存器。分配的方法是,满足该浮点参数需要的且编号最小的一组连续的FP寄存器。
第一个整数参数,通过寄存器R0~R3来传递。其他参数通过数据栈传递

参数个数可变的子程序参数传递规则

对于参数个数可变的子程序,当参数不超过4个时,可以使用寄存器R0~R3来传递参数;当参数超过4个时,还可以使用数据栈来传递参数;

在参数传递时,将所有参数看作是存放在连续的内存字单元中的字数据。然后,依次将各字数据传送到寄存器R0、Rl、R2、R3中,如果参数多于4个,将剩余的字数据传送到数据栈中,入栈的顺序与参数顺序相反,即最后一个字数据先入栈。

子程序结果返回规则

结果为一个32位的整数时,可以通过寄存器R0返回;

结果为一个64位整数时,可以通过寄存器R0和R1返回,依次类推;

结果为一个浮点数时,可以通过浮点运算部件的寄存器f0、d0或者s0来返回;

结果为复合型的浮点数(如复数)时,可以通过寄存器f0\fn或者d0\dn来返回。

对于位数更多的结果,需要通过内存来传递。

参考文献:

孟祥莲.嵌入式系统原理及应用教程(第2版)[M].北京:清华大学出版社,2017.

标签:ATPCS,R0,什么,局部变量,嵌入式,参数,寄存器,数据,子程序
From: https://blog.51cto.com/u_15736437/5982018

相关文章

  • 嵌入式:ARM内嵌汇编及C和ARM汇编相互调用
    内嵌汇编在C程序中嵌入汇编程序可以实现一些高级语言没有的功能,并可以提高执行效率。armcc和armcpp内嵌汇编器支持完整的ARM指令集;tcc和tcpp用于Thumb指集。但是内嵌汇编器......
  • 第141期:为什么技术社区总是这么躁?
    封面图我一直有这种感觉,技术社区总是在不安的躁动,这种躁动直接表现在各种文章的题目上:都擦擦擦年了,你还不会靠靠靠吗都擦擦擦了,你还在靠靠靠吗?面试官:都tm猜猜猜了,你都不会吗......
  • 【面试题】面试官:为什么Promise中的错误不能被try/catch?
    大厂面试题分享面试题库前端面试题库(面试必备) 地址:​​前端面试题库​​前言之前我写过一篇文章,讨论了为什么​​asyncawait​​​中的错误可以被​​trycatch​​​......
  • 为什么会有用户名密码
    我们来思考一下用户名+密码的本质,通过用户名和密码我们可以去获取服务器上的资源,也就是用户名密码是获取资源的钥匙。如果我们需要去获取这份资源,只要拿到钥匙就行了,......
  • 逻辑回归-为什么模型会更加侧重于学习那些数值比较大的列
    np.random.seed(24)features,labels=arrayGenReg(w=[1,-1,1])将第一个特征取值调大100倍features[:,:1]=features[:,:1]*100features---array([[132.9212172......
  • 痞子衡嵌入式:Farewell, 我的写博故事2016-2019
    --题图:苏州天平山枫叶现在是2022年末,痞子衡又要起笔博文年终总结了,看着2020年之前的博文总结缺失,始终觉得缺憾,所以写下此篇2016-2019总结合辑。2016年之前,痞子......
  • 什么是云仿真,云仿真平台有哪些好处
    云仿真是什么?云仿真平台支持一种新的仿真模式一“云仿真”模式,它是一种利用网络和云仿真平台按需组织各种仿真资源(仿真云),以提供用户各种建模与仿真服务的新的仿真模式。上......
  • webpack学习一:什么是模块化开发,什么是webpack,以及二者之间的关系。
    文章目录​​前言​​​​一、模块化开发、webpack​​​​一、模块化开发(前端模块化)​​​​1.JavaScript原始功能​​​​2.匿名函数的解决方案​​​​3.使用模块作为......
  • 开源工作流系统是什么?
    随着数字化时代的到来,开源工作流系统在现代化办公系统中发挥了重要的应用价值,可以说是帮助企业提升办公协作效率的的得力系统之一。那么,什么是开源工作流系统?它的特点又有......
  • 服务体验对于业务的核心价值是什么?怎么衡量?
    要回答这个问题,首先想清楚以下几个问题:①管理层对服务体验的预期是什么?有没有给设定明确的目标?②服务体验的架构及对应的职责是什么?结合当前实际情况,管理层对体验的预期......