[英]Segmentation fault (core dumped) when making compliation
I was solving assignment that involve creating small Compiler. 我正在解决涉及创建小型编译器的任务。 My compiler produce the following assembly code for simple assignment statement 我的编译器为简单的赋值语句生成以下汇编代码
// global declaration
int k;
float x,y,z;
// inside main func
k=10;
x = y = k;
Assembly code (I'm getting Segmentation fault (core dumped) : 汇编代码(我遇到了分段错误(核心已转储) :
# 19
# b_push_ext_addr (x)
subl $8, %esp
movl $x, (%esp)
# b_push_ext_addr (y)
subl $8, %esp
movl $y, (%esp)
# b_push_ext_addr (k)
subl $8, %esp
movl $k, (%esp)
# b_deref (signed int)
movl (%esp), %eax
# Proplm on next Line ... why?
movl (%eax), %edx
movl %edx, (%esp)
# b_convert (signed int -> float)
fildl (%esp)
fstps (%esp)
# b_assign (float)
movl (%esp), %edx
addl $8, %esp
movl (%esp), %eax
movl %edx, (%eax)
movl %edx, (%esp)
# b_deref (float)
movl (%esp), %eax
movl (%eax), %edx
movl %edx, (%esp)
# b_convert (float -> double)
flds (%esp)
fstpl (%esp)
# b_convert (double -> float)
fldl (%esp)
fstps (%esp)
# b_assign (float)
movl (%esp), %edx
addl $8, %esp
movl (%esp), %eax
movl %edx, (%eax)
movl %edx, (%esp)
# b_pop ()
addl $8, %esp
When I used gdb: it point to this line: 当我使用gdb时:它指向这一行:
(gdb) x/i $eip
=> 0x80485bd <main+336>: mov (%eax),%edx
The actual fault is at a similar instruction but further down: 实际故障也有类似的说明,但还要进一步说明:
fstps (%esp) # stack has some float
# b_assign (float)
movl (%esp), %edx # edx has a float now
addl $8, %esp
movl (%esp), %eax
movl %edx, (%eax)
movl %edx, (%esp) # write the float onto stack
# b_deref (float)
movl (%esp), %eax # load the float from stack
movl (%eax), %edx # try to use float as pointer => segfault
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.