第十三章——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码表示个位。