IA-32汇编语言笔记(2)—— IA32处理器及其寄存器
- 记录汇编语言课笔记,可能有不正确的地方,欢迎指出
- 教材《新概念汇编语言》—— 杨季文
- 这篇文章对应书:第二章 IA32处理器基本功能 2.1.1~2.2.1部分
文章目录
- 一、IA32处理器简介
- 1、IA32系列处理器
- (1)早期的16位处理器
- (2)第一款32位处理器
- 2 、保护方式&实地址方式
- (1)保护方式
- (2)实地址方式
- (3)工作方式切换
- 二、通用寄存器及使用
- 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 |
IA-32汇编语言笔记(2)—— IA32处理器及其寄存器相关推荐
- Intel 64/x86_64/x86/IA-32处理器标志寄存器详解(3) - 32位EFLAGS - 概述
32位标志寄存器中的标志位/域可以分成3组:状态标志位,控制标志位,以及系统标志位.下图定义了这些标志位以及对应的比特位编号.在处理器刚刚初始化之后(通过激活RESET引脚或者INIT引脚),EFLA ...
- Intel 64/x86_64/x86/IA-32处理器标志寄存器详解(5) - 32位EFLAGS - 系统标志
System Flags/Fields 标志寄存器的系统标志位与IO特权级(IOPL)域可以用来控制I/O,可屏蔽硬件中断,程序调试,任务切换,以及设置虚拟8086模式(参看下图).只有特权代码(通常 ...
- Intel 64/x86_64/x86/IA-32处理器标志寄存器详解(4) - 32位EFLAGS - 状态标志与控制标志
Status Flags 状态标志位(比特位0,2,4,6,7和11)指示了算术指令的结果,例如ADD,SUB,MUL,与DIV指令. 标志位 描述 CF(bit 0) 进位/借位Carry.如果算术 ...
- Intel 64/x86_64/x86/IA-32处理器标志寄存器详解(2) - 32位EFLAGS - 80386(386, Intel386)/80486(486, Intel486)
80386/386/Intel386标志寄存器EFLAGS 80386增加了RF/VM标志位,用于支持虚拟8086模式与指令断点调试. 80486/486/Intel486标志寄存器EFLAGS (1 ...
- Intel 64/x86_64/x86/IA-32处理器标志寄存器详解(6) - 64位RFLAGS
64位标志寄存器RFLAGS 在64位模式下,RFLAGS标志寄存器扩展到了64个比特位,但是最高32比特位全部是保留位.RFLAGS(64位模式)与EFLAGS(兼容模式)的系统标志位一致,没有增加 ...
- Intel汇编语言程序设计学习-第二章 IA-32处理器体系结构-下
2.2 IA-32处理器体系结构 如前所述,IA-32是指始于Intel386直到当前最新的奔腾4的系列的处理器(额...这本书是什么时候写的啊,表示现在应该是I7啊),在IA-32的发展过程中,I ...
- Intel汇编语言程序设计学习-第二章 IA-32处理器体系结构-上
第2章 IA-32处理器体系结构 2.1 基本概念 本章以程序员的视角描述Intel IA-32处理器家族机器计算机系统,包括所有的Intel兼容处理器,如AMD的速龙(Athlon)和皓龙(Op ...
- Intel 64/x86_64/IA-32/x86处理器段寄存器 - 32位段寄存器/64位段寄存器
Segment Registers 本节主要讲述Intel处理器中的段寄存器,用于支持处理器的段式存储器管理机制.16位的8086/Intel286处理器有4个段寄存器CS/DS/SS/ES.32位的 ...
- 汇编语言笔记(待更新大作业)
文章目录 前言 计算机系统基础 概述 微处理器/中央处理器(CPU) 概述 性能指标与总线 前端总线(Front Side Bus) 带宽 数据总线DB/地址总线AB/控制总线CB CPU软件特性与指 ...
最新文章
- C++中的 istringstream
- 循环小数是分数集合吗_2020年部分CFA国外考场取消,通过率会受影响吗?
- python输入任意多个成绩-Python 实现输入任意多个数,并计算其平均值的例子
- java spring maven pdf 导出
- 路由器有线优先吗_路由器要定时按这个键,很多人不懂,难怪网速又慢又卡!...
- DPM 2012 R2恢复Exchange 2013单用户邮箱
- 使用 Socket 通信实现 FTP 客户端程序
- 复杂美科技有限公司区块链专利
- 【Tableau server7.0_私人版本】Tableau Server Certified Associate(Tableau CA) 考前预备
- 企业微信没有50名员工可以扩容吗?客户数达到上限会怎样?
- 多边形的定义为什么要强调封闭图形_11.3.1 多边形讲解.ppt
- groovy使用场景
- 为什么我的echarts字体样式这么丑?Echarts 柱状图、饼图 等标签、字体、样式调整
- 局域网自建对讲服务器,Windows 局域网语音对讲
- Azure核心服务(VM)——>创建windows虚拟机并在此之上部署一个cms网站
- 简单了解消息中间件及ActiveMQ
- php 中文转义问题
- 防止form表单提交的几种方式
- 使用 VS 2008 编译 ECW SDK 3.3
- 【BZOJ1067】【SCOI2007】降雨量