浅谈MDK,IAR,CLANG和GCC的局部变量字节对齐处理差异(2023-10-13)
2023-10-14 15:29阅读:
视频:
https://www.bilibili.com/video/BV1CB4y1Z7kA
问题由来:
早期这个帖子里面的局部变量对齐仅测试了MDK AC5,但项目中使用AC6发现了新问题,看来AAPCS规约研究的还是不够细:
https://www.armbbs.cn/forum.php?mod=viewthread&tid=109400
当时对局部变量的描述如下:局部变量使用的是栈空间(除了静态局部变量和编译器优化不使用栈,直接用寄存器做变量空间),也就是大家使用在xxxx.S启动文件开辟的stack空间。
在M内核里面,局部变量的对齐问题如果研究起来是最烧脑的,这个涉及到AAPCS规约(Procedure Call Standard for the Arm Architecture,
Arm架构的程序调用标准)。
https://www.bilibili.com/video/BV1CB4y1Z7kA
问题由来:
早期这个帖子里面的局部变量对齐仅测试了MDK AC5,但项目中使用AC6发现了新问题,看来AAPCS规约研究的还是不够细:
https://www.armbbs.cn/forum.php?mod=viewthread&tid=109400
当时对局部变量的描述如下:局部变量使用的是栈空间(除了静态局部变量和编译器优化不使用栈,直接用寄存器做变量空间),也就是大家使用在xxxx.S启动文件开辟的stack空间。
在M内核里面,局部变量的对齐问题如果研究起来是最烧脑的,这个涉及到AAPCS规约(Procedure Call Standard for the Arm Architecture,
