¿Qué es% gs en la Asamblea
void return_input (void) { char array[30]; gets (array); printf("%s\n", array); }
Después de compilarlo en gcc, esta función se convierte al siguiente código de ensamblaje:
push %ebp mov %esp,%ebp sub $0x28,%esp mov %gs:0x14,%eax mov %eax,-0x4(%ebp) xor %eax,%eax lea -0x22(%ebp),%eax mov %eax,(%esp) call 0x8048374 lea -0x22(%ebp),%eax mov %eax,(%esp) call 0x80483a4 mov -0x4(%ebp),%eax xor %gs:0x14,%eax je 0x80484ac call 0x8048394 leave ret
No entiendo dos líneas:
mov %gs:0x14,%eax xor %gs:0x14,%eax
¿Qué es% gs y qué hacen exactamente estas dos líneas?
Este es el comando de compilación:
cc -c -mpreferred-stack-boundary=2 -ggdb file.c