一,实验内容
1,创建一个main.c文件
touch main.c
2,使用命令打开编辑器进行编辑c代码
打开文件命令
gedit main.c
c程序如下图:
3,编译
使用gcc –S –o main.s main.c -m32
命令将main.c中的程序编译成汇编代码,并生成main.s文件,使用cat main.s
查看编译结果如下图
二,实验分析
1,汇编代码
删除多余的代码段后得到的汇编代码如下:
g:
pushl %ebp
movl %esp, %ebp
movl 8(%ebp), %eax
addl $2813, %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 $2813, (%esp)
call f
addl $1, %eax
leave
ret
2,分析汇编代码
对该段汇编代码的分析如下:
其中需要注意的几点:
1.调用函数的现场保护体现出的保护代码如下,主要起到对当前堆栈栈顶的保护
pushl %ebp
movl %esp, %ebp
2.参数的传递与获取调用函数时要传递的参数通过压栈的方式传递给被调用函数
subl $4, %esp
movl $2813, (%esp)
3.参数获取时需要从堆栈中获取
movl 8(%ebp), %eax
4.工作过程中堆栈的变化过程如图所示