x64汇编调用printf崩溃

发布于 2022-09-01 23:42:53 字数 616 浏览 19 评论 0

原来的代码在Linux上运行正常

BITS 64

extern exit
extern printf

global main

SECTION .data
fmt0    db '%hd', 0Ah, 0h

SECTION .text
main:
label_1:    enter 6, 0
label_2:    xchg rbp, r8

label_9:    push r8

label_10:   mov rsi, 1
label_11:   mov rdi, fmt0
label_12:   xor rax, rax
label_13:   call printf

label_14:   pop r8

label_18:   xchg rbp, r8
label_19:   leave
label_20:   call exit

后来把代码移植到Windows上,把传参改成Windows的调用约定

label_10:   mov rdx, 1
label_11:   mov rcx, fmt0

nasm汇编,MinGW-GCC链接到64位msvcrt.dll。

运行时崩溃,gdb调试发现调用printf前后栈中内容不一致,r8没有恢复。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

时光礼记 2022-09-08 23:42:53

找到一个可能的原因
Windows下用register传参依旧需要分配栈空间。并且需要16字节对齐。
The x64 Application Binary Interface (ABI) is a 4 register fast-call calling convention, with stack-backing for those registers.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文