EDA365电子论坛网
标题:
参数的传递规则
[打印本页]
作者:
Wenghezhong
时间:
2016-7-13 14:57
标题:
参数的传递规则
根据参数个数是否固定可将之程序分为参数个数固定的子程序和参数个数可变的子程序。这2种子程序的参数传递规则是不同的。
- k; m- v8 L2 F& b+ D. r g7 r
1)
+ y/ b q! a. z" ]/ d# X9 d7 N
参数个数固定的子陈旭参数传递规则
) j2 {- ?6 V' I+ P
对于参数个数固定的子程序,参数传递与参数个数可变的子程序参数传递规则不同。如果系统包含浮点运算的硬件部件,浮点参数将按照下面的规则传递:
u2 f( V' y$ ?6 g) T: ^
各个浮点参数按顺序处理。
4 a7 m T/ e" W: t: c/ `$ C+ C' t; S
为每个浮点参数分配FP寄存器。分配的方法是,满足该浮点参数需要的且编号最小的一组连续的FP寄存器。
) t1 A" b+ {! m# {5 O' m
第一个整数参数,通过寄存器R0~R3来传递,其他参数通过数据栈传递。
7 z( b6 M5 N6 q! k8 b/ k
2)
5 ]+ k( |) F I; r. X1 u
参数个数可变的子程序参数传递规则
' N5 Y4 X: P. w5 w! l; o! p I4 c
对于参数个数可变的子程序,当参数不超过4小时,可使用寄存器R0~R3来书安迪参数;当参数超过4小时,还可使用数据栈来传递参数。
! V7 V* ^# X8 M! {
在参数传递时,将所有参数看作是存放在连续的内存单元中的字数据。然后,一次将各字数据传送到寄存器R0,R1,R2,R3中,如果参数多于4个,将剩余的字数据传送到数据栈中,入栈的顺序与参数顺序相反,即最后一个字数据先入栈。
0 d5 L- y) v% I
按照以上传递规则,对于一个浮点数参数可通过寄存器传递,也可通过数据栈传递,也可能一般通过寄存器传递,一般通过数据栈传递。
/ z0 G& Q9 C) `. i; S2 _
3)
- `& g+ R" S& P: r- K
子程序结果返回规则
: J4 Y( _+ _: f6 q* V& ]$ y1 @5 x
结果为一个32位的整数时,可通过寄存器R0返回。
' ~: n0 O& ^" g' J+ q
结果为一个64位整数时,可通过寄存器R0和R1返回,依次类推;
) g e1 x: }1 G. q. |+ t
结果为一个浮点数,可通过浮点运算部件的寄存器F0、D0或者S0来返回;
% A$ W, C4 t" n9 j7 S8 K
结果为复合型的浮点数时,可通过寄存器F0~Fn或者D0~Dn来返回;
q& |/ c; J m) j
对于位数更多的结果,需要通过内存来传递。
$ I' v: v [$ y! x
ARM程序和Thumb程序混合使用的ATPCS
* T4 _: U! J0 R' i7 J+ X% W
为了适应一些特殊需求,对ATPCS规定的子程序间调用的基本规则进行修改,得到了几种不同的子程序调用规则,包括:
- q8 [2 y: j3 S8 T# J0 h
支持数据栈限制检查的ATPCS
5 o9 V8 |3 h: |! J
支持只读段位置无关的ATPCS
: k" K; u# Q0 T3 ~5 m' E* ?! ]# @
支持可读/写段位置无关的ATPCS
) B8 V$ z' Z) o H. `4 V' k4 j+ Z- f
支持ARM程序和Thumb程序混合使用的ATPCS
" @6 n4 c. o' O& [% }! m' \
支持处理器浮点运算的ATPCS
1 M+ z6 P& Y1 W' @
在这里只是简单介绍支持ARM程序和Thumb程序混合实用化的ATPCS
# J7 c! F& z( D( i
。在编译和汇编时,通过使用/interwork告诉编译器生成的目标代码遵守支持ARM程序和Thumb程序混合使用的ATPCS。它一般用于以下场合:
0 q( d4 @" |. A7 {
程序中存在ARM程序调用Thumb程序的情况。
/ Z# `4 L9 e8 h8 b0 C
程序中存在Thumb程序调用ARM程序的情况。
2 t5 E& t+ D: D1 h* s
需要链接器来进行ARM状态和Thumb状态切换的情况。
0 r; [' J" ]- [% X! s' Y
在下述情况下,使用选项/nointerwork:
$ C* s' e1 k8 B/ I4 t* [
程序中不包含Thumb程序;
! B2 o. M$ B. r2 n/ G
用户自己进行ARM状态和Thumb状态切换。
" b0 v% }# p/ I' Y) y
其中,选项/nointerwork是默认的选项。
# [) V; ~7 s3 G% M* I: k% O
注意:在同一个C源程序中不能同时包含ARM指令个Thumb指令,但汇编可以。
2 D% u! B$ Q3 V' L @2 H* ~, \# V% x
如果程序遵守支持ARM程序和Thumb程序混合使用的ATPCS,则程序中ARM子程序和Thumb子程序可相互调用。对于C源程序,只要在编译时指定apcs/interwork选项,编译器生成地代码会自动遵守支持ARM程序和Thumb程序混合使用的ATPCS。而对于汇编源程序,必须保证编写的代码遵守支持ARM程序和Thumb程序混合使用的ATPCS。
/ U0 y; E% b8 d; Q9 E
当链接器发现有ARM子程序与Thumb子程序相互调用时,链接器将修改相应的调用和返回代码,或者添加一段veneers代码(通过将链接器生成的用于程序状态切换的代码段称为veneers代码)来完成程序状态的切换。
作者:
85486952
时间:
2016-7-13 16:04
路过捧场,谢谢分享!
' f- j4 n: k4 Y! L* o$ b* K! H
作者:
wzs6668
时间:
2016-7-14 14:45
路过捧场,谢谢分享!
7 _9 O5 p1 d) r. Q/ i
作者:
Hh0203
时间:
2016-7-18 17:51
路过捧场,谢谢分享!!
作者:
Frank_tw
时间:
2017-11-19 18:38
GOOD
欢迎光临 EDA365电子论坛网 (https://bbs.eda365.com/)
Powered by Discuz! X3.2