接触linux汇编语言的段错误问题。

.code32
.section .data
.section .text
.globl _start
_start:
movl %esp,%ebp
subl $4,%esp
movl $5,-4(%ebp)
int $0x80

运行后提示错误。后来我发现是movl $5,-4(%ebp)这条指令导致段错误。而我把这条指令改成movl $5,-4(%esp)就不报错了。
但是教材上用%ebp这种形式,再改变寄存器测试,最后暂时知道的是只能用%esp到栈上寻址才不会报错;如果只能用%esp去寻址,那么当有新的数据压入栈中的时候,其他数据相对于%esp的距离就会发生变化。
这个段错误是怎么回事啊???

1个回答

访问到不应该访问的内存,%esp不对吧,意义不一样,-4(%ebp)是为了取出参数,你把你的程序带着参数运行看看还报错不

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!