2022-2023-1 20222814 《Linux内核原理与分析》第二周作业
反汇编C程序
首先要编写一个C程序
1、创建c文件,然后编辑
2、编写代码
3、编译c文件,并查看输出结果
4、使用命令将c文件编译成汇编代码,然后查看c文件的汇编代码
5、以下是全部汇编代码
6、通过命令 g/.s*/d 进行精简,可得到简化后的汇编代码
分析:
首先执行main函数
pushl %ebp :esp沿着地址递减的方向指向下一个存储单元,将ebp现在指向的存储单元的地址压入栈中。
movl %esp, %ebp :将ebp寄存器同样指向esp寄存器指向的那块栈地址。
subl $32, %esp :将esp寄存器的内容减32,即向下移动八个帧。
movl $6, (%esp) : 立即数6放到esp所在位置
call func1 : 即调用func1子函数。
movl %eax,28(%esp),: 将eax寄存器中的内容存入28(%esp)中
movl 28(%esp),%eax : 将28(%esp)中的内容存入eax寄存器中
movl %eax,4(%esp),: 将eax寄存器中的内容存入4(%esp)中
call printf:执行printf
执行 func1子函数:
pushl %ebp : 将ebp的值压入栈内。
movl %esp, %ebp : 将ebp寄存器也指向esp所指示的位置。
subl $4, %esp :将esp寄存器的内容减4,即向下移动一个帧。
movl 8(%ebp), %edx : 将8(%ebp)中的内容1存入edx寄存器中
movl %eax,(%esp),: 将eax寄存器中的内容存入(%esp)中
call func2:调用子函数func2
执行 func2子函数:
pushl %ebp : 将ebp的值压入栈内。
movl %esp, %ebp : 将ebp寄存器也指向esp所指示的位置。
movl 8(%ebp), %edx : 将8(%ebp)中的内容1存入edx寄存器中
addl $3,%eax:数值+3
popl %ebp:弹出上一个现场的栈顶指针
ret、leave:返回