王爽汇编语言第十三章——int指令 第十四章——端口

第十三章——int指令

1、int格式:int n,n为中断类型码。它的功能是引发中断过程。

2、Cpu执行int n指令,相当于引发一个n号中断的中断过程,执行过程如下:(1)取中断类型码n(2)标志寄存器入栈,IF=0,TF=0(3)CS、IP入栈(4)(IP)=(N*4),(CS)=(N*4+2)

从此处转去执行n号中断的中断处理程序

3、可以在程序中使用int指令调用任何一个中断的中断处理程序。

4、我们可以将中断处理程序简称为中断例程。

5、BIOS和DOS中断例程的安装过程:

开机后,cpu一加电,初始化(CS)=0FFFFH,(IP)=0,自动从FFFF:0单元开始执行程序。FFFF:0处有一条跳转指令,cpu执行该指令后,转去执行BIOS中的硬件系统检测和初始化程序。

初始化程序将建立BIOS所支持的中断向量,即将BIOS提供的中断例程的入口地址登记在中断向量表中。

硬件系统检测和初始化完成后,调用int 19h进行操作系统的引导。从此将计算机交由操作系统控制。

DOS启动后,除完成其他工作后,还将它所提供的中断例程装入内存,并建立相应的中断向量。

6、一般来说,一个供程序员调用的中断例程中往往包括多个子程序,中断例程内部用传递进来的参数来决定执行哪个子程序。

7、BIOS和DOS提供的中断例程,都用ah来传递内部子程序的编号。

8、Int 21h中断例程是DOS提供的中断例程,其中包含了DOS提供给程序员在编程时调用的子程序。我们从前一直使用的是int 21h中断例程的4ch号功能,即程序返回功能,如下:

mov ah,4ch ;程序返回

mov al,0 ;返回值

int 21h

(ah)=4ch表示调用第21h号中断例程的4ch号子程序,功能为程序返回,可以提供返回值作为参数。

第十四章——端口

1、cpu可以直接读写3个地方的数据:(1)cpu内部的寄存器(2)内存单元(3)端口

2、对端口的读写不能用mov、push、pop等内存读写指令,端口的读写指令只有两条,in和out分别用于从端口读取数据和往端口写入数据。

3、Cpu执行内存访问指令和端口访问指令的时候,总线上的信息:

访问内存:mov ax,ds:[8]

假设执行前(ds)=0,执行时,与总线相关的操作:

Cpu通过地址线将地址信息8发出

Cpu通过控制线发出内存读命令,选中存储器芯片,并通知它将要从中读取数据

存储器将8号单元中的数据通过数据线送入cpu

4、访问端口:in al,60h:从60h号端口读入一个字节

执行时与总线相关的操作:

Cpu通过地址线将地址信息60h发出

Cpu通过控制线发出端口读命令,选中端口所在的芯片,并通知它,将要从中读取数据

端口所在的芯片将60h端口中的数据通过数据线送入cpu

注:在in和out指令中,只能使用ax或al来存放从端口中读入的数据或要发送到端口中的数据。访问8位端口时用al,访问16位端口时用ax。

5、端口的读写:

对0~255以内的端口进行读写:

in al,20h ;从20h端口读入一个字节

out 20h,al ;往20h端口写入一个字节

对256~65535的端口进行读写时,端口号放在dx中:

mov dx,3f8h ;将端口号3f8送入dx

in al,dx ;从3f8h端口读入一个字节

out dx,al ;向3f8h端口写入一个字节

6、PC机中有一个CMOS RAM芯片,其有如下特征:

包含一个实时钟和一个有128个存储单元的RAM存储器(早期的计算机为64个字节)

该芯片靠电池供电。因此,关机后其内部的实时钟仍可正常工作,RAM中的信息不丢失。

128个字节的RAM中,内部实时钟占用0~0dh单元来保存时间信息,其余大部分单元用于保存系统配置信息,供系统启动时BIOS程序读取。BIOS也提供了相关的程序,使我们可以在开机的时候配置CMOS RAM中的系统信息。

该芯片内部有两个端口,端口地址为70h和71h。Cpu通过这两个端口读写CMOS RAM。

70h为地址端口,存放要访问的CMOS RAM单元的地址;71h为数据端口,存放从选定的CMOS RAM单元中读取的数据,或要写入到其中的数据。

可见,cpu对CMOS RAM的读写分两步进行,比如:读CMOS RAM的2号单元:(1)将2送入端口70h(2)从71h读出2号单元的内容

7、shl和shr是逻辑移位指令,shl是逻辑左移指令,功能为:(1)将一个寄存器或内存单元中的数据向左移位

(2)将最后移出的一位写入CF中(3)最低位用0补充

例如有如下指令:mov al,01001000b

shl al,1 ;将al中的数据左移一位

执行后,(al)=10010000b,CF=0

如果移动位数大于1时,必须将移动位数放在cl中。

比如指令:mov al,01010001b

mov cl,3 shl al,cl

执行后,(al)=10001000b,CF=0

shr逻辑右移指令:(1)将一个寄存器或内存单元中的数据向右移位(2)将最后移出的一位写入CF中(3)最高位用0补充。

8、在CMOS RAM中,存放着当前时间:

秒:00H 分:02H 时:04H 日:07H

月:08H 年:09H

这6个信息的长度都为1个字节。

这写数据以BCD码的方式存放:

数码: 0   1   2   3   4

BCD码:0000 0001 0010 0011 0100

数码:  5   6   7   8   9

BCD码:0101 0110 0111 1000 1001

所以26表示为:00100110

可见,一个字节可表示两个BCD码,则CMOS RAM存储时间信息的单元中,存储了用两个BCD码表示的两位十进制数,高4位BCD码表示十位,低4位的BCD码表示个位。

猜你喜欢

转载自blog.csdn.net/weixin_42617472/article/details/82883600