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

news2024/9/20 2:48:01

目录

 

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.coloradmin.cn/o/1612060.html

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

相关文章

OpenCV基本图像处理操作(十)——图像特征harris角点

角点 角点是图像中的一个特征点,指的是两条边缘交叉的点,这样的点在图像中通常表示一个显著的几角。在计算机视觉和图像处理中,角点是重要的特征,因为它们通常是图像中信息丰富的区域,可以用于图像分析、对象识别、3D…

小而强,大不同:小模型SLM在人工智能时代的影响

小模型的优势越来越明显了 在人工智能领域的竞赛中,小型语言模型(SLM)正在崛起,挑战传统观念。虽然大型语言模型(LLM)曾占据主导地位,但SLM凭借其小巧、高效和适应性强的优势,正在推…

【php开发工程师系统性教学】——Laravel框架(验证码)的配置和使用的保姆式教程

👨‍💻个人主页:开发者-曼亿点 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 曼亿点 原创 👨‍💻 收录于专栏&#xff1a…

决策树分类任务实战(python 代码详解)

目录 一、导入库、数据集、并划分训练集和测试集 二、参数调优 (一)第一种调参方法:for循环 (1)单参数优化 ①单参数优化(无K折交叉验证) ②单参数K折交叉验证 优化 (2)多参数优化 ①多参数优化(无K折交叉验证) 参数介绍: ②多参数K折交叉验证…

博客网站/部署服务器---继上篇前端页面接入后端

目录 准备工作 创建用户类博客类与连接数据库 创建博客类 创建用户类 创建连接数据库工具类 实现对数据库数据博客的操作 实现对数据库用户的操作 创建数据库语句 登录页面 前端 后端 博客列表 前端 注销登录 写入数据 判断用户是否登录 替换页面用户昵称 后…

C语言中的控制语句(循环语句while、for)

循环语句 什么是循环 重复执行代码 为什么需要循环循环的实现方式 whiledo...whilefor while语句 语法格式&#xff1a; while (条件) {循环体…… } 需求&#xff1a;跑步5圈 示例代码&#xff1a; #include <stdio.h>int main() {// 需求跑步5圈// 1. 条件变量的…

C语言 逻辑运算符

本文 我们来说 逻辑运算符 有时做出决策需要测试多个条件&#xff0c;C语言提供了用于将简单条件组合成复杂条件的逻辑运算符。 逻辑运算符 如下图 用逻辑运算符连接操作数组成的表达式称为逻辑表达式。 逻辑运算的结果只有0和1 逻辑运算的对象可以是任意数值型&#xff0c;但…

Axure RP 9中文激活版:专业原型设计工具mac/win

Axure RP 9是一款由美国Axure Software Solution公司开发的专业原型设计工具。它凭借强大的交互功能和丰富的设计素材&#xff0c;为产品经理、UI设计师、交互设计师等用户提供了高效、便捷的原型设计体验。 Axure RP 9支持快速创建线框图、流程图、原型和规格说明文档&#xf…

过零可控硅光耦与随机可控硅光耦

无过零检测 推荐型号 MOC3021无过零检测 对应的数据手册 原理框图 工作电流 过零检测 推荐型号 MOC3061 原理框图 工作电流 注意事项 随机导通型是随时打开的。都是过零时关闭 也即是说&#xff1a;过零型打开的都是一个馒头波。 参考链接 过零可控硅光耦怎么用-电路知识干…

大屏-flex布局

<div class"container"><div class"title">标题</div><div class"content"><div class"item"></div><div class"item" style"width: calc((100% - 30) / 3 * 2)"><…

Vue报错 Cannot read properties of undefined (reading ‘websiteDomains‘) 解决办法

浏览器控制台如下报错&#xff1a; Unchecked runtime.lastError: The message port closed before a response was received. Uncaught (in promise) TypeError: Cannot read properties of undefined (reading websiteDomains) at xl-content.js:1:100558 此问题困扰了…

Fannel和Calico

一 1、路由器下面每一个端口都是一个vlan,隔离了广播包 192.168.1.0和192.168.2.0他们属于不同的vlan,没有三层交换机或者路由器,他们通不了信 不在同一个vlan,也就是子网,包就会走向网关(也就是路由器那里,路由器有路由表。查看目的地192.168.2.0在b口,从b口出去vlan…

深度学习--CNN卷积神经网络(附图)

框架 让我们先看一下CNN的框架 卷积层中后是ReLu激活函数 &#xff0c;然后是深化池&#xff0c;之后是全连接&#xff0c;最后进行Softmax进行归一化。 所以&#xff0c;我们先逐一了解一下它们各个部分 全连接层 全连接层也称感知机&#xff0c;BP神经网络 全连接层&…

20240330-2-XGBoost面试题

XGBoost面试题 1. RF和GBDT的区别 相同点&#xff1a; 都是由多棵树组成&#xff0c;最终的结果都是由多棵树一起决定。 不同点&#xff1a; 集成学习&#xff1a; R F RF RF属于 B a g g i n g Bagging Bagging思想&#xff0c;而 G B D T GBDT GBDT是 B o o s t i n g Bo…

节点加密技术:保障数据传输安全的新利器

随着信息技术的快速发展&#xff0c;网络数据的安全传输问题日益凸显。节点加密技术作为一种新兴的加密手段&#xff0c;正逐渐成为保障数据传输安全的重要工具。本文将探讨节点加密技术的原理、应用及其优势&#xff0c;并分析其未来的发展趋势。 节点加密技术的原理 节点加密…

EI级 | Matlab实现VMD-TCN-LSTM-MATT变分模态分解卷积长短期记忆神经网络多头注意力多变量时间序列预测

EI级 | Matlab实现VMD-TCN-LSTM-MATT变分模态分解卷积长短期记忆神经网络多头注意力多变量时间序列预测 目录 EI级 | Matlab实现VMD-TCN-LSTM-MATT变分模态分解卷积长短期记忆神经网络多头注意力多变量时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.Matl…

(助力国赛)美赛O奖数学建模可视化!!!含代码2(箱型图、旭日图、直方图、三元图、平行坐标图、密度图、局部放大图)

众所周知&#xff0c;数学建模的过程中&#xff0c;将复杂的数据和模型结果通过可视化图形呈现出来&#xff0c;不仅能够帮助我们更深入地理解问题&#xff0c;还能够有效地向评委展示我们的研究成果。   今天&#xff0c;承接《可视化代码1》&#xff0c;作者将与大家分享《…

@reduxjs/toolkit进阶指南

虽然reduxjs/toolkit为Redux提供了开箱即用的最佳实践,但它也内置了一些强大的功能,可以极大简化Redux在复杂场景下的使用。本文将重点介绍以下进阶特性: 1.使用Immer简化不可变更新 Redux要求状态更新必须是不可变的,这意味着我们需要手动复制和更新数据,这种模式很容易出错…

Ubuntu 微调训练ChatGLM3大语言模型

Ubuntu 微调训练ChatGLM3大语言模型 LLaMA Factory 的 LoRA 微调提供了 3.7 倍的加速比&#xff0c;同时在广告文案生成任务上取得了更高的 Rouge 分数。结合 4 比特量化技术&#xff0c;LLaMA Factory 的 QLoRA 微调进一步降低了 GPU 显存消耗。 https://github.com/hiyouga…

天星金融(原小米金融)履行社会责任,提高社保政策知晓度

二十大报告指出“为民造福是立党为公、执政为民的本质要求“&#xff0c;人民幸福安康是推动高质量发展的最终目的。社会保障作为维护社会公平、增进人民福祉的基本制度&#xff0c;既是“安全网”也是“稳定器”&#xff0c;发挥着改善民生的重要作用。为进一步提升人民群众对…