习题一
1. 什么是接口?
接口就是微处理器CPU与外部世界的连接部件,是CPU与外界进行信息交换的中转站。
2. 为什么要在CPU与外设之间设置接口?
在CPU与外设之间设置接口主要有4个原因:
(1) CPU与外设二者的信号不兼容,包括信号线的功能定义、逻辑定义
和时序关系
(2) CPU与外设的速度不匹配,CPU的速度快,外设的速度慢
(3) 若不通过接口,而由CPU直接对外设的操作实施控制,会使CPU
处于穷于应付与外设打交道之中,大大降低CPU的效率
(4) 若外设直接由CPU控制,会使外设的硬件结构依赖于CPU,对外设
本身的发展不利。
3. 微型计算机的接口一般应具备那些功能?
微机的接口一般有如下的几个功能: (1) 执行CPU命令的功能:CPU将对外设的控制命令发到接口电路中的
命令寄存器(命令口)中,在经分析去控制外设
(2) 返回外设状态的功能:通过状态寄存器(状态口)完成,包括正常
工作状态和故障状态
(3) 数据缓冲的功能:接口电路中的数据寄存器(数据口)对CPU于外
设间传送的数据进行中转
(4) 设备寻址的功能:CPU某个时刻只能和一台外设交换数据,CPU发
出的地址信号经过接口电路中的地址译码电路来选中I/O设备
(5) 信号转换的功能:当CPU与外设的信号功能定义、逻辑关系、电平
高低及工作时序不兼容时接口电路要完成信号的转换功能 (6) 数据宽度与数据格式转换的功能:由于CPU处理的数据都是并行的,
当外设采用串行传送方式时,接口电路就要完成串、并之间的转换,并进行数据格式的转换。
4. 接口电路的硬件一般由哪几部分组成?
接口电路的硬件一般由以下几部分组成:
(1) 基本逻辑电路:包括命令寄存器、状态寄存器和数据缓冲寄存器,
是接口电路中的核心
(2) 端口地址译码电路:实现设备的选择功能
(3) 供选电路:根据不同任务和功能要求而添加的功能模块电路。 5. 接口电路的软件控制程序一般包括哪几部分?
接口电路的软件控制程序一般包括以下的程序段,各部分程序是相互渗透、融为一体的:
(1) 初始化程序段:对可编程接口芯片进行初始化编程
(2) 传送方式处理程序段:不同的传送方式(查询、中断、DMA方式)
程序段不同
(3) 主控程序段:完成接口任务的程序段
(4) 程序终止与退出程序段:程序退出前对接口电路中硬件进行保护的
程序段
(5) 辅助程序段:人-机对话、菜单等
6. 接口电路的结构有哪几种形式?
接口电路的结构主要有四种:
(1) 固定式结构:不可编程的接口电路,结构简单、功能单一、固定 (2) 半固定式结构:由PAL或GAL器件构成的接口电路,功能和工作方
式可以通过改写内部的逻辑表达式来改变,但逻辑表达式一旦烧入芯片,其功能和工作方式就固定下来了
(3) 可编程结构:其功能和工作方式可由编程指定,使用灵活、适应面
广,且种类繁多
(4) 智能型结构:芯片本身就是一个微处理器,外设的全部管理都由智
能接口完成,如I/O处理器I0809或通用单片机
7. CPU与接口之间有哪几种传送数据的方式?它们各应用在什么场合?
CPU与接口之间的数据传送方式主要有查询方式、中断方式和DMA方式: (1) 查询方式:主要用于CPU不太忙且传送速度不高的情况下。无条件
传送方式作为查询方式的一个特例,主要用于对简单I/O设备的控制或CPU明确知道外设所处状态的情况下。
(2) 中断方式:主要用于CPU的任务比较忙的情况下,尤其适合实时控
制和紧急事件的处理
(3) DMA方式(直接存储器存取方式):主要用于高速外设进行大批量
数据传送的场合。
习题二
2I/O端口的编址方式有几种?各有何特点?
I/O端口的编址方式有两种——统一编址方式(存储器映象方式)和独立编址方式(I/O映象方式、专用I/O指令方式)
(4) 统一编址方式:从整个寻址空间中划出一部分给I/O设备,其余的给
存储器,通过地址码区分操作对象是存储器还是I/O,二者的地址码不重叠。这种方式的优点是①I/O端口的编址空间大,且易于扩展②I/O指令丰富、功能齐全;缺点是①存储器的地址空间减少,达不到系统最大的寻址空间②I/O指令比独立编址方式的专用I/O指令长,译码时间长,执行速度慢
(5) 独立编址方式:存储单元与I/O端口分别编址,地址码重叠,通过操
作码区分操作对象是存储器还是I/O。这种方式的优点是①I/O端口不占存储器的编址空间,使存储器的容量可达系统的最大寻址能力②I/O指令短、执行速度快;指令清晰、可读性强;缺点是①I/O端口地址范围一旦确定,不易扩展②I/O指令种类有限,操作单一
4I/O端口地址译码电路在接口电路中的作用是什么?
I/O端口地址译码电路的作用就是把地址和控制信号进行逻辑组合,从而产生对接口芯片的选择信号。
5在I/O端口地址译码电路中常常设置AEN=0,这有何意义?
AEN=1,表示正在进行DMA操作,在I/O端口地址译码电路中,常常令AEN=0时,译码输出才有效,这样做的目的是为了避免在DMA操作周期中,由DMA控制器对这些以非DMA方式传送的I/O端口执行DMA方式的传送。 6若要求I/O端口地址为374H,则在图2.1(b)中的输入地址线要作哪些改动?
为了使I/O端口的地址为374H,图2.1(b)中地址线A2、A8后的非门去掉,
而在地址线A3、A7后面加上非门。即修改后地址线A0、A1、A3、A7后有非门,其余地址线后无非门。如图所示:
A9 A8 A7 & 1 …AEN 1 IOR 1 8. 在独立编址方式下,CPU采用什么指令来访问端口?
独立编址方式下,采用专用的I/O指令——输入/输出指令(如PC系列微机中的IN、OUT)来访问端口。
9. I/O端口地址译码电路一般有哪几种结构形式?
I/O端口地址译码电路一般有两种结构形式: 固定式端口地址译码——硬件电路不改动,译码输出的地址或地址范围不变 可选式端口地址译码——电路中有若干个DIP开关,硬件电路不改动,只改变开关的状态,就可以使译码输出的地址或地址范围发生变化。
。
10. 采用GAL器件设计地址译码电路时,其核心是编写GAL器件输入源文件
(即GAL设计说明书)。现利用GAL16V8设计一个扩展系统的地址译码电路,要求该系统的I/O端口地址范围分别为300H~31FH和340H~35FH;存储器地址范围为D0000H~EFFFFH。试编写GAL16V8的编程输入源文件。 略。
11. 若将图2.3中DIP开关状态设置为:S2和S1合上(ON);S3和S0断开(OFF),
试指出74LS138输出端 Y 5 的地址范围,并与图中在DIP开关原来的状态下 Y 5 输出端所产生的地址范围进行比较,有何变化? 如果S2和S1合上(ON);S3和S0断开(OFF),Y 5 有效时,各位地址线的状态如下: A9 A8 A7 A6 A5 A4 A3 A2 1 0 0 1 0 1 0 1 S3 S2 S1 S0 开 合 合 开 所以,这种开关状态下, Y 5 的地址范围是254H~257H;而DIP开关在原来的开关状态下, Y 5 这两个地址范围A9~A6的状 的地址范围是314H~317H。态不同,因为A9~A6的状态是由开关的状态决定的;而二者的A5~A2是相同的,因为它们不受开关状态的影响。
1采用DMA方式为什么能实现高速传送?
A3 A2 A1 A0 1 ≥1 1 1 & Y 习题四