网站大量收购闲置独家精品文档,联系QQ:2885784924

(微机接口技术及其应用)第4章可编程中断控制接口芯片8259A.ppt

(微机接口技术及其应用)第4章可编程中断控制接口芯片8259A.ppt

  1. 1、本文档共146页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
  中断控制输入/输出方式是CPU与外设交换信息的一种主要的输入/输出传送方式,中断控制技术是计算机发展中的一种主要技术。中断控制方式使外设具有一定的主动权,即只有在外设需要服务时,它才通过中断控制器接口向CPU提出申请服务。这样,CPU就不必反复去查询外设的状态,从而克服了程序查询导致CPU效率低的缺点。   随着计算机系统结构的不断改进以及计算机技术的飞速发展,中断的适用范围也在不断地扩大。除了原有的硬件中断,又出现了内部中断,并逐步形成了一个完整的中断系统。完整的中断系统是指实现中断过程的手段,包括硬件和软件,即为了实现中断功能而设置的各种硬件和软件。   本章将在讲述8088/8086中断系统中各类中断的功能、特点以及中断向量的形成等内容的基础上,进一步介绍中断控制器接口,可编程中断控制器8259A的结构、功能、工作方式、编程方法以及应用。    4.1.1 8088/8086的中断分类   8088/8086具有一个强有力的中断系统,它可以处理256种向量中断。每个中断对应一个类型码,这256种中断对应的中断类型码为0~255。如果按照产生中断的方法来分,所有的256种中断可以分为两大类:外部中断和内部中断。8088/8086中断源的分类如图4-1所示。       图4-1 8086/8088中断源的分类   图4-1中,硬件中断是通过外部的硬件产生的,又称为外部中断。外部中断又分为可屏蔽中断和非屏蔽中断。可屏蔽中断通过CPU的INT端进入CPU。可屏蔽中断只有当中断允许标志IF=1时,才能被CPU响应。在一个系统中,如果通过与中断控制器8259A配合,可屏蔽中断可以有一个或多个。而非屏蔽中断则是通过NMI端引入CPU的,它不受中断允许标志IF的屏蔽,一个系统中一般只允许有一个非屏蔽中断。   内部中断又分为微处理器内部中断(如除数为0中断、单步中断等)和由中断指令引起的软件中断。软件中断是CPU根据软件中的某条指令或者软件对标志寄存器中某个标志进行设置而产生的。由于软件中断的产生过程完全和硬件电路无关,因此一般又称为内部中断。 4.1.2 中断类型码与中断矢量表   在8088/8086的中断系统中,无论是外部中断还是内部中断,每一个中断源都分配一个确定的中断类型码,即0~255。每个中断类型码对应一个中断矢量,这些中断矢量按照低地址存放IP值,高地址存放CS值的规律存放在内存的0段中,形成了一个中断矢量表。因此,当CPU响应中断后,根据每个中断源提供的中断类型码,便能自动从中断矢量表中取出相应的中断矢量。所谓中断矢量,实际上就是中断服务程序的入口地址,每个中断类型对应一个中断矢量。   8088/8086中断系统在内存0段的0~03FFH区域建立了一个中断矢量表,该表总共可以容纳256个中断矢量。中断矢量按照规定放入中断矢量表中。在8088/8086系统中,每个中断矢量占4个存储单元,其中前两个存储单元存放中断服务程序入口地址的偏移量,即IP值,后两个单元存放中断服务程序入口地址的段地址,即CS值。IP值和CS值存放时都按低位在前、高位在后的原则,按照中断类型的序号(0~255),将对应的中断矢量在内存的0段0单元开始有规则地按顺序进行排列。这样,只要有中断类型码,就可根据中断类型码与中断矢量所在位置之间的对应关系,很方便地判断出中断关系矢量表的地址,即    中断矢量表地址?=?中断类型码×4   【例4-1】 中断类型码为21H的中断,其中断向量存放在以0000:0084H(4×21H=84H)开始的4个字节单元中。   计算出中断向量地址后,只要将4n和4n+1单元的内容装入IP,将4n+2和4n+3单元的内容装入CS,即可转入中断服务程序。   注意:在80386以后的微机中,由于虚拟内存及保护方式的出现,中断向量表不再固定存放在00000H~003FFH区域中(中断向量表的名字也改为中断描述符表IDT),而可以位于内存的任意区域,表的首地址放在CPU内部的IDT基址寄存器中。每个表项也从4个字节增加到了8个字节,包括2字节的选择器、4字节的偏移量和2字节的其他属性。   【例4-2】 中断类型码为10H的中断所对应的中断矢量存放在0段以0040H开始的4个存储单元中(即10H×4 ?=?40H),如果从0040H开始的4个单元中的值分别为42H、44H、46H、48H,那么该系统中的10H中断所对应的中断矢量为4846H、4442H。中断矢量表如表4-1所示。    表4-1 中?断?矢?量?表   如果一个系统中的中断类型码为25H的中断其中断服务程序存放在以2345H:7890H开始的内存区域中,那么,中断类型码为25H的中断矢量在中断矢量表中又是如何存放的呢?   我们可以这样分

文档评论(0)

autohhh + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档