I/O系统:I/O设备,I/O接口,I/O端口的编址,I/O指令、通道指令,I/O控制方式 ,补充:中断

news2025/1/10 20:26:10

I/O:Input / Output,即输入/输出。

I/O系统一般由I/O硬件(I/O设备,I/O接口,I/O总线等)和I/O软件(驱动程序,用户程序,管理程序,升级补丁等)构成。通常计算机系统中把CPU和主存之外的部分称为输入输出系统。

 I/O总线

I/O总线:主机和I/O设备之间的总线连接。

总线相关的内容,可参考:总线

I/O设备

I/O设备:可以将数据输入到计算机,也可以接收计算机输出数据的外部设备(简称外设)。

常见I/O设备:输入设备(鼠标,键盘),输出设备(显示器,打印机等),外存储器(简称外存,硬盘,光盘等)。

其中:显示器(阴极射线管CRT显示器、液晶LCD显示器、LED显示器)

显示器的性能指标:

  • 屏幕大小:以对角线长度表示。
  • 分辨率:像素个数。屏幕上一个光点就是一个像素。宽的像素 * 高的像素。
  • 灰度级:黑白显示器(例如:kindle)所显示的像素点的亮暗差别;彩色显示器所表现的颜色的不同。灰度级越高,图像层次越清楚逼真。灰度级位数n,则亮度或颜色eq?2%5E%7Bn%7D种。
  • 刷新频率:单位时间内扫描整个屏幕内容的次数。通常显示器刷新频率在60~120Hz。刷新频率超过30Hz才不会感到闪烁。(因光点很快消失,需在消失前重新扫描显示,即刷新)
  • 显示存储器(VRAM):刷新存储器。存储容量由图像分辨率和灰度级决定。至少存储一帧图像信息。

        VRAM容量 =  分辨率 * 灰度级位数。

        VRAM带宽 =  分辨率 * 灰度级位数 * 帧频。

I/O设备由机械部件和电子部件组成。

I/O设备的机械部件主要用于执行具体的I/O操作。CPU不能直接控制I/O设备的机械部件。

I/O设备的电子部件是I/O接口,介于主机和I/O设备的机械部件之间,用于实现CPU对设备的控制(CPU控制I/O接口,I/O接口控制I/O设备的机械部件)。

I/O接口(又称I/O控制器、设备控制器)

主机和I/O设备的数据传送,通过I/O接口实现。

I/O接口种类很多,也会制定相应的标准。大部分I/O接口是可编程的。

I/O接口可能是串行接口(一位一位数据传送,例如USB),也可能是并行接口(多位数据同时传送)。

I/O接口是块芯片,常集成在主板上,通过总线(地址总线、数据总线、控制总线)与主机连接。也有的I/O接口集成在南桥芯片(桥接器)中。

I/O接口中包含一系列寄存器(数据缓冲寄存器、控制寄存器、状态寄存器等)。

I/O接口的功能:

  • 缓冲数据:CPU速度快,I/O设备速度慢,为了缓解两者速度的矛盾,因此需I/O接口中的数据缓冲寄存器暂存需传送的数据。
  • 数据格式转换:因为CPU到I/O接口大多为并行,也可能串行;外部设备到I/O接口可能串行也可能并行,因此需I/O接口中的串-并转换机构负责数据格式转换(串行-并行转换)。
  • 检测状态和错误:检测设备的状态和错误信息,以便CPU查询。
  • 接收并识别CPU发出的命令。
  • 地址译码和设备选择功能。
  • 控制逻辑,如中断、DMA控制逻辑(允许产生DMA请求信号并在响应后完成DMA传输)、设备操作等。

CPU --> I/O接口:

  • CPU通过控制总线向I/O接口发送命令、时钟信号等。
  • CPU通过地址总线向I/O接口指明I/O端口。
  • CPU通过查询I/O接口的状态寄存器来获取外部设备的状态或错误。
  • (向I/O设备写数据)CPU通过数据总线向I/O接口的数据缓冲寄存器传送数据;(从I/O设备读数据)CPU通过数据总线从I/O接口的数据缓冲寄存器接收数据存入主存。

I/O接口:

  • I/O接口通过控制总线向CPU反馈中断请求信号。
  • I/O接口通过数据总线向CPU传送中断类型号。
  • I/O接口通过地址译码逻辑电路将地址信号映射到指定端口。
  • I/O接口通过I/O控制逻辑电路根据控制字(命令字,即CPU对设备发出的具体命令)向设备发出控制信号。
  • (向I/O设备写数据)将I/O接口中的数据缓冲寄存器的数据写入外部设备;(从I/O设备读数据)外部设备向I/O接口的数据缓冲寄存器传送数据。

注:控制寄存器和状态寄存器因时间错开,有些I/O接口中控制寄存器和状态寄存器为同一个寄存器。

一个IO接口可以对应一个或者多个设备,每个设备可以有自己的一组寄存器(数据寄存器、控制寄存器、状态寄存器)。CPU通过控制不同组的寄存器,来控制不同的设备。

I/O接口中能被CPU直接访问的寄存器称为I/O端口(PORT)。 

I/O端口主要有数据端口、控制端口和状态端口,若干端口加上相应的控制逻辑电路组成接口。

一般CPU能对数据端口执行读写操作,对控制端口只能执行写操作,对状态端口只能执行读操作。

4f9fa0e6ea15491292e28592830c4f4f.png

I/O端口的编址

一个I/O端口对应一个或一组寄存器,都有各自的编号(即地址)。

I/O端口的编址方式:统一编址,独立编址。

(1)统一编址:将I/O端口当做主存单元进行地址分配。将主存划分出一部分作为I/O端口的地址空间。也称为存储器映射方式。一般用于单总线结构的计算机系统中。

        统一的访存指令。访问主存的指令都可以访问I/O端口。使用不同的地址码区分主存和I/O端口。

        控制电路简单,程序设计较灵活,端口有较大编址空间,但占用主存地址空间,地址位数多,译码速度慢。

(2)独立编址:I/O端口的地址和主存地址是相互独立的。也称为I/O映射方式。

        专门的I/O指令访问I/O端口。使用不同的指令区分内存和I/O端口。在X86中,I/O指令有IN、OUT、INS、OUTS。

        有专门的I/O指令,程序清晰,不占用主存地址空间,地址位数少,译码速度快,但控制电路复杂,I/O指令少,程序设计灵活性差。

I/O指令,通道指令

通常,CPU通过I/O指令,访问I/O端口,从而实现主机和外部设备之间的数据传送。

有通道的系统中,CPU通过I/O指令启动/停止设备、控制通道等,通道通过通道指令完成主机和设备之间的数据传送。

I/O指令:CPU指令的一部分。I/O指令是只能在操作系统内核使用的特权指令。

格式:操作码、命令码、设备码。

  • 操作码:识别是否是I/O指令。
  • 命令码:执行什么操作。
  • 设备码:对哪个设备执行操作。

通道指令:通道能识别的指令。

通道指令序列组成通道程序,通道程序提前编制好存放在内存中。

CPU通过I/O指令向通道发出命令(通道程序在内存中的位置、哪个设备等),通道识别并执行一系列通道指令,代替CPU对I/O设备进行统一管理。

I/O控制方式 

外部设备(外设)和主机之间的输入/输出控制方式:程序查询方式,程序中断方式,DMA方式,通道控制方式等。

(1)程序查询方式:也称为程序直接控制方式。

  • CPU启动I/O设备后,不断循环查询I/O设备的状态,等到I/O设备数据准备好,进行数据传送(一般每次传送一个字)。

CPU和I/O设备只能串行工作。CPU不断轮询检查设备状态,长时间处于忙等状态,CPU利用率低。

注:从外部设备读数据时,CPU从I/O接口中的数据缓冲寄存器将数据读入CPU寄存器,再将CPU寄存器中的内容写入主存。

ab6a4687748145b6ab080393ba04e7b1.png​ 

3fe2ba5084044b1e82e0fc6099a3204e.pngc6e86fa8c6eb41c391c896454f6dac86.png

(2)程序中断方式:也称中断驱动方式。

  1. CPU启动I/O设备后,CPU继续执行当前程序;
  2. I/O设备准备好数据后,向CPU发出中断请求,CPU响应请求则暂停当前程序,开始处理中断服务程序(I/O设备与主机之间的数据传送);
  3. CPU处理完中断,CPU再继续执行被暂停的程序。

CPU和I/O设备可并行工作,提高CPU的工作效率,但要每个设备分配相应的中断请求号和中断服务程序,以及增加中断控制器,且每准备好一个字就发出一次中断请求,降低系统性能。

字符设备常采用中断方式。字符设备:以字符或字节为单位进行数据传送的设备,传输速率慢,不可寻址,例如:鼠标,键盘。

da07dac0c85542eaa9922e4fe2d6c5fd.png

7ecd4c432d444407a80530ed0e0fc1f2.png

(3)DMA方式:需要DMA控制器(又称DMA接口,一种I/O接口,连接高速设备、块设备)。

DMA,Direct Memory Access,直接主存访问。

块设备:以“块”为单位进行数据传送的设备,传输速率较快,可寻址,例如:磁盘。

DMA方式,数据传送时是由DMA控制器控制不需要CPU干预,CPU只涉及开始时向DMA控制器发出命令、数据传送完处理中断请求。

进一步提高CPU和I/O设备的并行性。但对于多个离散的数据块,CPU需发出多次I/O指令、处理多次中断请求。

a6b6908274194a8a8845a507588b38d9.png

【单总线结构】以从I/O设备读数据为例:

  1. CPU启动I/O指令将主机地址、外部设备地址、数据长度等传送到DMA控制器,CPU仍执行当前程序;
  2. I/O设备将数据暂存在DMA控制器的数据缓冲寄存器,每准备好一个字,向DMA控制器发出一次DMA请求;
  3. DMA控制器向CPU申请总线,CPU将总线控制权交给DMA控制器;
  4. DMA控制器控制I/O设备与主机之间数据传送(每次传送一个字,此时CPU不能使用总线不能访问主存);
  5. 一整块或多个连续块的数据传送完,DMA控制器才向CPU发出一次中断请求表明数据已传送完;
  6. CPU响应并处理中断请求。

【三总线结构】以从I/O设备读数据为例:

  1. CPU启动I/O指令将主机地址、外部设备地址、数据长度等传送到DMA控制器,CPU仍执行当前程序;
  2. I/O设备将数据暂存在DMA控制器的数据缓冲寄存器,每准备好一个字,向DMA控制器发出一次DMA请求;
  3. DMA控制器花费一个存取周期通过专门的DMA总线控制I/O设备和主存之间的数据传送(每次传送一个字,此时CPU不能访问主存);
  4. 一整块或多个连续块的数据传送完,DMA控制器才向CPU发出中断请求表明数据已传送完;
  5. CPU响应并处理中断请求。

【三总线结构】CPU和DMA控制器都有专门的总线访问主存,在访存时可能产生冲突。

CPU和DMA控制器访问主存的方式:

  1. DMA控制器传送一整块数据时CPU都不能访问主存,CPU利用率不高;
  2. DMA控制器和CPU交替访问主存,硬件逻辑复杂;
  3. 存取周期挪用:CPU访问主存时DMA控制器等待,CPU不访问主存(或存取周期结束后)DMA控制器访问主存,若同时访问则DMA控制器先访问主存(I/O访存优先)。

​(4)通道控制方式:需要硬件设备通道,通道程序提前编制好存放在主存中。

通道控制方式,数据传送时是由通道控制不需要CPU干预,CPU只涉及开始时向通道发出命令、数据传送完处理中断请求。

【双总线结构】

  1. CPU向通道发送I/O指令(通道程序在内存中的位置、哪个设备等),CPU仍执行当前程序;
  2. 通道执行内存中通道程序的一系列通道指令,控制I/O设备完成数据传送;
  3. 通道执行完规定的任务后(即传送完一组数据块),向CPU发出中断请求;
  4. CPU响应并处理中断请求。

补充:中断

中断:多道程序中,程序执行过程中,因某些情况,CPU暂停当前程序,去处理其他程序,处理完,再继续原程序。

引起中断的事件称为中断源。即可以产生中断请求信号的部件为中断源。

中断源向CPU 发出中断请求信号称为中断请求。

发生中断时被打断程序的暂停点称为断点。

CPU暂停当前程序而转为响应中断请求的过程称为中断响应。

处理中断源的程序称为中断处理程序。

CPU执行有关的中断处理程序称为中断处理。

返回断点的过程称为中断返回。

中断分类:内中断,外中断(狭义上的中断)。

e5890d07cf1247818cbc16feee3795f0.png

CPU响应中断必须满足的条件:

(1)有中断源发出中断请求,

(2)CPU处于开中断状态(即允许中断),

(3)一条指令执行完并且没有更紧急的任务。

CPU响应中断的时间:

每条指令执行阶段的结束时刻。

(每条指令执行阶段结束前,CPU向接口发出中断查询信号以获取I/O的中断请求)

中断判优:多个中断源同时发出中断请求时,通过中断判优逻辑(优先级)响应一个中断源。可由硬件实现(硬件排队器)也可由软件实现(查询程序)。通常使用硬件排队器来实现中断判优。

3acf78ec6d5b48c292ba427163c381cb.pnge9df7c2aecfc4c42b30dfefef48a5446.png

中断处理过程(CPU执行):中断隐指令,中断服务程序。

中断隐指令:

  • 关中断(确保在中断服务程序时,保护中断现场或恢复中断现场不被新的中断打断,中断处理完可以回到原程序正确执行下去),
  • 保存断点(用堆栈或特定存储单元保存当前程序的PC值即程序计数器的内容,保证中断处理后能正确返回原程序),
  • 引出中断服务程序(硬件排队器择优后,通过中断向量地址形成部件映射到对应的向量地址即中断类型号,根据向量地址对应的无条件转移指令(JMP指令)的中断向量,获得中断服务程序的入口地址并传送给PC)。

7203f6f741454baea575dbb117e95500.png

中断服务程序:

  • 保护现场(用堆栈或特定存储单元保存通用寄存器和状态寄存器的内容,保证返回原程序时恢复中断时的CPU环境),
  • 中断服务(设备服务,即操作系统内核处理中断),
  • 恢复现场(通过出栈指令或取数指令把之前保存的信息送回到各自寄存器中),
  • 中断返回(通过中断返回指令回到原程序断点处,即把之前保存的PC值即断点送回到PC中)。

4ab5166583b441bfbafabb27a49b3a4c.png

多重中断(中断嵌套):

多重中断:执行中断服务程序时,可响应新的中断请求。但需有选择的响应中断请求。

中断屏蔽:当CPU检测到中断请求时,中断控制器通过中断屏蔽字决定是否响应中断请求。1表示屏蔽该中断源(即不响应该中断源的中断请求),0表示该中断源可正常申请中断。

每个中断源必须屏蔽自身(即不能被自身中断);优先级高的中断源可以中断优先级低的中断源(例如:A的优先级高于B,A执行时,B发出中断请求 将被屏蔽不被响应;若B执行时,A发出中断请求,暂停B执行A即A的中断请求被响应)。

每个中断源都有一个屏蔽触发器,所有屏蔽触发器组合在一起就是屏蔽字寄存器,屏蔽寄存器的内容称为屏蔽字

c80b062cbb5e44568b1c7de40fee10d6.png

47c65248de5d4c9b96da369e3a30ca12.png

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

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

相关文章

基于sd的模特换装

这个领域的核心就是怎么把商品展示出来,商品本身不能发生变化,细节不能乱,模特换装或者虚拟换装,核心不在人,而在于商品,阿里塔玑这种核心在于怎么把平面的2D商品转成一个3D商品图,怎么让模特把…

蒙特卡洛方法使用原理解系-单位圆的面积计算

简介 蒙特卡洛也成为统计模拟方法,提出以概率统计理论为指导的一类非常重要的数值计算方法,是指使用随机数(或者更常见的伪随机数)来解决很多计算问题的方法。蒙特卡罗方法的名字来源于摩纳哥的一个城市蒙特卡罗,该城…

IIO驱动 Industrial I/O(正点原子笔记)

最近看见很多iio 驱动adc,赶紧找来学习一下。 传感器内部都会有ADC,传感器对外提供 IIC或者 SPI 接口,SOC 可以通过 IIC 或者 SPI 接口来获取到传感器内部的 ADC 数值,从而得到想要测量的结果。Linux 内核为了管理这些日益增多的…

恒运资本:港股内房股拉升 融创中国、中国恒大涨超30%

截至发稿,融创我国、我国恒大涨超30%,把戏年控股、天誉置业涨超20%。 9月6日,港股内地房地产板块拉升,截至发稿,融创我国、我国恒大涨超30%,把戏年控股、天誉置业涨超20%,佳兆业集团、富力地产…

springboot实战(六)之mybatis-plus代码自动生成器【重要】

目录 环境: 步骤: 1.添加依赖 2.配置代码 3.运行 测试 1.测试生成的service 1.1、service用法 2.分页查询 2.1、分页插件配置 2.2、测试 3.源码 环境: jdk:1.8 springboot版本:2.7.15 mybatis-plus版本&#xff1…

单片机-蜂鸣器

简介 蜂鸣器是一种一体化结构的电子讯响器,采用直流电压供电 蜂鸣器主要分为 压电式蜂鸣器 和 电磁式蜂鸣器 两 种类型。 压电式蜂鸣器 主要由多谐振荡器、压电蜂鸣片、阻抗匹配器及共鸣箱、外壳等组成。多谐振荡器由晶体管或集成电路构成,当接通电源后&…

Object —— Guide Deform

使用动画skin驱动引导线;;内嵌Guid Deform节点;

Django创建应用、ORM的进阶使用及模型类数据库迁移

1 Django项目创建第一个应用 Django 项目就是基于 Django 框架开发的 Web 应用,它包含了一组配置和多个应用,我们把应用称之为 App,在前文中对它也做了相应的介绍,比如 auth、admin,它们都属于 APP。 一个 App 就是一…

2023高教社杯国赛ABCDE题免费思路预定(MathClub网站汇聚市面的所有资源,注册即送)

目录 引言A题:[题目名称]概述参考思路参考资源 B题:[题目名称]概述参考思路参考资源 结论 作者:MathClub 日期:2023年9月6日 引言 2023年全国大学生数学建模竞赛(高教社杯)即将来临,对于众多数…

ChatGPT:深度学习和机器学习的知识桥梁(文末送书)

🤵‍♂️ 个人主页:艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞&#x1f4…

nodejs+vue+elementui精品课程网站设计

前端技术:nodejsvueelementui基于nodejs语言、vue.js框架、B/S架构、Mysql数据库设计并实现了精品课程网站设计。系统主要包括首页、个人中心、用户管理、课程信息管理、课程分类管理、学习论坛、在线试题管理、试题管理、系统管理、考试管理等功能模块。 本文首先介…

tf和pytorch每轮epoch显示输出的auc是如何计算的

tf和pytorch每轮epoch显示输出的auc是如何计算的? tf的计算 近似 ROC 或 PR 曲线的 AUC(曲线下面积)。 tf1 通过计算真阳性,假阳性,假阴性,真阴性值的计算策略。 tensorflow AUC & streaming_auc_我…

浅谈Spring

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器(框架)。 一、什么是IOC? IoC Inversion of Control 翻译成中⽂是“控制反转”的意思,也就是说 Spring 是⼀个“控制反转”的容器。 1.1控制反转推导 这个控制反转怎…

PHP教学质量评估系统Dreamweaver开发mysql数据库web结构php编程计算机网页代码

一、源码特点 PHP教学质量评估系统是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 代码 https://download.csdn.net/download/qq_41221322/88301983 论文 https://down…

【简单几何】CF Edu11 D

Problem - D - Codeforces 题意&#xff1a; 思路&#xff1a; 和蓝桥杯国赛有道题类似&#xff0c;都是用中点来确定图形防止精度缺失 应该算是典 Code&#xff1a; #include <bits/stdc.h>using i64 long long;constexpr int N 2e3 10; constexpr int M 1e6 1…

stm32(GD32,apm32),开优化后需要特别注意的地方

提到优化就不得不提及 volatile 使用场景 1&#xff1a;中断服务程序中修改的供其它程序检测的变量&#xff0c;需要加volatile&#xff1b; : 2&#xff1a;多任务环境下各任务间共享的标志&#xff0c;应该加volatile&#xff1b; 3&#xff1a;并行设备的硬件寄存器&#x…

干货|数学建模必考的四大模型

数学建模国赛即将开始&#xff0c;小编总结近五年的数学建模ABC题题型&#xff0c;并根据题型总结建模常用的四大模型&#xff0c;如下&#xff1a; A题 一般A题偏物理方面&#xff0c;专业性更强&#xff0c;偏难&#xff0c;新手不建议选择A题&#xff0c;原因在于可能看不…

【ccf-csp题解】第1次csp认证-第四题-无线网络-题解

题目描述 思路讲解 可以把题目抽象为&#xff1a;从第1个点到第2个点&#xff0c;经过特殊点的数量不超过k的单源最短路径&#xff08;其中每条边的权重均为1&#xff09; 可以使用bfs解决这个问题&#xff0c;但是dist[][]数组和队列中放置的pair<int,int>元素不再是单…

【大魔王送书第二期】搞懂大模型的智能基因,RLHF系统设计关键问答

RLHF&#xff08;Reinforcement Learning with Human Feedback&#xff0c;人类反馈强化学习&#xff09;虽是热门概念&#xff0c;并非包治百病的万用仙丹。本问答探讨RLHF的适用范围、优缺点和可能遇到的问题&#xff0c;供RLHF系统设计者参考。 目录 RLHF是什么&#xff1f;…

京东API 接入说明(1688商品详情,关键字搜索商品等)

API地址:https://o0b.cn/anzexi 调用示例&#xff1a;https://api-gw.onebound.cn/jd/item_get/?keytest_api_key& &num_iid10335871600&&langzh-CN&secret 参数说明 通用参数说明 url说明 https://api-gw.onebound.cn/平台/API类型/ 平台&#xff1a;淘…