我正在尝试使用gcc -c main.s编译以下代码
.intel_syntax noprefix
.global main
main:
push ebp
mov ebp,esp
sub esp,0x10
mov DWORD PTR [ebp-0xc],0x0
mov eax,DWORD PTR [ebp+0xc]
mov eax,DWORD PTR [eax+0x4]
mov DWORD PTR [ebp-0x4],eax
leave
ret我得到了一个错误:
main.s:6:错误:“`push”的操作数类型不匹配
这不管用的原因是什么?
发布于 2018-10-07 18:39:34
从Intel 64和IA-32架构软件开发人员手册,7.3.1.5堆栈操作指令在64位模式
在64位模式下,堆栈指针大小为64位,不能被指令前缀覆盖.在隐式堆栈引用中,地址大小重写将被忽略.在64位模式下,堆栈上32位值的推送和弹出是不可能的。。
(强调我的)
push ebp试图推送32位寄存器,这在64位模式下是不允许的.
这是32位代码(即使push ebp是可编码的,也会在64位模式下崩溃),所以您需要将它组装成32位可执行文件。使用gcc或clang,使用
gcc -m32 -no-pie -fno-pie main.s -o my_prog(没有饼状选项是不必要的,但您可能希望它们为32位代码获得一个更简单的位置相关的可执行文件。)
https://stackoverflow.com/questions/52691517
复制相似问题