好文档 - 专业文书写作范文服务资料分享网站

(完整word版)微机原理与接口技术汇编语言指令详解吐血版,推荐文档

天下 分享 时间: 加入收藏 我要投稿 点赞

第一讲

第三章 指令系统--寻址方式

回顾: 8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过

程。

重点和纲要:指令系统--寻址方式。有关寻址的概念;6种基本的寻址方式及

有效地址的计算。

教学方法、实施步骤 回 顾 讲 授 提 问 小 结 时间分配 5”×2 40” ×2 3” ×2 2” ×2 教学手段 板书 计算机 投影仪 多媒体课件等

讲授内容:

3.1 8086/8088寻址方式

首先,简单讲述一下指令的一般格式:

操作码 操作数 …… 操作数 计算机中的指令由操作码字段和操作数字段组成。

操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。 操作数:指在指令执行操作的过程中所需要的操作数。该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的指针或其它有关操作数的信息。

寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数有效地址的方法。8086/8088的基本寻址方式有六种。 1.立即寻址

所提供的操作数直接包含在指令中。它紧跟在操作码的后面,与操作码一起放在代码段区域中。如图所示。

例如:MOV AX,3000H

1

立即数可以是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+3000H

3.寄存器寻址

操作数包含在CPU的内部寄存器中,如寄存器AX、BX、CX、DX等。 例如:MOV DS,AX MOV AL,BH 4.寄存器间接寻址

操作数是在存储器中,但是,操作数地址的16位偏移量包含在以下四个寄

2

存器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位偏移量(当然要以一个段寄存器作为地址基准)作为操作

3

数的偏移地址,如图所示。

操作数在存贮器中,其偏移地址由(基址寄存器)+(变址寄存器)+相对偏移量形成

基址寄存器――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 段寄存器使用的基本约定

访问存储器类型 取指令码 堆栈操作 串操作源地址 串操作目的地址 BP用作基址寄存器 一般数据存取 默认段寄存器 CS SS DS ES SS DS 可指定段寄存器 无 无 CS、ES、SS 无 CS、DS、ES CS、ES、SS 段内偏移地址来源 IP SP SI DI 根据寻址方式求得有效地址 根据寻址方式求得有效地址

习题与思考:

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],100

2.已知SS=0FFA0H,SP=00B0H,先执行两条把8057H和0F79H分别进栈的PUSH指令,再执行一条POP指令,试画出堆栈区和SP内容变化的过程示意图。(标出存储单元的地址)

4

第二讲

3.2 指令系统--数据传输、算术运算

回顾:8086/8088的内部结构和寄存器,8086/8088的工作过程。

8086/8088的寻址方式及操作数地址的计算。

重点和纲要:要求学生了解指令的功能,掌握数据传送类,算术运算类指令的使用方法。(掌握指令内涵,会用)

回 顾 讲 授 提 问 小 结

时间分配 5”×2 40” ×2 3” ×2 2” ×2 教学手段 板书 计算机 投影仪 多媒体课件等 教学方法、实施步骤

讲授内容:

3.2 8086/8088 指令系统

8086/8088的指令系统可以分为以下六个功能组。

1.数据传送(Data Transter) 2.算术运算(Arithmetic) 3.逻辑运算(Logic) 4.串操作(String menipulation) 5.程序控制(Program Control) 6.处理器控制(Processor Control)

一、数据传送指令

主要介绍 MOV,XCHG、堆栈和地址传送指令。

5

(完整word版)微机原理与接口技术汇编语言指令详解吐血版,推荐文档

第一讲第三章指令系统--寻址方式回顾:8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过程。重点和纲要:指令系统--寻址方式。有关寻址的概念;6种基本的寻址方式及有效地址的计算。教学方法、实施步骤回顾讲授提问小结时间分配
推荐度:
点击下载文档文档为doc格式
3z0r88qm6f3qhtz4wh2h1h1yk7phhy00sku
领取福利

微信扫码领取福利

微信扫码分享