第一讲第三章 指令系统--寻址方式回顾: 8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过程。
重点和纲要:指令系统--寻址方式。
有关寻址的概念;6种基本的寻址方式及有效地址的计算。
教学方法、实施步骤时间分配 教学手段 回 顾 5”×2 板书 计算机 投影仪 多媒体课件等讲 授 40” ×2 提 问 3” ×2 小 结2” ×2讲授内容:3.1 8086/8088寻址方式首先,简单讲述一下指令的一般格式:操作码 操作数 …… 操作数计算机中的指令由操作码字段和操作数字段组成。
操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。
操作数:指在指令执行操作的过程中所需要的操作数。
该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的指针或其它有关操作数的信息。
寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数有效地址的方法。
8086/8088的基本寻址方式有六种。
1.立即寻址所提供的操作数直接包含在指令中。
它紧跟在操作码的后面,与操作码一起放在代码段区域中。
如图所示。
例如:MOV AX ,3000H立即数可以是8位的,也可以是16位的。
若是16位的,则存储时低位在前,高位在后。
立即寻址主要用来给寄存器或存储器赋初值。
2.直接寻址操作数地址的16位偏移量直接包含在指令中。
它与操作码—起存放在代码段区域,操作数一般在数据段区域中,它的地址为数据段寄存器DS加上这16位地址偏移量。
如图2-2所示。
例如: MOV AX,DS:[2000H];图2-2(对DS来讲可以省略成 MOV AX,[2000H],系统默认为数据段)这种寻址方法是以数据段的地址为基础,可在多达64KB的范围内寻找操作数。
8086/8088中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为基准的区域中。
此时只要在指令中指明是段超越的,则16位地址偏移量可以与CS或SS或ES相加,作为操作数的地址。
MOV AX,[2000H] ;数据段MOV BX,ES:[3000H] ;段超越,操作数在附加段即绝对地址=(ES)*16+3000H3.寄存器寻址操作数包含在CPU的内部寄存器中,如寄存器AX、BX、CX、DX等。
例如:MOV DS,AXMOV AL,BH4.寄存器间接寻址操作数是在存储器中,但是,操作数地址的16位偏移量包含在以下四个寄存器SI、DI、BP、BX之一中。
可以分成两种情况:(1)以SI、DI、BX间接寻址,则通常操作数在现行数据段区域中,即数据段寄存器(DS)*16加上SI、DI、BX中的16位偏移量,为操作数的地址,例如: MOV AX, [SI] 操作数地址是:(DS)*16+(SI)(2)以寄存器BP间接寻址,则操作数在堆栈段区域中。
即堆栈段寄存器(SS)*16与BP的内容相加作为操作数的地址,例如:MOV AX,[BP] 操作数地址是:(SS)*16+(BP)若在指令中规定是段超越的,则BP的内容也可以与其它的段寄存器相加,形成操作数地址。
例如: MOV AX,DS:[BP] 操作数地址是:(DS)*16+(BP)5.变址寻址由指定的寄存器内容,加上指令中给出的8位或16位偏移量(当然要由一个段寄存器作为地址基准)作为操作数的偏移地址。
(操作数在存贮器中)可以作为寄存器变址寻址的四个寄存器是SI、DI、BX、BP。
⑴若用SI、DI和BX作为变址,则与数据段寄存器相加,形成操作数的地址即默认在数据段;⑵若用BP变址,则与堆栈段寄存器相加,形成操作数的地址即默认在堆栈段例如: MOV AX,COUNT[SI];操作数地址是:(DS)*16+(SI)+COUNT但是,只要在指令中指定是段超越的,则可以用别的段寄存器作为地址基准。
6.基址加变址寻址把BX和BP看成是基址寄存器,把SI、DI看着是变址寄存器,把一个基址寄存器(BX或BP)的内容加上一个变址寄存器(SI或DI)的内容,再加上指令中指定的8位或16位偏移量(当然要以一个段寄存器作为地址基准)作为操作数的偏移地址,如图所示。
操作数在存贮器中,其偏移地址由(基址寄存器)+(变址寄存器)+相对偏移量形成基址寄存器――BX:数据段、BP:堆栈段;变址寄存器――SI、DI。
例如:MOV AX,[BX][SI] 或 MOV AX,[BX+SI]也可放置一个相对偏移量,如COUNT 、MASK等等,用于表示相对寻址。
MOV AX,MASK[BX][SI]MOV BH,COUNT[DI][BP];MOV BH,COUNT[BP+DI]✧若用BX作为基地址,则操作数在数据段区域✧若用BP作为基地址,则操作数在堆栈段区域但若在指令中规定段是超越的,则可用其它段寄存器作为地址基准。
P.28 表2-1 段寄存器使用的基本约定习题与思考:1.假定DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,数据变量VAL 的偏移地址为0050H,请指出下列指令源操作数是什么寻址方式?其物理地址是多少?(1)MOV AX,0ABH (2)MOV AX,[100H](3)MOV AX,VAL (4)MOV BX,[SI](5)MOV AL,VAL[BX] (6)MOV CL,[BX][SI](7)MOV VAL[SI],BX (8)MOV [BP][SI],1002.已知SS=0FFA0H,SP=00B0H,先执行两条把8057H和0F79H分别进栈的PUSH指令,再执行一条POP指令,试画出堆栈区和SP内容变化的过程示意图。
(标出存储单元的地址)第二讲3.2 指令系统--数据传输、算术运算回顾:8086/8088的内部结构和寄存器,8086/8088的工作过程。
8086/8088的寻址方式及操作数地址的计算。
重点和纲要:要求学生了解指令的功能,掌握数据传送类,算术运算类指令的使用方法。
(掌握指令内涵,会用)讲授内容:3.2 8086/8088 指令系统8086/8088的指令系统可以分为以下六个功能组。
1.数据传送(Data Transter) 2.算术运算(Arithmetic)3.逻辑运算(Logic) 4.串操作(String menipulation)5.程序控制(Program Control) 6.处理器控制(Processor Control)一、数据传送指令主要介绍 MOV,XCHG、堆栈和地址传送指令。
1.数据传送MOV指令一般格式:MOV OPRD1,OPRD2MOV 是操作码,OPRD1和OPRD2分别是目的操作数和源操作数。
功能:完成数据传送具体来说,一条数据传送指令能实现:⑴CPU内部寄存器之间数据的任意传送(除了代码段寄存器CS和指令指针IP以外)。
MOV AL,BL;字节传送MOV CX,BX;字传送MOV DS,BX⑵立即数传送至CPU内部的通用寄存器组(即AX、 BX、CX、DX、BP、SP、SI、DI),MOV CL,4MOV AX,03FFHMOV SI,057BH⑶CPU内部寄存器(除了CS和IP以外)与存储器(所有寻址方式)之间的数据传送。
MOV AL,BUFFERMOV AX,[SI]MOV [DI],CXMOV SI,BLOCK[BP]MOV DS,DATA[SI+BX]MOV DEST[BP+DI],ES⑷能实现用立即数给存储单元赋值例如:MOV [2000H],25HMOV [SI],35H对于MOV 指令应注意几个问题:①存储器传送指令中,不允许对CS和IP进行操作;②两个操作数中,除立即寻址之外必须有一个为寄存器寻址方式,即两个存储器操作数之间不允许直接进行信息传送;如我们需要把地址(即段内的地址偏移量)为AREAl的存储单元的内容,传送至同一段内的地址为AREA2的存储单元中去,MOV指令不能直接完成这样的传送,但我们可以用CPU内部寄存器为桥梁来完成这样的传送:MOV AL,AREAlMOV AREA2,AL③两个段寄存器之间不能直接传送信息,也不允许用立即寻址方式为段寄存器赋初值;如:MOV AX,0;MOV DS,AX④目的操作数,不能用立即寻址方式。
2.堆栈指令(简述堆栈的概念及存取特点,如先进后出)包括入栈(PUSH)和出栈(POP)指令两类。
仅能进行字运算。
(操作数不能是立即数)⑴入栈指令PUSH一般格式:PUSH OPRD源操作数可以是CPU内部的16位通用寄存器、段寄存器(CS除外)和内存操作数(所有寻址方式)。
入栈操作对象必须是16位数。
功能:将数据压入堆栈执行步骤为:SP=SP-2;[SP]=操作数低8位;[SP+1]= 操作数高8位例如:PUSH BX执行过程为:SP=SP-1,[SP]=BH;SP=SP-1,[SP]=BL,如图2-8所示。
⑵出栈指令POP一般格式:POP OPRD功能:将数据弹出堆栈对指令执行的要求同入栈指令。
例如:POP AX 图2-8POP [BX]POP DS3.交换指令 XCHG一般格式:XCHG OPRD1,OPRD2功能:完成数据交换这是—条交换指令,把一个字节或一个字的源操作数与目的操作数相交换。
交换能在通用寄存器与累加器之间、通用寄存器之间、通用寄存器与存储器之间进行。
但段寄存器和立即数不能作为一个操作数,不能在累加器之间进行。
例如: XCHG AL,CLXCHG AX,DIXCHG BX,SIXCHG AX,BUFFERXCHG DATA[SI],DH4.累加器专用传送指令有三种,输入、输出和查表指令。
前两种又称为输入输出指令。
⑴ IN 指令一般格式:IN AL,n ; B AL←[n]IN AX,n ; W AX←[n+1][n]IN AL,DX ; B AL←[DX]IN AX,DX ; W AX←[DX+1][DX]功能:从I/O端口输入数据至AL或AX。
输入指令允许把一个字节或一个字由一个输入端口传送到AL或AX中。
若端口地址超过255时,则必须用DX保存端口地址,这样用DX作端口寻址最多可寻找64K个端口。
⑵ OUT 指令一般格式:OUT n,AL ; B AL→[n]OUT n,AX ; W AX→[n+1][n]OUT DX,AL ; B AL→[DX]OUT DX,AX ; W AX→[DX+1][DX]功能:将AL或AX的内容输出至I/O端口。
该指令将AL或AX中的内容传送到一个输出端口。
端口寻址方式与IN指令相同。
⑶ XLAT指令一般格式:XLAT ; AL=(DX)×16+(BX)+(AL))功能:完成一个字节的查表转换。