第01章_80X86微处理器体系结构2.ppt

上传人:椰子壳 文档编号:5030091 上传时间:2020-01-29 格式:PPT 页数:51 大小:1.14MB
返回 下载 相关 举报
第01章_80X86微处理器体系结构2.ppt_第1页
第1页 / 共51页
第01章_80X86微处理器体系结构2.ppt_第2页
第2页 / 共51页
第01章_80X86微处理器体系结构2.ppt_第3页
第3页 / 共51页
第01章_80X86微处理器体系结构2.ppt_第4页
第4页 / 共51页
第01章_80X86微处理器体系结构2.ppt_第5页
第5页 / 共51页
点击查看更多>>
资源描述

《第01章_80X86微处理器体系结构2.ppt》由会员分享,可在线阅读,更多相关《第01章_80X86微处理器体系结构2.ppt(51页珍藏版)》请在三一文库上搜索。

1、程序是指令的有序集合,指令是程序的组成元素,通常一条指令对应着一种基本操作。一台计算机能执行什么样的操作,能做多少种操作,是由该计算机的指令系统决定的。一台计算机的指令集合,就是该计算机的指令系统。每种计算机都有自己固有的指令系统,互不兼容。但是,同一系列的计算机其指令系统是向上兼容的。,1.8 8088/8086指令系统,1.8指令系统,第2章:2.2 8088/8086的寻址方式,从8088/8086的指令格式入手,论述: 立即数寻址方式 寄存器寻址方式 存储器寻址方式 进而熟悉8088/8086汇编语言指令格式,尤其是其中操作数的表达方法 为展开8088/8086指令系统做好准备,指令的

2、组成,操作码说明计算机要执行哪种操作,如传送、运算、移位、跳转等操作,它是指令中不可缺少的组成部分 操作数是指令执行的参与者,即各种操作的对象 有些指令不需要操作数,通常的指令都有一个或两个操作数,也有个别指令有3个甚至4个操作数,指令由操作码和操作数两部分组成,指令的助记符格式,操作数2,常被称为源操作数src,它表示参与指令操作的一个对象 操作数1,成被称为目的操作数dest,它不仅可以作为指令操作的一个对象,还可以用来存放指令操作的结果 分号后的内容是对指令的解释,操作码 操作数1,操作数2 ;注释,汇编语句格式,指令的操作码和操作数,每种指令的操作码: 用一个助记符表示(指令功能的英文

3、缩写) 对应着机器指令的一个或多个二进制编码 指令中的操作数: 可以是一个具体的数值 可以是存放数据的寄存器 或指明数据在主存位置的存储器地址,操作数的寻址方式,指令系统设计了多种操作数的来源 寻找操作数的过程就是操作数的寻址 把寻找操作数的方式叫做(操作数)寻址方式 理解操作数的寻址方式是理解指令功能的前提 操作数采取哪一种寻址方式 一方面,会影响处理器执行指令的速度和效率 另一方面,对程序设计也很重要,MOV指令,8088/8086 CPU的寻址方式,寻找和获得操作数、操作数存放地址或指令转移地址的方法称为寻址方式。8088/8086 CPU的寻址分为两类,即数据寻址和指令寻址。 机器执行

4、指令的目的就是对指定的操作数完成规定的操作,将操作结果存入规定的地方。因此,如何获得操作数的存放地址及操作结果的存放地址就是一个很关键的问题。8088/8086 CPU有多种方法来获取操作数的存放地址及操作结果的存放地址,这些方法统称为数据寻址方式。,寻址方式,操作数及操作结果存放的地点有三处: 存放在指令的地址码字段中:立即操作数 存放在寄存器中:寄存器操作数 存放在存储器的数据段、堆栈段或附加数据段中:存储器操作数 寻找这些操作数有三种基本寻址方式: 立即寻址方式 寄存器寻址方式 存储器寻址方式,又包括多种寻址方式,操作数的表达符号(1),操作数的表达符号(2),一、立即数寻址方式,指令中

5、的操作数直接存放在机器代码中,紧跟在操作码之后(操作数作为指令的一部分存放在操作码之后的主存单元中) 这种操作数被称为立即数imm 可以是8位数值i8(00HFFH) 也可以是16位数值i16(0000HFFFFH) 立即数寻址方式常用来给寄存器和存储单元赋值,多以常量形式出现,演示,MOV AX, 0102H ;AX0102H,【例】 MOV AL,0FFH,【例】 MOV AX,1234H,二、 寄存器寻址方式,操作数存放在CPU的内部寄存器reg中: 8位寄存器r8: AH、AL、BH、BL、CH、CL、DH、DL 16位寄存器r16: AX、BX、CX、DX、SI、DI、BP、SP 4

6、个段寄存器seg: CS、DS、SS、ES 寄存器名表示其内容(操作数),演示,MOV AX, BX ;AXBX,三、 存储器寻址方式,操作数在主存储器中,用主存地址表示 程序设计时,8088采用逻辑地址表示主存地址 段地址在默认的或用段超越前缀指定的段寄存器中 指令中只需给出操作数的偏移地址(有效地址EA) 8086设计了多种存储器寻址方式 1、直接寻址方式 2、寄存器间接寻址方式 3、寄存器相对寻址方式 4、基址变址寻址方式 5、相对基址变址寻址方式,1. 直接寻址方式,直接寻址方式的有效地址在指令中直接给出 默认的段地址在DS段寄存器,可使用段超越前缀改变 用中括号包含有效地址,表达存储

7、单元的内容,演示,MOV AX, 2000H ;AXDS:2000H,MOV AX, ES: 2000H ;AXES:2000H,2. 寄存器间接寻址方式,有效地址存放在基址寄存器BX或变址寄存器SI、DI中 默认的段地址在DS段寄存器,可使用段超越前缀改变,演示,MOV AX, BX ;AXDS:BX,【例】 MOV AX,BX (DS)=3000H,(BX)=1010H,(31010H)=12H,011H)=24H 则操作数的20位物理地址=30000H+1010H=31010H。 指令执行完以后,(AX)=2412H。,3. 寄存器相对寻址方式,有效地址是寄存器内容与有符号8位或16位位

8、移量之和,寄存器可以是BX、BP或SI、DI 有效地址BX/BP/SI/DI8/16位位移量 段地址对应BX/SI/DI寄存器默认是DS,对应BP寄存器默认是SS;可用段超越前缀改变,演示,MOV AX, SI+06H ;AXDS:SI+06H,MOV AX, 06HSI ;AXDS:SI+06H,4. 基址变址寻址方式,有效地址由基址寄存器(BX或BP)的内容加上变址寄存器(SI或DI)的内容构成: 有效地址BX/BPSI/DI 段地址对应BX基址寄存器默认是DS,对应BP基址寄存器默认是SS;可用段超越前缀改变,演示,MOV AX, BX+SI ;AXDS:BX+SI,MOV AX, BX

9、SI ;AXDS:BX+SI,【例】 MOV AX,BX SI(或写为MOV AX,BX+SI) (DS)=2000H,(BX)=0500H,(SI)=0010H 则 偏移地址=0500H+0010H=0510H 20位物理地址=20000H+0510H =20510H 如(20510H)=12H,(20511H)=34H,5. 相对基址变址寻址方式,有效地址是基址寄存器(BX/BP)、变址寄存器(SI/DI)与一个8位或16位位移量之和: 有效地址BX/BPSI/DI8/16位位移量 段地址对应BX基址寄存器默认是DS,对应BP基址寄存器默认是SS;可用段超越前缀改变,演示,MOV AX,

10、BX+DI+6 ;AXDS:BX+DI+6,MOV AX, 6BX+DI,MOV AX, 6BXDI,【例】TABLE是数据段中定义的一个符号地址,假设它在数据段中的偏移地址是1000H。,MOV AX,TABLEBXDI (DS)=2000H,(BX)=0100H,(DI)=0020H,则偏移地址=1000H +0100H+0020H=1120H,20位物理地址=20000H+1120H=21120H 如(21120H)=12H,(21121H)=34H 执行完指令以后,(AX)=3412H,存储器寻址方式中的变量,变量指示内存中的数据,变量名具有地址属性。存储器寻找方式中经常采用变量形式

11、变量的定义 WVAR DW 1234H ;定义16位变量WVAR,具有初值1234H ;假设其偏移地址为10H 单独引用变量名是直接寻址方式 MOV AX,WVAR ;指令功能:AX1234H ;等同于 MOV AX,0010H 相对寻址方式中,变量名表示其偏移地址,相当于位移量 MOV AX, DI+WVAR ; MOV AX,WVARDI ;等同于 MOV AX,DI+0010H,相对寻址方式中的位移量,在寄存器相对和相对基址变址寻址方式中,其位移量不仅可用常量表示,也可用符号表示 这个符号可以是变量名,例如WVAR变量,而且支持多种表达形式 MOV AX, DI+WVAR ; ;等同于

12、MOV AX, WVARDI MOV AX,BX+SI+WVAR ;等同于 MOV AX, SI+WVAR ;等同于 MOV AX, WVARBX+SI ;等同于 MOV AX, WVARBXSI,这类指令都仅限于I/O端口或存储单元与累加器AL(AX)之间传送数据。具体包括IN输入指令、OUT输出指令和XLAT换码指令。 1、 IN输入指令 汇编格式:IN AL,I/O口地址表达式 或 IN AX,I/O口地址表达式) 执行的操作: AL(I/O口地址表达式) 或 AX(I/O口地址表达式+1),(I/O口地址表达式),四、累加器专业传送指令,说明: 该指令的目的操作数仅限于累加器,即8位操

13、作采用AL,16位操作采用AX,不能由其他任何寄存器代替。 如果I/O寻址的口地址号在8位以内,可以用直接寻址方式,地址表达式则由一个8位立即数表示(长格式) ;如果I/O寻址的口地址号在16位以内,可以用寄存器间接寻址方式,所寻址的地址口号则装入DX,间接寻址仅可以使用DX (短格式)。,2、 OUT输出指令 汇编格式: OUT 地址表达式,AL 或 OUT 地址表达式,AX 执行的操作: I/O口地址(AL) 或 (I/O口地址+1),(I/O口地址)(AX) 说明:同1。,3、 长格式 IN AL,0E0H OUT 0E0H,AL 4、 短格式 MOV DX,200H IN AL,DX

14、OUT DX,AL,输入输出指令,输入指令(IN:将外设数据传送给CPU内的AL/AX) IN AL,i8 ;字节输入 IN AL,DX ;字节输入 IN AX,i8 ;字输入 IN AX,DX ;字输入 输出指令(OUT:将CPU内的AL/AX数据传送给外设) OUT i8,AL ;字节输出 OUT DX,AL ;字节输出 OUT i8,AX ;字输出 OUT DX,AX ;字输出,演示,演示,I/O端口,8088只能通过输入输出指令与外设进行数据交换;呈现给程序员的外设是端口(Port),即I/O地址 8086用于寻址外设端口的地址线为16条,端口最多为21665536(64K)个,端口号

15、为0000H FFFFH 每个端口用于传送一个字节的外设数据,I/O寻址方式,8088/8086的端口有64K个,无需分段,设计有两种寻址方式 直接寻址:只用于寻址00H FFH前256个端口,操作数i8表示端口号 间接寻址:可用于寻址全部64K个端口,DX寄存器的值就是端口号 对大于FFH的端口只能采用间接寻址方式,数据交换方式,如果输入输出一个字节,利用AL寄存器 如果输入输出一个字,利用AX寄存器 输入一个字,实际上是从连续两个端口输入两个字节,分别送AL(对应低地址端口)和AH(对应高地址端口) 输出一个字,实际上是将AL(对应低地址端口)和AH(对应高地址端口)两个字节的内容输出给连

16、续两个端口,IN指令实例(从20H端口输入一个字),;方法1:直接寻址,字量输入 in ax,20h ;方法2:间接寻址,字量输入 mov dx,20h in ax,dx,;方法3:直接寻址,字节量输入 in al,21h mov ah,al in al,20h ;方法4:间接寻址,字节量输入 mov dx,21h in al,dx mov ah,al dec dx in al,dx,OUT指令实例(向300H端口输出一个字节),;唯一的方法:间接寻址,字节量输出 mov al,bvar ;bvar是字节变量 mov dx,300h out dx,al,问 题,习 题 2,1.1 试述微处理器

17、的发展历史。 1.2 8086微处理器由哪几部分组成?各部分的功能是什么? 1.3 简述8086 CPU的寄存器组织。 1.4 试述8086 CPU标志寄存器各位的含义与作用。 1.5 8086中,存储器为什么采用分段管理? 1.6 什么是逻辑地址?什么是物理地址?如何由逻辑地址计算物理地址?,1.7 8086中,CPU实际利用哪几条地址线来访问I/O端口?最多能访问多少个端口? 1.8 80x86微处理器的指令队列的作用是什么? 1.9 80486中,什么是描述符?描述符表寄存器有什么作用? 1.10 80486如何实现段页式存储器管理? 1.11 什么是微处理器超标量体系结构?,课间休息,汇编语言的两种语句格式,执行性语句执行性语句用于表达处理器指令(也称为硬指令),汇编后对应一条指令代码。由处理器指令组成的代码序列是程序设计的主体 标号: 硬指令助记符 操作数,操作数 ;注释 说明性语句说明性语句用于表达伪指令,指示源程序如何汇编、变量怎样定义、过程怎么设置等 名字 伪指令助记符 参数,参数, ;注释,MOV指令的功能,立即数寻址方式,寄存器寻址方式,直接寻址方式,间接寻址方式,相对寻址方式,基址变址寻址方式,相对基址变址寻址方式,IN AL, 21H,返回,OUT 43H, AL,返回,下 课,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 研究报告 > 商业贸易


经营许可证编号:宁ICP备18001539号-1