汇编语言(二)-80x86的计算机组织


)

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

  1. 通用寄存器
    功能:存放数据
  • AX(AH,AL):累加器(乘积低位),I/O数据**
  • BX(BH,BL):基地址寄存器
  • CX(CH,CL):循环或串操作计数器
  • DX(DH,DL):乘除法专用(乘积高位),I/O端口地址
    在这里插入图片描述
  1. 段基址寄存器
    功能:存放基地址
  • CS:代码段

  • DS:数据段

  • ES:附加段

  • SS:堆栈段

     基址寻址
     EA=(BR(起始地址))+偏移地址
    

分段的目的:存储区域的分配控制
在这里插入图片描述
位于BIU(总线接口单元)
注意:基址寄存器的内容不要随意变动

在这里插入图片描述

  1. 指针寄存器(Pointer)
    功能:存放段内偏移地址
  • IP 指令指针( Instruction )

    下一条要执行指令地址(注意和原理PC的区别)
    代码段的偏移地址 CS : IP
    
  • SP 堆栈指针( Stack )

    栈顶偏移地址
    堆栈段的偏移地址 SS : SP
    
  • BP 基址指针( Base )

    栈内偏移地址
    堆栈段的偏移地址 SS : BP
    
  1. 变址寄存器(Index)
    功能:存放数据的偏移地址(注意可以不在数据段
  • SI 源变址( Source )
  • DI 目的变址( Destination )
    均可以和DS联用 — DS : SI DS : DI
    串操作时DI和ES联用 — DS : SI ES : DI
    在这里插入图片描述
  1. 程序状态字(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. 物理地址的生成过程

  1. 物理地址 Physical Address
    在存储器里以字节为单位存储信息,为正确地存放或取得信息,每一个字节单元给以一个唯一的存储器地址,称为物理地址,又叫实际地址绝对地址

注意:8086的物理地址是20bit
只有对应CPU操作时才涉及物理地址
在这里插入图片描述

  1. 逻辑地址
    逻辑上的相对位置关系

8086地址映射:物理地址 = ( 段基址寄存器 )×16 + 偏移地址
在这里插入图片描述
通过地址寄存器的数值,可以得出真实的物理地址,这种称为实模式
注意:单独的地址寄存器都是逻辑地址
在这里插入图片描述

  1. 存储器逻辑分段示意
  • 每段存储区的范围
    注意:空间范围由偏移地址决定,216=64K
    在这里插入图片描述

  • 各段存储区可以折叠
    注意:在后续的CPU型号,增加了保护模式
    分段优点:有利于程序和数据的分离,允许程序在存储器内重定位
    在这里插入图片描述

4. 习题

  1. 在 80x86 微机的输入/输出指令中,I/O 端口号通常是由 DX 寄存器提供的,但有时也可以在指令中直接指定 00~FFH 的端口号。试问可直接由指令指定的 I/O 端口数。
  • 答:可直接由指令指定的 I/O 端口数为 256 个。
  1. 有两个 16 位字 1EE5H 和 2A3CH 分别存放在 80x86 微机的存储器的000B0H 和 000B3H 单元中,请用图表示出它们在存储器里的存放情况。
  • 答:存储器里的存放情况如下图所示。在这里插入图片描述
  1. 在 IBM PC 机的存储器中存放信息如下图所示。试读出 30022H 和30024H 字节单元的内容,以及 30021H 和 30022H 字单元的内容。
    在这里插入图片描述
  • 答:30022H 字节单元的内容为 ABH;30024H 字节单元的内容为 EFH。30021H 字单元的内容为 AB34H;30022H 字单元的内容为 CDABH。
  1. 在实模式下,段地址和偏移地址为 3017:000A 的存储单元的物理地址是什么?如果段地址和偏移地址是 3015:002A 和 3010:007A 呢?
  • 答:3017:000A、3015:002A 和 3010:007A 的存储单元的物理地址都是3017AH。
  1. 如果在一个程序开始执行以前(CS)=0A7F0H,(如 16 进制数的最高位为字母,则应在其前加一个 0) (IP)=2B40H,试问该程序的第一个字的物理地址是多少?
  • 答:该程序的第一个字的物理地址是 0AAA40H。
  1. 在实模式下,存储器中每一段最多可有 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. 下列操作可使用那些寄存器?
    (1) 加法和减法 数据寄存器等
    (2) 循环计数 CX
    (3) 乘法和除法 AX、DX,乘数和除数用其他寄存器或存储器
    (4) 保存段地址 段寄存器
    (5) 表示运算结果为 0 ZF=1
    (6) 将要执行的指令地址 CS:IP
    (7) 将要从堆栈取出数据的地址 SS:SP
  • 答:答案见题目的右边。
  1. 那些寄存器可以用来指示存储器地址?
  • 答:BX、BP、SI、DI、堆栈操作时的 SP、对应的段地址、386 及其后继机型的 Exx。
  1. 请将下列左边的项和右边的解释联系起来(把所选字母放在括号中):
    (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 要执行的操作(一般还要指出操作数地址),在程序运行时执行。
  • 答:答案见题目的括号中。
  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值