15 外中断

1、以前我们讨论的都是CPU对指令的执行。我们知道,CPU在计算机系统中,除了能够执行命令,进行计算意外,还应该能够对外部设备进行控制,接受他们的输入,向他们进行输出。也就是说,CPU除了有运算能力外,还要有I/O能力

要即使处理外设的输入,显然需要解决两个问题:

外设的输入随时可能发生,CPU如何得知

CPU从何处得到外设的输入

 

2、接口芯片和端口

第14章我们讲过,PC系统的接口卡和主板上,装有各种接口芯片。这些外设接口芯片的内部有若干寄存器,CPU将这些寄存器当作端口来访问

外设的输入部直接送入内存和CPU。而是送入相关的接口芯片的端口中;CPU向外设的输出也不是直接送入外设,而是先送入端口中,再由相关的芯片送到外设。CPU还可以向外设输出控制米嗯令,而这些控制命令也是先送到相关芯片的端口中,然后再由相关的芯片根据命令对外设实施控制

可见,CPU通过端口和外部设备进行联系

 

3、外中断信息

在PC系统中,外中断源一共有以下两类。

(1)可屏蔽中断

可屏蔽中断是CPU可以不响应的外中断,CPU是否响应可屏蔽中断,要看标志寄存器IF位的设置,当CPU检测到可屏蔽中断信息时,如果IF=1,则CPU在执行完当前指令后响应中断,引起中断过程;如果IF=0,则不响应可屏蔽中断

现在我们可以解释中断过程中将IF置为0的原因了。将IF置0的原因就是,在进入中断处理程序后,禁止其他的可屏蔽中断

当然,如果在中断处理程序中需要处理可屏蔽中断,可以用指令将IF置1.8086CPU提供的设置IF的指令如下:

sti,设置IF=1

cli,设置IF=0

(2)不可屏蔽中断

不可屏蔽中断时CPU必须响应的外中断。当CPU检测到不可屏蔽中断信息时,则在执行完当前指令后,立即响应,引发中断过程

对于8086CPU,不可屏蔽中断的中断类型码固定为2,所以中断过程中,不需要取中断类型码

几乎所有由外设引发的外中断,都是可屏蔽中断。当外设有需要处理的时间(比如说键盘输入)发生时,向关系篇向CPU发出可屏蔽的中断信息。不可屏蔽中断是在系统中有必须处理的紧急情况发生用来通知CPU的中断信息

 

4、PC机键盘的处理过程

键盘输入

键盘上的每一个键相当于一个开关,键盘中有一个芯片对键盘上的每一个键的开关状态进行扫描

按下一个键时,开关接通,该芯片救出女生一个扫描码,扫描码说明了按下的键在键盘上的位置,松开按键时产生的扫描码也被送入到60h端口中

一般将按下一个键时产生的扫描码称为通码,松开一个键产生的扫描码称为断码。扫描码长度为1个字节,通码的第七位为0,断码的第七位为1,即:

断码=通码+80h

比如,g键的通码为22h,断码为a2h

引发9号中断

键盘的输入到达60h端口时,相关的芯片就会向CPU发出中断类型码为9的可屏蔽中断信息。CPU检测到该中断信息后,如果IF=1,则响应中断,引发中断过程,转去执行int 9中断例程

执行嗯int 9中断例程

BIOS提供了int 9中断例程,用来进行基本的键盘输入处理,主要的工作如下:

(1)读取60h端口中的俄扫描码

(2)如果是字符键的扫描码,将该扫描码和它所对应的字符码(即ASCII码)送入内存中的BIOS键盘缓冲区;如果是控制键(比如 ctrl)的扫描码,则将其转变为状态字节(用二进制位记录控制键和切换键状态的字节)写入内存中存储状态字节的单元

(3)对键盘系统进行相关的控制,比如说,向相关芯片发出应答信息

BIOS键盘缓冲区是系统启动后,BIOS用于存放int 9中断例程所接收的键盘输入的内存区。该内存区可以存储15个键盘输入,因为int 9中断例程除了接收扫描码外,还要产生和扫描码对应的字符码,所以在BIOS键盘缓冲区中,一个键盘输入用一个字单元存放,高位字节存放扫描码,低位字节存放字符码

0040:17单元存储键盘状态字节,盖孜节记录了控制键和切换键的状态。键盘状态字节各位记录的信息如下

0右shift
1左shift
2ctrl
3alt
4scrolllock指示灯亮
5numlock小键盘数字
6capslock输入大写字母
7insert处于删除态

 

5、指令系统总结

我们对8086CPU的指令系统进行一下总结

(1)数据传送指令

比如mov、push、pop、pushf、popf、xchg等都是数据传送指令,这些指令实现寄存器和内存、寄存器和寄存器之间单个数据的传送

(2)算术运算指令

比如,add、sub、adc、sbb、inc、dec、cmp、imul、idev、aaa等都是算术运算指令,这些指令实现寄存器和内存中的数据的算术运算,他们的执行结果影响标志寄存器的sf、zf、of、cf、pf、af

(3)逻辑指令

比如,and、or、not、xor、shl、shr、sal、sar、rol、ror、rcl、rcr等都是逻辑指令。除了not指令外,它们的执行结果都影响标志寄存器的相关标志位

(4)转移指令

可以修改IP,或同时修改CS和IP的指令统称为转移指令。转移指令分为以下几类。

  • 无条件转移指令,比如jmp;
  • 条件转移指令,比如jcxz、je、jb、ja、jnb、jna等
  • 循环指令,比如loop;
  • 过程,比如,call、ret、retf
  • 中断,比如,int、iret

 

(5)处理机控制指令

这些指令对标志寄存器或其他处理机状态进行设置,比如cld、std、cli、sti、nop、clc、cmc、stc、hlt、wait、esc、lock等都是处理机控制指令

(6)串处理指令

这些指令对内存中的批量数据进行处理,比如,movsb、movsw、cmps、scas、lods、stos等。若要使用这些指令方便的进行批量数据的处理,则需要和rep、repe、repne等前缀指令配合使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值