voID return_input (voID){ char array[30]; gets (array); printf("%s\n",array); }
在gcc中编译之后,此函数将转换为以下程序集代码:
push %ebpmov %esp,%ebpsubmov %gs:0x14,%eaxx28,%espmov %gs:0x14,%eaxmov %eax,-0x4(%ebp)xor %eax,%eaxlea -0x22(%ebp),(%esp)call 0x8048374 lea -0x22(%ebp),(%esp)call 0x80483a4 mov -0x4(%ebp),%eaxxor %gs:0x14,%eaxje 0x80484ac call 0x8048394 leave ret
我不明白两行:
cc -c -mpreferred-stack-boundary=2 -ggdb file.c
什么是%gs,这两行究竟是什么呢?
这是编译命令:
mov %gs:0x14,%eax解决方法 GS是一个段寄存器,其在linux中的使用可以在 here上读取(它基本上用于每个进程数据).
该代码用于验证堆栈没有爆炸或已被证实,使用存储在GS 0x14中的金丝雀值,参见this.
总结以上是内存溢出为你收集整理的linux – 什么是汇编中的%gs全部内容,希望文章能够帮你解决linux – 什么是汇编中的%gs所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)