)
1. 8086的产生及背景
IBM:International Business Machines Corporation
Intel:Integrated Electronics
- | - |
---|---|
电子管 | ENIAC (1946) ; IBM 701 (1952) |
晶体管 | IBM 7090 (1958) |
集成电路 | IBM 360 (1964)(将集成电路应用到计算机体系,系列机兼容机) |
大规模集成 | IBM Personal Computer ; Intel 4004 (1971) |
-
Intel系列
Intel 4004
Intel 8008
获得了芯片所有权、开放的指令集所有权Intel 8080
2250个晶体管,4bit数据,每秒6万次计算
40脚封装
Intel 8086
16bit数据,5MHz时钟频率
Intel 8088(Intel8086简化版)
IBM在自己的首台PC中采用
注意:系列机、兼容机的思想
2. 8086CPU的内部组织
2.1 8086CPU的内部组织结构
特点:外总线地址输出20位,面向寄存器的操作模式
2.2 8086的寄存器组织
注意:8086的所有可见寄存器均16bit
- 通用寄存器
功能:存放数据
- AX(AH,AL):累加器(乘积低位),I/O数据**
- BX(BH,BL):基地址寄存器
- CX(CH,CL):循环或串操作计数器
- DX(DH,DL):乘除法专用(乘积高位),I/O端口地址
- 段基址寄存器
功能:存放基地址
-
CS:代码段
-
DS:数据段
-
ES:附加段
-
SS:堆栈段
基址寻址 EA=(BR(起始地址))+偏移地址
分段的目的:存储区域的分配及控制
位于BIU(总线接口单元)
注意:基址寄存器的内容不要随意变动
- 指针寄存器(Pointer)
功能:存放段内偏移地址
-
IP 指令指针( Instruction )
下一条要执行指令地址(注意和原理PC的区别) 代码段的偏移地址 CS : IP
-
SP 堆栈指针( Stack )
栈顶偏移地址 堆栈段的偏移地址 SS : SP
-
BP 基址指针( Base )
栈内偏移地址 堆栈段的偏移地址 SS : BP
- 变址寄存器(Index)
功能:存放数据的偏移地址(注意可以不在数据段)
- SI 源变址( Source )
- DI 目的变址( Destination )
均可以和DS联用 — DS : SI DS : DI
串操作时DI和ES联用 — DS : SI ES : DI
- 程序状态字(PSW)
功能:存放条件码标志、控制标志、系统标志
a. 状态标志(条件码Flag)
判断指令的运行结果,经过ALU输出置位
-
CF 进位或借位( Carry )
-
AF 半进位( Auxiliary )
状态标志判断规则 (一) CF(进位),运算时最高有效位产生的进位(或借位),本例CF=1; AF(辅助进位)低4位和高4位之间产生的进位(或借位),仅在BCD码运算时有意义
-
ZF 零( Zero )
-
SF 符号( Sign )
(二) SF(符号),运算结果的最高位,仅对有符号数有意义; ZF(结果为零),运算结果是否为“0”; 当运算结果为全“0”时,ZF成立,ZF=1; 当运算结果不全“0”时,ZF不成立,ZF=0
-
OF 溢出( Overflow )
-
PF 偶校验( Parity )
(三) OF ( 溢出 ),运算结果是否超出表数范围,仅对有符号数有意义; PF ( 偶校验 ),运算结果“1”的个数是否为偶数个 当“1”为偶数个数时,PF成立,PF=1; 当“1”为奇数个数时,PF不成立,PF=0
b. 控制标志
决定机器的控制模式
-
DF (Direction):串操作时的控制方向
当DF=0,增量方向,CLD 当DF=1,减量方向,STD
c. 系统标志
决定系统的工作处理模式
-
IF(Interrupt):是否允许CPU响应可屏蔽中断
当IF=0,关闭中断,CLI 当IF=1,开放中断,STI
-
TF ( Trap ):CPU是否单步调试操作(自陷模式)
执行一条指令,暂停显示该条指令执行结果 当TF=1,单步调试 当TF=0,连续执行 特定的执行模式设置
3. 物理地址的生成过程
- 物理地址 Physical Address
在存储器里以字节为单位存储信息,为正确地存放或取得信息,每一个字节单元给以一个唯一的存储器地址,称为物理地址,又叫实际地址或绝对地址
注意:8086的物理地址是20bit
只有对应CPU操作时才涉及物理地址
- 逻辑地址
逻辑上的相对位置关系
8086地址映射:物理地址 = ( 段基址寄存器 )×16 + 偏移地址
通过地址寄存器的数值,可以得出真实的物理地址,这种称为实模式
注意:单独的地址寄存器都是逻辑地址
- 存储器逻辑分段示意
-
每段存储区的范围
注意:空间范围由偏移地址决定,216=64K
-
各段存储区可以折叠
注意:在后续的CPU型号,增加了保护模式
分段优点:有利于程序和数据的分离,允许程序在存储器内重定位
4. 习题
- 在 80x86 微机的输入/输出指令中,I/O 端口号通常是由 DX 寄存器提供的,但有时也可以在指令中直接指定 00~FFH 的端口号。试问可直接由指令指定的 I/O 端口数。
- 答:可直接由指令指定的 I/O 端口数为 256 个。
- 有两个 16 位字 1EE5H 和 2A3CH 分别存放在 80x86 微机的存储器的000B0H 和 000B3H 单元中,请用图表示出它们在存储器里的存放情况。
- 答:存储器里的存放情况如下图所示。
- 在 IBM PC 机的存储器中存放信息如下图所示。试读出 30022H 和30024H 字节单元的内容,以及 30021H 和 30022H 字单元的内容。
- 答:30022H 字节单元的内容为 ABH;30024H 字节单元的内容为 EFH。30021H 字单元的内容为 AB34H;30022H 字单元的内容为 CDABH。
- 在实模式下,段地址和偏移地址为 3017:000A 的存储单元的物理地址是什么?如果段地址和偏移地址是 3015:002A 和 3010:007A 呢?
- 答:3017:000A、3015:002A 和 3010:007A 的存储单元的物理地址都是3017AH。
- 如果在一个程序开始执行以前(CS)=0A7F0H,(如 16 进制数的最高位为字母,则应在其前加一个 0) (IP)=2B40H,试问该程序的第一个字的物理地址是多少?
- 答:该程序的第一个字的物理地址是 0AAA40H。
- 在实模式下,存储器中每一段最多可有 10000H 个字节。如果用调试程序 DEBUG 的 r 命令在终端上显示出当前各寄存器的内容如下,请画出此时存储器分段的示意图,以及条件标志 OF、SF、ZF、CF 的值。
C>debug
-r
AX=0000 BX=0000 CX=0079 DX=0000 SP=FFEE BP=0000
SI=0000 DI=0000 DS=10E4 ES=10F4 SS=21F0 CS=31FF
IP=0100 NV UP DI PL NZ NA PO NC
- 答:此时存储器分段的示意图如上图所示。OF、SF、ZF、CF 的值都为 0。
- 下列操作可使用那些寄存器?
(1) 加法和减法 数据寄存器等
(2) 循环计数 CX
(3) 乘法和除法 AX、DX,乘数和除数用其他寄存器或存储器
(4) 保存段地址 段寄存器
(5) 表示运算结果为 0 ZF=1
(6) 将要执行的指令地址 CS:IP
(7) 将要从堆栈取出数据的地址 SS:SP
- 答:答案见题目的右边。
- 那些寄存器可以用来指示存储器地址?
- 答:BX、BP、SI、DI、堆栈操作时的 SP、对应的段地址、386 及其后继机型的 Exx。
- 请将下列左边的项和右边的解释联系起来(把所选字母放在括号中):
(1) CPU (M) A.保存当前栈顶地址的寄存器。
(2) 存储器 © B.指示下一条要执行的指令的地址。
(3) 堆栈 (D) C.存储程序、数据等信息的记忆装置,微机有 RAM 和ROM 两种。
(4) IP (B) D.以后进先出方式工作的存储空间。
(5) SP (A) E.把汇编语言程序翻译成机器语言程序的系统程序。
(6) 状态标志 (L) F.唯一代表存储空间中每个字节单元的地址。
(7) 控制标志 (K) G.能被计算机直接识别的语言。
(8) 段寄存器 (J) H.用指令的助记符、符号地址、标号等符号书写程序的语言。
(9) 物理地址 (F) I.把若干个模块连接起来成为可执行文件的系统程序。
(10) 汇编语言 (H) J.保存各逻辑段的起始地址的寄存器,8086/8088 机有四个:CS、DS、SS、ES。
(11) 机器语言 (G) K.控制操作的标志,如 DF 位。
(12) 汇编程序 (E) L.记录指令操作结果的标志,共 6 位:OF、SF、ZF、AF、PF、CF。
(13) 连接程序 (I) M.分析、控制并执行指令的部件,由算术逻辑部件 ALU 和寄存器等组成。
(14) 指令 (O) N.由汇编程序在汇编过程中执行的指令。
(15) 伪指令 (N) O.告诉 CPU 要执行的操作(一般还要指出操作数地址),在程序运行时执行。
- 答:答案见题目的括号中。