请教熟悉arm汇编的高手,关于ATPCS

[复制链接]
查看11 | 回复3 | 2021-1-27 06:35:02 | 显示全部楼层 |阅读模式
在看ATPCS的时候发现说子函数的数据栈必须是8字节对齐,这是为什么?
有人说如果在该子函数中不再调用其他子函数的时候不需要保证数据栈8字节对齐,这又是为什么?

分 -->
回复

使用道具 举报

千问 | 2021-1-27 06:35:02 | 显示全部楼层
对其是为了提高效率,不对其效率低。应该是这样
回复

使用道具 举报

千问 | 2021-1-27 06:35:02 | 显示全部楼层
对齐的作用和原因:各个硬件平台对存储空间的处理上有很大的不同。一些平台对某些特定类型的数据只能从某些特定地址开始存取。其他平台可能没有这种情况,但是最常见的是如果不按照适合其平台要求对数据存放进行对齐,会在存取效率上带来损失。比如有些平台每次读都是从偶地址开始,如果一个int型(假设为32位系统)如果存放在偶地址开始的地方,那么一个读周期就可以读出,而如果存放在奇地址开始的地方,就可能会需要2个读周期,并对两次读出的结果的高低字节进行拼凑才能得到该int数据。显然在读取效率上下降很多。这也是空间和时间的博弈。
回复

使用道具 举报

千问 | 2021-1-27 06:35:02 | 显示全部楼层
效率问题。很多事需要平衡才能达到最佳。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行