void return_input (void)
{
char array[30];
gets (array);
printf("%s\n",array);
}
在gcc中编译之后,此函数将转换为以下程序集代码:
push %ebp
mov %esp,%ebp
sub $0x28,%esp
mov %gs:0x14,%eax
mov %eax,-0x4(%ebp)
xor %eax,%eax
lea -0x22(%ebp),(%esp)
call 0x8048374
lea -0x22(%ebp),(%esp)
call 0x80483a4
mov -0x4(%ebp),%eax
xor %gs:0x14,%eax
je 0x80484ac
call 0x8048394
leave
ret
我不明白两行:
mov %gs:0x14,%eax
什么是%gs,这两行究竟是什么呢?
这是编译命令:
cc -c -mpreferred-stack-boundary=2 -ggdb file.c