微机学习:第九课

指令系统
1、计算机的编程结构:
①寄存器;②存储器;③输入/输出端口
2、操作数的寻址方式:
①立即寻址和寄存器寻址;
②输入/输出端口寻址;
③关于地址的寻址
3、Pentium的指令系统
①传送指令
②算术运算指令
③逻辑运算和位操作指令
④串操作指令及其重复前缀
⑤控制类指令

指令
指令格式:操作码+操作数(地址码)
操作数只有一个的指令叫做单操作数指令,有两个就叫做双操作数指令,双操作数指令的双操作数为源操作数和目的操作数。
操作数是参与运算或加工处理的数据,所以操作数存放在:
①寄存器
②存储器(包括堆栈)
③指令区(代码区)(立即数)

如下图所示:
微机学习:第九课_第1张图片

双操作数指令:目的操作数在前,源操作数在后。操作数一定会是寄存器或存储器,只有源操作数才可能是立即数。

立即寻址:

操作数直接存放在指令中,紧跟在操作码之后的寻址方式就是立即数寻址方式,如:
MOV AL,80H

寄存器寻址
把在指令中指出所使用寄存器的寻址方式即为寄存器寻址方式。指令所要的操作数已存储在某寄存器中,或把目的操作数存入寄存器。
计算机的编程结构中通用寄存器都可以用于寄存器寻址。例如:
INC CX(CX中的内容加1)

输入/输出端口寻址:
8086微处理器采用独立编址的I/O端口,有专门的输入指令IN和输出指令OUT,寻址方式有直接寻址和间接寻址两种。
I/O端口直接寻址:IN中输入端口变址为源操作数,OUT中输出端口地址为目的操作数,寻址范围为0-255(8字节)。例:
IN AL,50H(50H端口的字节读入AL)

在判断指令的意思的时候,要先看操作指令时IN还是OUT,如果是IN,那么我们就要关注输入;如果是OUT,我们就要关注输出。
例如:
1、OUT 80H,AX
解析:操作指令为OUT,我们的端口都是8字节的,这里的端口是80H,但是我们的源操作数AX存储的内容确是16字节的,因此光一个端口无法放入。还需要增加一个端口,且需要满足低字节对应低端口号,高字节对应高端口号。
答案:AX的内容输出到80H、81H两个端口(低对低、高对高)
2、IN EAX,60H
不做解析,答案为:
60H、61H、62H、63H端口的4个字节由低到高依次输入到EAX中。

问题
1、OUT DX,AL:
答:将AL中的字节输出到DX所指的端口中
2、OUT DX,AX
答:将AL中的字节输出到DX所指的端口中,同时将AH中的字节输出到DX+1所指的端口中。

I/O端口间接寻址
定义:I/O端口地址由DX寄存器间接给出,即I/O端口地址放在中,DX在指令中以操作数的形式出现。
IN中DX以源操作数出现,OUT中以目的操作数出现。
若访问的端口地址大于255时,就要用间接寻址方式。可以访问的端口范围为0~65535

例题:OUT DX,EAX
EAX中的双字由低到高依次输出到DX、DX+1、DX+2、DX+3所指的4个端口中。

存储器寻址:
如果操作码所需操作数存放在内存储器中,则指令中需要给出操作数的地址信息。
当操作数是存放在存储器中时,存储器的存储单元的物理地址有两部分组成。一部分是段地址;一部分是偏移地址。
①直接寻址:
定义:操作数在存储器中,指令中直接给出操作数所在存储单元的有效地址。
例:MOV EAX,ES:DATA
ES段有效地址为DATA、DATA+1、DATA+2、DATA+3的4个字节由低到高依次传送到EAX中。
②间接寻址:
例1:MOV AX,[BX];(BX)=0001H,(0001H)=35H,(0002H)=00H
则:
微机学习:第九课_第2张图片
首先利用指令码寻找到BX的内容,其16进制表达为0001H,则对应数据段寄存器的位置上的数据传给AX
例2:MOV AX,[BP];(BP)=0001H,(0001H)=35H,(0002H)=00H
则:
微机学习:第九课_第3张图片
上面的两个例子,体现了寄存器的使用规则(BX和DS搭配,BP和SS搭配)

你可能感兴趣的:(微型计算机技术及应用,算法)