X
首页
技术
模拟电子
单片机
半导体
电源管理
嵌入式
传感器
最能打国产芯
应用
汽车电子
工业控制
家用电子
手机便携
安防电子
医疗电子
网络通信
测试测量
物联网
最能打国产芯
大学堂
首页
直播
专题
TI 培训
论坛
汽车电子
国产芯片
电机驱动控制
电源技术
单片机
模拟电子
PCB设计
电子竞赛
DIY/开源
嵌入式系统
医疗电子
颁奖专区
【厂商专区】
【电子技术】
【创意与实践】
【行业应用】
【休息一下】
最能打国产芯
活动中心
直播
发现活动
颁奖区
电子头条
参考设计
下载中心
分类资源
文集
排行榜
电路图
Datasheet
最能打国产芯
单片机
[资料分享] 接口电路详解-原理、应用、分类,处理过程
tiankai001
2013-4-20 23:47
楼主
接口设计
什么是接口?
接口是CPU和外设之间的连接设备,用于缓存和转发数据。
为什么需要接口?
(1)解决主机CPU和外围设备之间的时序配合和通信联络问题
主机的CPU是高速处理器件,比如8086-1的主频为10MHz,1个时钟周期仅为100ns,一个最基本的总线周期为400ns。而外围设备的工作速度比CPU的速度慢得多。如常规外围设备中的电传打字机传送信息的速度是毫秒级;工业控制设备中的炉温控制采样周期是秒级。为保证CPU的工作效率并适应各种外围设备的速度配合要求,应在CPU和外围设备间增设一个I/O接口电路,满足两个不同速度系统的异步通信联络。
I/O接口电路为完成时序配合和通信联络功能,通常都设有数据锁存器、缓冲器、状态寄存器以及中断控制电路等。通过接口电路,CPU通常采用查询或中断控制方式为慢速外围设备提供服务,就可保证CPU和外围设备间异步而协调的工作,既满足了外围设备的要求,又提高了CPU的利用率。
(2)解决CPU和外围设备之间的数据格式转换和匹配问题
CPU是按并行处理设计的高速处理器件,即CPU只能读入和输出并行数据。但是,实际上要求其发送和接收的数据格式却不仅仅是并行的,在许多情况下是串行的。例如,为了节省传输导线,降低成本,提高可靠性,机间距离较长的通信都采用串行通信。又如,由光电脉冲编码器输出的反馈信号是串行的脉冲列,步进电动机要求提供串行脉冲等等。这就要求应将外部送往计算机的串行格式的信息转换成CPU所能接收的并行格式,也要将CPU送往外部的并行格式的信息转换成与外围设备相容的串行格式,并且要以双方相匹配的速率和电平实现信息的传送。这些功能在CPU控制下主要由相应的接口芯片来完成。
(3)解决CPU的负载能力和外围设备端口选择问题
即使是CPU和某些外围设备之间仅仅进行并行格式的信息交换,一般也不能将各种外围设备的数据线、地址线直接挂到CPU的数据总线和地址总线上。这里主要存在两个问题,一是CPU总线的负载能力的问题:二是外围设备端口的选择问题。因为过多的信号线直接接到CPU总线上,必将超过CPU总线的负载能力,采用接口电路可以分担CPU总线的负载,使CPU总线不致于超负荷运行,造成工作不可靠。CPU和所有外围设备交换信息都是通过双向数据总线进行的,如果所有外围设备的数据线都直接接到CPU的数据总线上,数据总线上的信号将是混乱的,无法区分是送往哪一个外围设备的数据还是来自哪一个外围设备的数据。只有通过接口电路中具有三态门的输出锁存器或输入缓冲器,再将外围设备数据线接到CPU数据总线上,通过控制三态门的使能(选通)信号,才能使CPU的数据总线在某一时刻只接到被选通的那一个外围设备的数据线上,这就是外围设备端口的选址问题。使用可编程并行接口电路或锁存器、缓冲器就能方便的解决上述问题。
此外,接口电路可实现端口的可编程功能以及错误检测功能。一个端口通过软件设置既可作为输入口又可作为输出口,或者作为位控口,使用非常灵活方便。同时,多数用于串行通信的可编程接口芯片都具有传输错误检测功能,如可进行奇/偶校验、冗余校验等。
接口硬件包含哪些部分?
(1)基本逻辑电路
命令寄存器
状态寄存器
数据缓冲寄存器
(2)端口地址译码电路
根据地址总线上的信号确定是否选中该接口的某个寄存器(端口)
(3)供选电路
与其它部件的连接电路,如与中断控制器连接以实现中断方式的数据传送。
接口软件有什么功能?
一个完整的设备接口程序包括:
(1)初始化程序段
(2)传送设置程序段
(3)主控程序段
(4)结束程序段
(5)人机接口程序段
设备驱动程序就是一种标准化的接口软件。
接口电路有哪些形式?
固定式结构:SSI,MSI (IC)
半固定结构:GAL, PAL
可编程结构:可编程芯片
智能型结构:带微处理器
CPU如何与接口进行数据交换?
查询方式: CPU<>接口
先确认外设已准备好,才进行传送
中断方式: CPU<>接口
为避免不断读取状态位检查设备是否已准备好而造成等待循环,
当输入设备准备好时,才向CPU发中断请求,CPU响应后转入执
行中断服务程序。
DMA方式: 存储器<>接口
接口<>接口
存储器<>存储器
I/O端口
什么是I/O端口?
CPU与外设通信时,传送的数据信息,状态信息和控制信息分别进入接口电路中不同的寄存器,通常将这些寄存器和它们的控制逻辑统称为I/O端口(Port),CPU可对端口中的信息直接进行读写。
数据端口:存放数据,是主机和外设之间交换的基本信息,长度一般为1-2字节,主要起数据缓冲的作用。
状态端口:指示外设的当前状态,每种状态用1位表示,每个外设可以有几个状态位,由CPU读取以测试或检查外设的状态。最常用的状态位有准备就绪位(Ready),忙碌位(Busy)和错误位(Error)。
命令端口:也称为控制端口,用来存放CPU向接口发出的各种命令和控制字,以便控制接口或设备的动作。常见的命令信息位有启动位,停止位,允许中断位等。
I/O端口编址方式
数据信息,状态信息和控制信息的含义各不相同,但在微机系统中,CPU通过接口与外设交换数据时,只有输入(IN)和输出(OUT)两种指令,所以只能把状态信息和命令信息也都当作数据信息来传送。
I/O端口的编址方式: 存储器映象寻址方式和I/O指令寻址方式。
存储器映象寻址方式(Memory Mapped I/O):把每一个I/O端口都看作一个存储单元,并与存储单元一样统一编址,可使用访问存储器映象的所有指令来访问I/O端口。
I/O单独编址方式:对系统中的输入输出端口地址单独编址,构成一个I/O地址空间,不占用存储空间,用专门的IN和OUT指令来访问这种具有独立地址空间的端口。8080/Z80/8088和8086等都采用此种方式。8086用地址总线的低16位来寻址I/O端口,可寻址的端口数最大可达到65536个。
I/O指令
如何访问I/O端口?通过执行I/O指令。
Intel 8086的I/O指令有哪些?
[plain]
view plain
copy
IN AL, PORT8 ;AL《(PORT8)
IN AL, DX ;AL《(DX)
OUT PORT8, AL ;(PORT8)《AL
OUT DX, AL ;(DX)《AL
其中,PORT8表示8位端口地址, PORT16表示16位端口地址,AX可以替代AL。
例如,
[cpp]
view plain
copy
MOV DX, 300H ; DX《300H
IN AL, DX ; AL《(DX)
MOV DX, 301H ; DX《301H
OUT DX, AL ; (DX)《AL
IN AX, 80H ; AL 《80H AH 《81H
I/O端口地址译码原理
如何在CPU执行I/O指令时可以访问到相应端口地址
的I/O端口?
设计I/O端口地址译码线路。
如何设计I/O端口地址译码电路?通过地址总线和控制总线产生端口芯片的选择信号(CS)
。
I/O端口地址译码电路分类
端口地址译码电路的种类:
固定式单端口地址译码 采用门电路或译码器进行译码,设计完毕后端口地址不能更改。
可选式端口地址译码 通过比较器和译码器等组成,端口地址可以通过DIP开关进行更改。
采用可编程逻辑阵列实现逻辑电路
固定式单端口地址译码(1)
固定式单端口地址译码(2)
固定式单端口地址译码(3)
3-8译码器译码电路
接口的输入输出方法
(1)无条件传送方式
也称为同步传送方式,主要用于对简单外设进行操作。对这类外设,在任何时刻均已准备好数据或处于接收数据状态,如LED显示器的明灭控制(如下图所示)
(2)查询方式
执行读端口指令不断查询接口状态,若接口准备好, 则可以执行I/O指令输出数据到接口或或从接口读入数据。
(3)中断方式
接口准备好之后,便请求CPU中断现在执行的程序,转而为之服务。
(4) DMA方式
当外设有大量数据需要与主存储器交换时,DMA控制器向CPU申请接管总线,若成功,则控制外设与主存储器直接交换数
DMA方式读磁盘的过程
系统启动时,3个开关打向上端,总线与CPU/存储器/外设连接,并由CPU来控制,进行DMA传输前,首先初始化8237A DMA控制器,设定传送数据的计数器,起始地址,DMA通道和传送方式。
CPU向磁盘控制器发出读盘命令,磁盘控制器读出数据。
磁盘控制器准备好数据后,向DMA控制器发送一个DMA请求信号DREQ,DMA控制器送一个保持请求信号HRQ到CPU的HOLD输入端,CPU发回保持响应信号HLDA信号,中止当前程序运营。DMA控制器收到HLDA后,将3个总线开关置向下方,让总线与CPU脱开而与DMA控制器相连。
DMA控制器取得总线控制权后,通过地址总线向存储器发送地址信号,并向磁盘控制器发出DMA确认信号DACK。
DMA控制器使控制总线上IOR#和MEMW#信号有效,使得磁盘控制器能向数据总线输出数据字节,并使存储器单元能够被写入。
完成一个字节传送后,DMA控制器自动修改内部寄存器的内容并指向下一个字节的地址,通过计数器的递减完成所有数据的传送。
DMA传送结束后,DMA控制器撤销它对CPU发出的保持信号HRQ,并释放总线。
CPU在每一个非锁定时钟周期结束后,都检测HOLD引脚看是否有DMA信号。
点赞
回复评论 (2)
沙发
dwwzl
:carnation: 支持啊!!!!!!!!!!!!!!!!!!!!!!!
点赞
2013-4-21 09:14
板凳
海草
好详细,不错,谢谢楼主
点赞
2017-12-8 17:28
最新活动
有奖直播报名中!抢占工业4.1先机 文晔科技日等你来!
2024 瑞萨电子MCU/MPU工业技术研讨会——深圳、上海站, 火热报名中
罗姆有奖直播 | 重点解析双极型晶体管的实用选型方法和使用方法
STM32N6终于要发布了,ST首款带有NPU的MCU到底怎么样,欢迎小伙们来STM32全球线上峰会寻找答案!
免费下载 | 安森美电动汽车充电白皮书,看碳化硅如何缓解“里程焦虑”!
是德科技有奖直播 | 应对未来高速算力芯片的设计与测试挑战
随便看看
dsp最多可以处理小数点后几位的数
MSP430G2553学习笔记
无刷直流电动机 - 第一部分:结构和工作原理
【Silicon Labs BG22-EK4108A 蓝牙开发评测】开箱
【STM32WB55 测评】+无线固件更新
求以太网RJ45的原理图封装。
小孩越来越有个性了
从零开始学FPGA我的第七个实验(记录一下)
vxworks下做opengl开发可以吗
Cadence元器件封装如何单独更改
SEED-EXP430F5529 USB实验板继续火爆开团!!!
请教关于基于THS7001可控运放的增益控制问题
silion labs zigbee如何入门
电阻功率选取问题
谁有wince5.0 mipsii版本的带模拟器的BSP?
《毕业论文设计》基于单片机的信号发生器设计
工作这点事!还必须得当回事!
想成为电源工程师?先搞清楚这些
新人就助
2017恩智浦物联网大赛来袭,无人机等大奖等你来
电子工程世界版权所有
京B2-20211791
京ICP备10001474号-1
京公网安备 11010802033920号
回复
写回复
收藏
回复