计算机组成原理【CO】Ch7 I/O大题

目录

 

I/O大题解题方法

I/O接口

各种I/O方式的特点

 I/O端口编址

程序查询方式

中断控制方式 

DMA控制方式

程序中断的工作流程

程序中断的工作流程

DMA方式和中断方式的区别

 

 


I/O大题解题方法

CPU

  • 程序查询
  • 中断
  • DMA

I/O接口的类型

  • 按字传输:每次传输一个字
    • 程序查询
    • 中断
  • 按块传输:每次传输一整块
    • DMA

设备

  • 霸道总裁型:
    • IO设备按自己的节奏往IO缓冲区冲入数据
    • 如果CPU不及时取走数据,就可能会导致数据的丢失
  • 乖乖听话型:
    • IO设备会根据CPU的指挥,往IO缓冲区冲入数据
    • CPU从缓冲区中取走一个字的数据后,会指挥IO设备输入下一个字的数据,不会有数据丢失的问题

传输总线

  • 并行:多位一起传
  • 串行:
    • 一位一传
    • 可能会有附加的校验位、起始位、结束位

CPU每次介入的动作

  • 程序查询方式
    • 每次检查IO接口的数据是否准备完毕
    • 一次程序查询的时间开销:需要执行多少指令?需要多少个时钟周期?
    • CPU的介入频率
      • 取决于查询程序上CPU的时间频率
  • 中断控制方式
    • 中断响应(隐指令)
      • 时间开销
      • 通常以时钟数作为条件
    • 中断服务程序
      • 时钟数
      • 指令总数、结合CPI
    • CPU介入的频率
      • 取决于IO接口发来中断的频率
  • DMA控制方式
    • 预处理
      • 让DMA接口输入一块数据
    • 后处理
      • 一整块数据传输完成后DMA接口给CPU中断,CPU处理中断
    • CPU介入的频率
      • 每传一块介入一次

数据丢失问题

  • 程序查询方式
    • 当IO接口缓冲区大小有限时,每一次数据冲入后,CPU都需要及时把数据取走,防止丢失
    • 若CPU每次查询的时间开销太久,跟不上数据冲入的速度,则数据可能丢失
  • 中断控制方式
    • 判断是否会数据丢失:中断处理的时间总共花了多少?是否大于IO接口冲入一次数据的时间?
    • 若中断处理的时间太久,可能导致IO接口数据被覆盖
  • DMA控制方式
    • 不会数据丢失,DMA接口的总线使用优先级高

I/O接口

I/O接口【也叫I/O控制器】

I/O接口的功能

  • 地址译码、设备选择:通过CPU中来的外设的地址码,找到指定的设备
  • 主机和外设的通信联络控制:时序配合,协调不同工作速度的外设和主机之间交换信息
  • 数据缓冲:CPU与外设之间的速度不匹配,设置数据缓冲寄存器,避免丢失数据
  • 信号格式的转换:电平转换、串/并转换、数/模转换
  • 控制命令、状态信息
    • CPU要启动外设时,通过I/O接口重点命令寄存器向外设发出启动命令
    • 外设准备就绪后,将“准备好”的转台信息送回I/O接口中的状态寄存器,并反馈给CPU

I/O接口的基本结构

  • 端口(Port):接口电路中可以进行读写的寄存器
  • 接口(Interface):若干端口加上相应的控制逻辑
  • I/O指令:对数据缓冲寄存器、状态/控制寄存器的进行访问操作的指令
    • 只能在OS内核的底层I/O软件中使用
    • I/O指令实现的数据传送通常发生在通用寄存器和I/O端口之间
    • 是一种特权指令
  • 数据线:【双向传输】
    • 命令字、状态字、中断类型号
    • 外设将状态信息传中到CPU
    • CPU对外设的控制命令
    • 发往CPU的中断类型号
    • 【因为是从外部设备传输到CPU,故只能从数据线传输】
  • 地址线:【单向传输】
    • 要访问的I/O接口中的寄存器的地址
  • 控制线:【单向传输】
    • 仲裁信号
    • 握手信号
  • I/O总线:
    • 控制线、地址线:单向传输,从CPU传送给IO接口
    • 数据线:双向传输,命令字、状态字、中断类型号均是IO接口发往CPU

I/O接口的类型

按数据传输方式分

📢接口要完成数据格式的转换

📢这里的数据传送方式是指外设和接口一侧的传送方式

  • 并行接口:一个字节或一个字的所有位同时传送
  • 串行接口:一位一位地传送

按主机访问I/O设备的控制方式分

  • 程序查询接口
  • 中断接口
  • DMA接口

按功能选择的灵活性分

  • 可编程接口
  • 不可编程接口

 

常见的I/O接口:打印机适配器、网络控制器、可编程中断控制器

各种I/O方式的特点

程序查询

完全采用软件的方式实现。

中断方式

通过中断服务程序实现数据传送,但中断处理需要相关硬件的实现。

DMA方式

完全采用硬件控制数据交换的过程。

通道

采用软硬件结合的方法,通过执行通道程序(由通道指令组成)控制数据交换的过程。

 I/O端口编址

 

统一编址(存储器映射方式)

独立编址(I/O映射方式)

定义

  • 把I/O端口当做存储器的单元进行地址分配
  • CPU不需要设置专门的I/O指令,用统一的访存指令就可以访问I/O端口
  • I/O端口的地址空间与主存地址空间无法从地址码的形式上区分
  • 需要设置专门的I/O指令来访存I/O端口

特点

  • 依靠地址码的不同区分存储单元和I/O设备
  • 通过专门的I/O指令来区分存储单元和I/O设备

优点

  • 不需要专门的I/O指令
  • 可以使CPU访问I/O的操作更灵活、更方便
  • 还可以使端口有较大的编址空间
  • 输入/输出指令与存储器指令有明显区别
  • 程序编制清晰,便于理解

缺点

  • 端口占用存储器地址,使内存容量变小
  • I/O设备进行数据输入/输出操作时,执行速度较慢
  • 输入/输出指令少,一般只能对端口进行传送操作
  • 尤其需要CPU提供存储器读/写、I/O设备读/写两组控制信号增
    加了控制的复杂性

程序查询方式

  • 程序查询方式
    • 每次检查IO接口的数据是否准备完毕
    • 一次程序查询的时间开销:需要执行多少指令?需要多少个时钟周期?
    • CPU的介入频率
      • 取决于查询程序上CPU的时间频率

中断控制方式 

  • 中断控制方式
    • 中断响应(隐指令)
      • 时间开销
      • 通常以时钟数作为条件
    • 中断服务程序
      • 时钟数
      • 指令总数、结合CPI
    • CPU介入的频率
      • 取决于IO接口发来中断的频率

DMA控制方式

  • DMA控制方式
    • 预处理
      • 让DMA接口输入一块数据
      • 数据传输前由DMA控制器请求总线的使用权
    • 数据传输:
      • DMA控制器直接控制总线完成
    • 后处理
      • 一整块数据传输完成后DMA接口给CPU传递中断信号,CPU处理中断
    • CPU介入的频率
      • 每传一介入一次
  • DMA请求 VS DMA中断:
    • 缓冲区充满请求一次
    • 一整块传输完中断一次

程序中断的工作流程

程序中断的工作流程

  • 中断请求
  • 中断响应判优
    • ⚠️中断的响应判优是硬件排队器实现的,是固定
    • 中断的处理优先级可以通过中断屏蔽技术动态调整
  • CPU响应中断的条件
  • 中断响应的过程:

DMA方式和中断方式的区别

DMA

中断方式

DMA方式靠硬件传送

中断方式靠程序【软件】传送

请求的是总线的使用权

请求的是CPU处理时间

DMA方式除了预处理和后处理,其他时候不占用CPU资源

中断方式是程序的切换,需要保护和恢复现场

对DMA请求的响应可以发生在每个机器周期结束时在取指周期、间址周期、执行周期后都可以【一个总线事务后】

对中断请求的响应只能发生在每条指令执行完毕时

即指令的执行周期后

DMA传送过程不需要CPU的干预,因此数据传输率非常高,适合于高速外设的成组数据传送

中断传送过程需要CPU的干预

DMA方式仅局限于传送数据块的I/O操作

中断方式具有对异常事件的处理能力

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

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

相关文章

【C++】日期类Date(详解)

🔥个人主页:Forcible Bug Maker 🔥专栏:C 目录 前言 日期类 日期类实现地图 获取某年某月的天数:GetMonthDay 检查日期合法,构造函数,拷贝构造函数,赋值运算符重载及析构函数…

【数据结构2-线性表】

数据结构2-线性表 1 线性表-数组2 线性表-单链式结构2.1 前插顺序单链表2.2 后插顺序单链表2.3 循环单链表2.4 双向链表 总结 线性表、栈、队列、串和数组都属于线性结构。 线性结构的基本特点是除第一个元素无直接前驱,最后一个元素无直接后继之外,其他…

.net反射(Reflection)

文章目录 一.概念:二.反射的作用:三.代码案例:四.运行结果: 一.概念: .NET 反射(Reflection)是指在运行时动态地检查、访问和修改程序集中的类型、成员和对象的能力。通过反射,你可…

【游戏专区】飞机大战

打过飞机的人都知道,不是那么好打滴,求得麻袋,甩掉你那脑子里的黄色信息。活不多说,我们开始吧。 1、easyX的原理 基于Windows图形编程,将Windows下的复杂程序过程进行封装,仅给用户提供一个简单熟悉的接…

21.组件组成

组件组成 组件最大的优势就是可复用性 当使用构建步骤时&#xff0c;我们一般会将 Vue 组件定义在一个单独的 .vue 文件中&#xff0c;这被叫做单文件组件(简称 SFC) 组件组成结构 <template><div>承载标签</div> </template> <script> expor…

【软件测试】正交表测试例题

【软件测试】正交表测试 例题1答案 例题2答案 例题3答案 例题1 很多Word编辑器都有字体修饰功能&#xff0c;可以将一个字加粗、倾斜、以及加上下划线。一个字可以同时被加粗和倾斜&#xff0c;也可以同时被倾斜和加下划线。三种因子Bold, Italic, Underline的效果可以任意组合…

计算机组成原理【CO】Ch3 存储系统

文章目录 考纲3.1 存储系统概述3.2 主存储器3.3 主存储器与CPU的连接3.4 外部存储器3.5 高速缓冲存储器3.6 虚拟存储器 【※】存储系统总体流程图【※】各个部件的存储位置计算机存储相关硬件与数据结构说明进程控制块&#xff08;PCB&#xff09;页表页表始址页表始址寄存器&a…

传感器融合 | 适用于自动驾驶场景的激光雷达传感器融合项目_将激光雷达的高分辨率成像+测量物体速度的能力相结合

项目应用场景 面向自动驾驶场景的激光雷达传感器融合&#xff0c;将激光雷达的高分辨率成像测量物体速度的能力相结合&#xff0c;项目是一个从多个传感器获取数据并将其组合起来的过程&#xff0c;可以更加好地进行环境感知。项目支持 ubuntu、mac 和 windows 平台。 项目效果…

CGLIB动态代理

文章目录 前言概要SpringBoot中使用小结 前言 当我们需要在Java中实现动态代理时&#xff0c;通常会考虑使用 JDK原生动态代理 或者 CGLIB动态代理。 我这里说一下CGLIB动态代理&#xff0c;并给出一个例子。 概要 CGLIB&#xff08;Code Generation Library&#xff09;是一…

ROS分布式通讯配置

4WD 必读&#xff1a;分布式通讯是相对于用虚拟机来连接小车上主机来说&#xff0c;如果是 4WD 笔记本无主 机用户&#xff0c;不存在分布式通讯一说。 1.4WD 用户单笔记设置一&#xff0c;连接底盘和雷达还有摄像头。 因为虚拟机带宽问题&#xff0c;无法保证摄像头正常运行。…

初始ansible变量及实例配置

目录 1、为什么要使用变量 2、变量分类 3、 变量详解 3.1 vars,vars_files , group_vars 3.1 .1 vars 剧本中定义变量 3.1.2 vars_file 将变量存放到一个文件中&#xff0c;并在剧本中引用 3.1.3 group_vars 创建一个变量文件给某个组使用 实例1-根据不同的主机…

云手机助力舆情监测,智慧引领信息时代

随着信息时代的到来&#xff0c;舆情监测已成为政府、企业、高校、金融机构等各行业的必备利器。在这个信息爆炸的时代&#xff0c;如何及时准确地感知民意、把握市场动态&#xff0c;已成为各界迫切需要解决的问题。而云手机作为信息时代的新生力量&#xff0c;在舆情监测方面…

Python 数据结构和算法实用指南(四)

原文&#xff1a;zh.annas-archive.org/md5/66ae3d5970b9b38c5ad770b42fec806d 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 第十二章&#xff1a;字符串算法和技术 根据所解决的问题&#xff0c;有许多流行的字符串处理算法。然而&#xff0c;最重要、最流行和最有…

代码随想录阅读笔记-回溯【重新安排行程】

题目 给定一个机票的字符串二维数组 [from, to]&#xff0c;子数组中的两个成员分别表示飞机出发和降落的机场地点&#xff0c;对该行程进行重新规划排序。所有这些机票都属于一个从 JFK&#xff08;肯尼迪国际机场&#xff09;出发的先生&#xff0c;所以该行程必须从 JFK 开…

【1569】jsp学生学籍管理系统Myeclipse开发sqlserver数据库web结构jsp编程计算机网页项目

一、源码特点 jsp 学生学籍管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为sqlserver2…

MYSQL之增删改查(中)

前言&#xff1a; 以下是MySQL最基本的增删改查语句&#xff0c;很多IT工作者都必须要会的命令&#xff0c;也 是IT行业面试最常考的知识点&#xff0c;由于是入门级基础命令&#xff0c;所有所有操作都建立在单表 上&#xff0c;未涉及多表操作。 4、“查”——之单表查询 My…

Gamba:将高斯溅射与Mamba结合用于单视图3D重建

Gamba: Marry Gaussian Splatting with Mamba for Single-View 3D Reconstruction Gamba&#xff1a;将高斯溅射与Mamba结合用于单视图3D重建 Qiuhong Shen11  Xuanyu Yi31 Zike Wu31  Pan Zhou2,42 Hanwang Zhang3,5 沈秋红 1 易轩宇 3 吴子可 3 潘周 2,4 2 张汉旺 3,5Shu…

C语言开源库iniparser解析ini文件

1 ini文件介绍 INI&#xff08;Initialization File&#xff09;文件是一种简单直观的数据存储格式&#xff0c;常用于配置应用程序的初始化设置。这种文件通常包含若干个节&#xff08;section&#xff09;和键值对&#xff08;key-value pairs&#xff09;。INI文件的每一部…

Spring AOP(面向切面编程)

1.Spring AOP 简介 1.1 AOP概述 AOP 为 Aspect Oriented Programming 的缩写&#xff0c;意思为面向切面编程, 是通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP 是 OOP 的延续&#xff0c;是Spring框架中的一个重要内容&#xff0c;是函数式编程的一…

FPGA Quartus IP核 打开使用

两种Quartus版本下的IP核&#xff0c;从使用者的角度来看仅仅是配置界面不同&#xff0c;在参数设置和使用方法上基本一致。本文以“MegaWizard Plug-In Manager”中的FIR Compiler IP核使用为例。 Quartus的FIR IP核属于收费IP&#xff0c;如果是个人学习使用需要对IP核单独破…