x86平台 通过反汇编简单的从程序,分析理解计算机是如何工作的。
2016-02-25 19:32
531 查看
作者:何新宇 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000 下面是一段简单的C语言程序 int g(int x) { return x + 3; } int f(int x) { return g(x); } int main(void) { return f(47) + 1; } 在linux系统中通过
gcc –S –o main.s main.c -m32 反编译得到汇编代码,精简后如下: g: pushl %ebp movl %esp, %ebp movl 8(%ebp), %eax addl $3, %eax popl %ebp ret f: pushl %ebp movl %esp, %ebp subl $4, %esp movl 8(%ebp), %eax movl %eax, (%esp) call g leave ret main: pushl %ebp movl %esp, %ebp subl $4, %esp movl $47, (%esp) call f addl $1, %eax leave ret 精简后的汇编代码,与c的程序执行顺序相同,从main开始,通过对ebp,esp的控制,以及call指令对eip的控制,来达到函数调用和返回。
相关文章推荐
- Linux socket 初步
- Linux Kernel 4.0 RC5 发布!
- linux lsof详解
- linux 文件权限
- Linux 执行数学运算
- 10 篇对初学者和专家都有用的 Linux 命令教程
- Linux 与 Windows 对UNICODE 的处理方式
- Ubuntu12.04下QQ完美走起啊!走起啊!有木有啊!
- 解決Linux下Android开发真机调试设备不被识别问题
- 运维入门
- 运维提升
- Linux 自检和 SystemTap
- Ubuntu Linux使用体验
- c语言实现hashmap(转载)
- Linux 信号signal处理机制
- linux下mysql添加用户
- Scientific Linux 5.5 图形安装教程
- Linux 下无损图片压缩小工具介绍