x64汇编调用printf崩溃

constroy
  • 33

原来的代码在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没有恢复。

回复
阅读 3.5k
1 个回答
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏