- 记录汇编语言课笔记,可能有不正确的地方,欢迎指出
- 教材《新概念汇编语言》—— 杨季文
- 这篇文章对应书:第二章 IA32处理器基本功能 2.1.1~2.2.1部分
文章目录
一、IA32处理器简介
1、IA32系列处理器
- 泛指:基于英特尔IA-32架构的32位微处理器
- 特点:向下兼容
- 并行化程度:流水线
- 处理器位数:32
(1)早期的16位处理器
名称 | 处理器位数 | 寄存器位数 | 外部数据线数量 | 地址线数量 | 特点 |
---|---|---|---|---|---|
8086 | 16 | 16 | 16 | 20(实地址1MB物理寻址) | 引入了存储分段管理的概念 |
8088 | 准16 | 16 | 8(16位内核,封装8位接口) | 20(实地址1MB物理寻址) | 引入了存储分段管理的概念 |
80286 | 16 | 16 | 16 | 24(实地址16MB物理寻址) | 引入了保护方式 |
(2)第一款32位处理器
名称 | 处理器位数 | 寄存器位数 | 外部数据线数量 | 地址线数量 | 特点 |
---|---|---|---|---|---|
80386 | 32 | 32 | 32 | 32(实地址4GB物理寻址) | 全面支持32位数据类型和32位操作; 新增若干新指令; 保护方式提供了完善的保护机制 |
2 、保护方式&实地址方式
- IA32系列CPU有3种工作方式:保护方式(包含一种子工作方式:虚拟8086方式)、实地址方式、系统管理方式
(1)保护方式
- 保护方式是IA32系列处理器的常态工作方式,可以发挥全部性能和特点 ,windows、Linux都运行于保护方式
- 全部32根地址线有效,可寻址4GB物理地址空间
- 支持存储器分段管理 & 可选的存储器分页管理机制
- 支持虚拟存储器的实现,用于指定存储单元的是面向虚拟存储器的虚拟地址
- 提供完善的保护机制
- 支持操作系统实现多任务管理
- 支持虚拟8086方式
(2)实地址方式
- 实地址方式是最初的工作方式:
- 开机/重新设置系统后,IA32工作于实地址方式
- 很久以前8086/8088等只支持实地址方式
- 实地址方式下只能访问最低1MB物理地址空间(00000H-FFFFFH)
- 实地址方式下只支持存储器分段管理,且每个段大小限于64KB,段内有效地址范围0000H-FFFFH。不支持分页
储管理机制。可以认为实地址方式下用于指定要访问存储单元的线性地址就是真实地址- 实地址方式无法发挥IA32处理器 全部性能
- 指令集、执行环境和保护方式相同
- 实地址方式常被称为实方式
(3)工作方式切换
二、通用寄存器及使用
- 寄存器是处理器内的特殊存储单元
- 处理器内有多种不同用途的寄存器
- 寄存器分别有各自的名称,以便表示和访问
1、通用寄存器简介
- IA32系列CPU有8个32位通用寄存器
- 通用寄存器用于存储数据、参与算数逻辑运算、给出存储单元地址
- 名称:
- 32位:
EAX
,EBX
,ECX
,EDX
,ESI
,EDI
,EBP
,ESP
- 16位:
AX
,BX
,CX
,DX
,BP
,SI
,DI
,SP
- 8位:
AH
,AL
,BH
,BL
,CH
,CL
,DH
,DL
- 32位:
- 通用寄存器的高16位不可以单独使用,因为没有名字;但是可以单独用低16位、还可再拆开高低8位单独使用
- 通用寄存器的低16位叫:
AX
,BX
,CX
,DX
,BP
,SI
,DI
,SP
,对应8086中的8个通用寄存器 - 各寄存器作用简要说明
EAX
,EBX
,ECX
,EDX
主要用于算术逻辑运算之中,如ADD/SUB/XOR/OR等ESI
,EDI
,EBP
,ESP
主要用作保存内存地址的指针。
名称 | 作用 |
---|---|
EAX | (针对操作数和结果数据的)累加器,另外还多用于函数返回值中,用于保存返回值 |
EBX | (DS段中的数据指针)基址寄存器 |
ECX | (字符串和循环操作的)计数器,如在循环命令LOOP中,ecx用来循环计数,每执行一次loop,ecx减1 |
EDX | (I/O指针)计数器 |
EBP | (SS段中栈内数据指针)扩展基址指针寄存器,表示栈区域的基地址,在函数被调用时保存ESP的值,函数返回时再把值重新返回给ESP,保证栈不会崩溃,这称为栈帧技术 |
ESI | (字符串操作源指针)源变址寄存器 |
EDI | (字符串操作目标指针)目的变址寄存器,EDI和ESI多与特定指令,如LODS/STOS/REP/MOVS等一起使用,主要用于内存 的复制。 |
ESP | (SS段中栈指针)栈指针寄存器,指示栈区域的栈顶地址,PUSH/POP/CALL/RET等指令可以直接用来操作ESP |