《庖丁解牛Linux内核分析》第一章主要讲了计算机的工作原理,具体涉及存储程序计算机工作模型、基本的汇编语言,以及C语言程序汇编出来的汇编代码如何在存储程序计算机工作模型上一步步的执行。
1.1 存储程序计算机工作模型
存储程序计算机的主要思想是:将程序存放在计算机存储器中,然后按存储器中的存储程序的首地址执行程序的第一条指令,以后就按照该程序中编好的指令执行,直至程序执行结束。
1.2 x86-32汇编基础
1.2.1 x86-32 CPU的寄存器
8086 CPU中总共有14个16位的寄存器:AX BX CX DX SP BP SI DI IP FLAG CS DS SS ES。这14个寄存器分为通用寄存器、控制寄存器和段寄存器3种类型。
AX BX CX DX SP BP SI DI为通用寄存器
IP FLAG为控制寄存器
CS DS SS ES段寄存器
1.2.2 数据格式
在Intel的术语规范中,字表示16位数据类型;在IA32中,32位数称为双字;在x86-64中,64位数称为四字。
1.2.3寻址方式和常用汇编指令
汇编指令包括操作码和操作数;其中操作数分为:立即数、寄存器数、存储器引用。
所谓寄存器寻址就是操作的是寄存器,不和内存打交道。
1.3汇编一个简单的C语言程序并分析其汇编指令执行过程
以“.”开头的字符串不会实际执行,所以都删除:
由以上很明显可以看到每个函数对应的汇编代码。Leave用来撤销函数堆栈,enter用来建立函数堆栈。代码在执行过程中堆栈空间和相应的EBP/ESP寄存器会不断发生变化