【接口技术】输入输出接口

【输入输出接口概念】外设接口功能及其一般结构,I/O端口编址方式,输入/输出数据传送方式,端口译码技术

【输入/输出接口】

外部设备及其信号

外部设备 = 输入设备 + 输出设备 + 复合输入/输出设备

外部设备的信号 = 数据信号(数字量、模拟量、开关量、脉冲量) + 状态信号(如Ready、Busy等,总是从外部设备发往CPU) + 控制信号(CPU发往外部设备)

外部设备的信号以数据形式,通过总线在CPU和外部设备之间传输

I/O接口及功能

接口的重要性:微机和I/O设备的信息类型和格式大多不一样,信号传输处理速度大多不匹配

接口功能:设备选择、信息传输、数据格式转换、联络、中断管理、复位、可编程、错误检测

接口的组成

接口处理的信号:CPU(或总线)与I/O设备之间的接口信息,通常分为数据信号、状态信号、控制信号

接口组成:接口硬件 + 接口软件(驱动程序)

端口:接口内的寄存器,暂存CPU和外设之间传输的数据、状态和命令

端口地址:每个端口有一个独立的地址

外部设备地址:设备接口内各端口的地址

端口种类:数据端口、命令(控制)端口、状态端口

接口软件 —— 初始化程序段、传送方式处理程序段、主控程序段、程序终止与退出程序段、辅助程序段

IBM PC的外设接口:单总线结构 + 通用的集成I/O芯片

现代PC机的外设接口:南北桥结构 或 中心结构

I/O端口的编址方法

  1. I/O端口与内存统一编址(存储器映射编址方式):1个8位端口占用一个内存单元地址
  2. I/O端口与内存独立编址(I/O端口编址方式):访问I/O端口需要专门的I/O指令

简单I/O接口的组成和译码

地址总线上传送的地址码对接口中的不同寄存器或电路进行区分

访问设备,实际是访问接口卡上的端口


I/O端口地址空间(ISA总线):实际只用A9-A0,连续2个8位端口等价1个16位端口,连续4个8位端口等价1个32位端口

I/O操作所需总线信号:地址信号AB、IO读写-IOW或-IOR、地址允许AEN


I/O端口地址寻址方式:I/O直接寻址(8位地址,1字节立即数寻址)和间接寻址(16位地址,DX寄存器给出

I/O端口地址选用原则:系统配置占用的,或申明保留的地址,不能使用

端口选择(译码)技术:门电路、芯片、可编程逻辑器件(ABEL语言)

I/O端口地址译码电路设计

1:固定式端口地址译码

    将端口地址转二进制,所有地址线、IOR和AEN经过与门为1


2:地址译码电路(74LS138,3-8译码器,G2A=G2B=0,G1=1)


    高位地址用于译码芯片使能,低位地址用于选择接口内不同的端口


    配置多段地址——使用jumper跳线器改变端口地址

由于读、写操作不会同时进行,输入端口和输出端口可使用同一个地址编码

数据锁存器与缓冲器(端口的设计&实现)

锁存器:由CLK上升沿或下降沿触发,输出不随输入变化

缓冲器:输出和输入随时保持一定关系,目的是加大负载

简单I/O接口:组合地址译码、数据锁存与缓冲、状态寄存器、命令寄存器各个电路


示意图:

【输入输出数据传输的控制方式】

1:程序方式

程序控制信息传送,CPU享有“主动权”

·无条件传送:输入信号不用锁存,输出信号用锁存
·条件传送(查询/异步):有存储和传送状态的端口;输入过程READY先1后0,输出过程BUSY先1后0

2:中断方式

CPU和外设“并行工作”,外设享有“主动权”

每传送一次数据,CPU必须执行一次中断服务程序

高速外设容易产生覆盖错误,传送速度低且CPU时间消耗大

3:直接存储器存取方式(DMA)

Direct Memory Access


DMA控制器(DMAC)来实现内存与外设,或外设与外设之间的直接快速传送,CPU不参加数据的传送工作

DMA方式使信息传送从以CPU为中心变为以内存为中心

一次DMA传送只需要执行一个DMA周期(相当于一个总线读/写周期)

·DMA传送的工作过程:

1)I/O设备向DMAC发出DMA请求;

2)DMAC向CPU发出总线请求(HOLD);

3)CPU在执行完当前指令的当前的总线周期后,向DMAC发出总线响应信号(HLDA);

4)CPU脱离对系统总线的控制,由DMAC接管对系统总线的控制;

5)DMAC向I/O设备发出DMA应答信号;

6)DMAC进行一个字节的传送;

7)完成设定的字节数据传送,CPU恢复对系统总线的控制;

【开关量输入输出接口】

1:开关量输入接口

1)基本的开关量输入接口

形态:单刀单掷、单刀双掷、按钮

开关量通过三态缓冲器(输入输出同相 或 输入输出反相)与系统数据总线连接

一条输入指令可以同时读入8位或16位开关量

2)矩阵式开关量输入接口

    行线(R0~R7):数据输出端口

    列线(C0~C7):数据输入端口

    电路特点:

·没有键按下时,列线全为1;

·行线全为1时,无论有无键按下,列线仍全为1

·某行线为0时,若该行有键按下,则输出7个1和1个0,0的位置与键对应

    键盘扫码与编码:

·编码是二字节码(高8位行码 + 低8位列码),例如(R3,C2)是(11110111,11111011)=F7FB H

·扫描码是一字节码(数字码),例如(R3,C2)=32 H =(0011,0010)

    键盘扫码程序:

    ·没有键按下,返回-1

    ·有键按下,产生抖动,返回二字节码(行列码)

    ·PRORT和CPORT定义行、列端口的地址

2:开关量输出接口

1)基本的开关量输出接口

LED发光二极管,输出0发光,输出1熄灭


2)LED七段数码显示管接口

位选择:选择某个数码管

段选择:选择某竖或某横的灯管(如abcdefg)

类型

0

1

2

3

4

5

6

7

8

9

共阳极

0C0H

0F9H

0A4H

0B0H

99H

92H

82H

0F8H

80H

90H

共阴极

3FH

06H

5BH

4FH

66H

6DH

7DH

07H

7FH

6FH

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/96058.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑提示MSVCP100.dll丢失错误怎么解决?分享四个解决方法帮你搞定

在平时我们使用电脑中,经常会遇到各种问题,比如msvcp100.dll文件丢失,那这个msvcp100.dll文件丢失需要怎么修复解决呢?和msvcp100.dll为什么会丢失呢,下面我一点点为大家解答与介绍解决msvcp100.dll丢失问题的方法。 一…

Redisson—分布式服务

一、 分布式远程服务(Remote Service) 基于Redis的Java分布式远程服务,可以用来通过共享接口执行存在于另一个Redisson实例里的对象方法。换句话说就是通过Redis实现了Java的远程过程调用(RPC)。分布式远程服务基于可…

【JVM】运行时数据区(内存区域划分)详解

文章目录 前言一、JVM 运行时数据区1, 堆2, Java 虚拟机栈3, 本地方法栈4, 程序计数器5, 元数据区 / 方法区 二、内存异常问题1, 栈溢出2, 内存溢出3, 内存泄露 总结 前言 📕各位读者好, 我是小陈, 这是我的个人主页 📗小陈还在持续努力学习编程, 努力通…

Minecraft个人服务器搭建自己的皮肤站并实现外置登录更换自定义皮肤组件

Minecraft个人服务器搭建自己的皮肤站并实现外置登录更换自定义皮肤组件 大家好,我是艾西有不少小伙伴非常喜欢我的世界Minecraft游戏,今天小编跟大家分享下Minecraft个人服务器怎么设置皮肤站。 Minecraft皮肤站是什么?其实官网就有皮肤站…

关于智能空气动力学

智能空气动力学是指运用智能科学方法和研究范式研究空气运动,尤其是物体与空气相对运动时空气对物体所施作用力规律、气体的流动规律和伴随发生的物理学变化,解决空气动力学问题的新的交叉学科。在空气动力学三大传统研究手段的基础上,智能空…

【Overload游戏引擎分析】画场景网格的Shader

Overload引擎地址: GitHub - adriengivry/Overload: 3D Game engine with editor 一、栅格绘制基本原理 Overload Editor启动之后,场景视图中有栅格线,这个在很多软件中都有。刚开始我猜测它应该是通过绘制线实现的。阅读代码发现&#xff0…

STM32复习笔记(二):GPIO

目录 (一)Demo流程 (二)工程配置 (三)代码部分 (四)外部中断(EXTI) (一)Demo流程 首先,板子上有4个按键,…

外包做了3个月,技术退步明显。。。。。

先说一下自己的情况,大专生,17年通过校招进入广州某软件公司,干了接近4年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…

网络初识必知会

局域网:把一些设备通过交换机/路由器连接起来 广域网:把更多的局域网也相互连接,当网络规模足够大的 交换机:组网过程中的重要设备! 路由器:组网过程中的重要设备! IP地址:描述一…

什么,这年头还有人不知道404

写在前面 哥,来帮我看看,这个请求怎么404了,明明接口路径是对的啊!一个下午,组里的小哥突然让我帮忙看这个问题,我不禁一惊,啥,这年头了还有人搞不定404,如有还有&#…

FFmpeg:打印音/视频信息(Meta信息)

多媒体文件基本概念 多媒体文件其实是个容器在容器里面有很多流(Stream/Track)每种流是由不同的编码器编码的从流中读出的数据称为包在一个包中包含着一个或多个帧 几个重要的结构体 AVFormatContextAVStreamAVPacket FFmpeg操作流数据的基本步骤 打印音/视频信息(Meta信息…

LVGL_基础控件滚轮roller

LVGL_基础控件滚轮roller 1、创建滚轮roller控件 /* 创建一个 lv_roller 部件(对象) */ lv_obj_t * roller lv_roller_create(lv_scr_act()); // 创建一个 lv_roller 部件(对象),他的父对象是活动屏幕对象// 将部件(对象)添加到组,如果设置了默认组&#xff0c…

不断优化的素数算法

前言:素数判断是算法中重要的一环,掌握优秀的素数判断方法是算法player的必修课。本文介绍的是由简到繁的素数算法,便于初学者从入门到精通。 素数(质数):只能被 1 和它本身整除的数称作素数,如…

总结二:linux面经

文章目录 1、 Linux中查看进程运行状态的指令、查看内存使用情况的指令、tar解压文件的参数。2、文件权限怎么修改?3、说说常用的Linux命令?4、说说如何以root权限运行某个程序?5、 说说软链接和硬链接的区别?6、说说静态库和动态…

(四)正点原子STM32MP135移植——u-boot移植

一、概述 u-boot概述就不概述了,u-boot、kernel、dtb三件套,dddd 经过国庆艰苦奋战,已经成功把所有功能移植好了 二、编译官方代码 进入u-boot的目录 2.1 解压源码、打补丁 /* 解压源码 */ tar xf u-boot-stm32mp-v2022.10-stm32mp-r1-r0.…

充分理清限制与条件+构造二分图+最小割:ARC142E

https://www.luogu.com.cn/problem/AT_arc142_e 他的充要条件是是什么: a i , a j ≥ m i n ( b i , b j ) a_i,a_j\ge min(b_i,b_j) ai​,aj​≥min(bi​,bj​)存在 a i ≥ m a x ( b i , b j ) a_i\ge max(b_i,b_j) ai​≥max(bi​,bj​) 第一个条件直接预处理一…

Springcloud支付模块

客户端消费者80 order 微服务提供者8001 payment 订单模块可以调动支付模块 步骤: 1、建moudle 2、改写pom 3、写yml 4、主启类 5、业务类

【LinuxC】时间、时区,相关命令、函数

文章目录 一、序1.1 时间和时区1.11 时间1.12 时区 1.2 查看时间时区的命令1.21 Windows1.22 Linux 二、C语言函数2.1 通用2.11 函数简介2.12 数据类型简介 2.2 windows 和 Linux特有函数2.3 C语言示例 一、序 1.1 时间和时区 1.11 时间 时间是一种用来描述物体运动变化的量…

黑马点评-01基于Redis实现短信登陆的功能

环境准备 当前模型 nginx服务器的作用 手机或者app端向nginx服务器发起请求,nginx基于七层模型走的是HTTP协议,可以实现基于Lua直接绕开tomcat访问Redis nginx也可以作为静态资源服务器,轻松扛下上万并发并负载均衡到下游的tomcat服务器,利用集群支撑起整个项目 使用nginx部…

黑马JVM总结(二十七)

(1)synchronized代码块 synchronized代码块的底层原理,它是给一个对象进行一个加锁操作,它是如何保证如果你出现了synchronized代码块中出现了问题,它需要给这个对象有一个正确的解锁操作呢,加锁解锁是成对…