【操作系统·考研】I/O管理概述

1.I/O设备

1.1 块设备

信息交换以数据块为单位,它属于有结构设备。
块设备传输速率较高,可寻址,且可对该设备随机地的读写。
栗子🌰:磁盘。

1.2 字符设备

信息交换以字符为单位,属于无结构类型。
字符设备传输速率低,不可寻址,并且时长采用中断I/O方式。
栗子🌰:打印机。
image.png

分类

  1. 低速设备:传输速率仅为几B ~ 几百B。如键盘、鼠标等。
  2. 中速设备:传输速率为几KB ~ 几MB。如激光打印机等。
  3. 高速设备:传输速率为数百MB ~ 数十GB。如磁盘机、光盘机等。

字符设备属于独占设备,访问属于互斥访问。

2.I/O接口(设备控制器)

2.1 概述

I/O接口位于CPU与设备之间,它既要与CPU通信,又要与设备进行通信,具有按CPU发来的命令去控制设备工作的功能。

2.2 结构

  • 设备控制器与CPU的接口
    • 三类信号线:数据线、地址线、信号线。
    • 两个寄存器
      • 数据寄存器:存放从设备送来的输入数据或从CPU送来的输出数据。
      • 控制/状态寄存器:存放从CPU送来的控制信息或设备送来的状态信息。
  • I/O逻辑
    • 功能:用于实现对设备的控制。
    • 通过一组控制线对CPU送来的I/O命令进行译码,通过一组地址线对CPU送来的地址进行译码,然后相应地对所选设备进行控制。
  • 设备控制器与设备的接口
    • 由于一个设备控制器可能会与多个设备相连,因此一个设备控制器中可能有多个设备接口。
    • 每个设备接口中存在数据、状态、控制三种类型的信号。

为了便于上层软件的编制,设备控制器通常需要提供控制寄存器、状态寄存器和控制命令。

2.3 功能

  1. 接收和识别CPU送来的命令,如磁盘控制器能接收到读、写、控制等信号。
  2. 数据交换,实现主存 - 设备控制器 - 设备之间的数据传输。
  3. 标识和报告设备的状态,以供CPU处理。
  4. 地址识别。
  5. 数据缓冲。
  6. 差错控制。

3.I/O端口

3.1 概述

I/O端口是指设备控制器中可被CPU直接访问的寄存器。

3.2 分类

  1. 数据寄存器:实现CPU和外设之间的数据缓冲。
  2. 状态寄存器:获取执行结果和设备的状态信息,以告知CPU外设是否准备好了。
  3. 控制寄存器:由CPU写入,以便启动命令或更改设备模式。

3.3 与CPU通信的方式

image.png

  1. 独立编址:为每个端口分配一个I/O端口号,所有I/O端口形成一个I/O端口空间。普通用户不能对其进行访问,只有OS的特殊的I/O指令才能访问端口。
  2. 统一编址:每个端口被分配唯一的内存地址,且不会有内存被分配这一地址,通常分配给端口的地址靠近地址空间的顶端。

4.I/O控制方式

4.1 程序直接控制方式

4.1.1 概述

计算机从外设读取的每个字,C{I都需要对外设状态进行循环检查,知到确定该字已经在I/O控制器的数据寄存器中。
image.png

4.1.2 优点

简单,易于实现。

4.1.3 缺点

在该方式中,由于CPU的高速性和I/O设备的低速性,导致CPU的绝大部分时间都在处于等待I/O设备完成数据I/O的循环测试中,造成了CPU资源的极大浪费,导致CPU的利用率极低。

4.2 中断驱动方式

4.2.1 概述

该方式的思想是允许I/O设备主动打断CPU的运行并请求服务,从而“解放”CPU。

4.2.2 工作过程

CPU向I/O控制器发出一个读命令,保存当前运行环境的上下文,然后就可以干其他事情去了,它将在每条指令的执行默认检查有无中断产生,I/O控制器这边在接收到CPU的指令后,便开始启动I/O工作,从外部读取数据到I/O控制器的数据寄存器中,待数据准备好后,便向CPU发出一个I/O中断,告知其本次数据已经准备好了,CPU执行到当条指令的执行末尾时,开始检查有无中断,发现有个I/O中断,于是CPU便保存当前执行环境的上下文,然后去执行中断处理程序,处理该I/O中断,将数据从I/O控制器那里读到CPU这边的寄存器中,然后继续向I/O控制器发出下一次的读写请求,然后继续忙其他事情去了,如此反复。
image.png

4.2.3 评估

该方式比程序直接控制方式有效,但由于每个字的传输还需要经过CPU,这就导致该方式仍要消耗较多的CPU时间。

4.3 DMA方式

4.3.1 概述

该方式的思想是直接在内存外设之间开辟一条直接的数据通路,彻底“解放”CPU!!!

这条数据通路只是逻辑上的,实际并未建立一条真正的物理通路,而通常是通过总线进行数据传送的。

4.3.2 特点

  1. 基本的传送单位是块。
  2. 所传送的数据是直接从外设送入内存,或者相反。
  3. 仅在传送一个或多个数据的开始和结束阶段,才需CPU干预,整块数据的传送是在DMA控制器的控制下完成的。

4.3.3 DMA控制器(DMAC)的组成

image.png

  • 命令/状态寄存器(CR):接收CPU送来的I/O命令、有关控制信息以及设备的状态信息。
  • 内存地址寄存器(MAR):在输入时,它存放数据从设备传送到内存的起始目标地址,在输出时,它存放从内存到设备的内存源地址。
  • 数据寄存器(DR):存放从设备到内存或从内存到设备的数据。
  • 数据计数器(DC):存放本次要传送的字(节)数。

4.3.4 工作过程

CPU接收到I/O设备的DMA请求时,它给DMAC发出一条命令并设备MAR和DC的值后,启动DMAC,然后忙其他事情去了,后面的数据传送及其控制将交由DMAC全权处理,待这一批数据传送完成后,DMAC将发送一个中断信号给CPU,告知其本次数据传送完成,CPU则根据该中断执行中断处理逻辑,执行一些本次数据传送的善后工作,收个尾。

系统将数据从磁盘读到内存的过程:

4.3.5 评估

DMA方式在一批数据全部传送完成后才中断CPU,而中断方式需要每传送一个数据就中断一次CPU;DMA方式的数据传送是在DMA控制器的控制下完成的,而中断方式则是在中断处理时由CPU完成。

4.4 通道控制方式

4.4.1 概述

I/O通道是指专门负责I/O的处理机,他可以进一步减少CPU的干预,将对一个数据读写为单位的干预转为对一批数据读写为单位的干预。同时,它可以实现CPU、通道、I/O设备三者的并行工作,从而整体上进一步提升系统的资源利用率。

通道又称I/O处理机,它用于实现内存外设之间的数据传送。

通道是一种特殊的处理器(不是软件),因此通道技术是一种硬件机制。
编制好的通道程序存放在内存中。
来自通道的中断将由设备管理负责处理。

通道控制设备控制器,设备控制器控制设备工作。三者是层层递进的关系。

4.4.2 工作过程

当CPU要完成一批数据的读写操作时,向I/O通道发出一条I/O指令,以给出要执行的I/O通道程序的首地址和要访问的I/O设备,然后通道接收到该命令后将执行通道程序以完成CPU分配的任务,数据传送完成后将向CPU发出中断请求。

4.4.3 评估

  • I/O通道的指令类型单一,没有自己的内存,通道所执行的程序是放在自己内存中的,与CPU共享内存。
  • 通道控制方式下,传输的数据块的大小、内存位置将由通道自己控制,此外,一个通道可以控制多条设备与内存进行数据交换,而DMAC只能对应一台设备与内存进行数据交换。

字节多路通道含有很多非分配型的子通道,其数量可达几十甚至数百个,每个通道可连接一个设备并控制该设备的I/O操作,这些子通道按照时间片轮转的方式使用主通道,各个通道每完成其I/O设备的一个字节的交换,便让出主通道的使用权,因此,字节多路通道适合于低速或中速I/O设备。


5.I/O软件的层次结构

image.png

5.1 用户层I/O软件

5.1.1 概述

实现与用户交互的接口,用户可直接调用在用户层提供的、与I/O操作有关的库函数,对设备进行操作。

一般而言,大部分的I/O软件都在OS内部,只有小部分处在用户层。
用户层软件必须通过一组系统调用来获取OS服务。

5.2 设备独立性软件

5.2.1 概述

用于实现用户程序与设备驱动器的统一接口、设备命令、设备的保护以及设备的分配与释放等,同时为设备管理和数据传送提供必要的存储空间。

设备独立性又称设备无关性,即使得应用程序独立于具体使用的物理设备。在应用程序中,使用逻辑设备来请求使用某类设备,而在系统实际执行时,需要将逻辑设备通过设备映射表(DMT)映射成物理设备名使用。
使用逻辑设备名的优势:

  1. 增加设备分配的灵活性。
  2. 易于实现I/O的重定向,指用于I/O操作的设备可以更换而不必更换应用程序。

5.2.2 功能

  1. 执行所有设备的公用操作。比如:对设备的分配与回收、将逻辑设备名映射为物理设备名、对设备进行保护、缓冲管理、差错控制、屏蔽设备之间信息交换单位大小和传输速率的差异等。
  2. 向用户层或文件层提供统一接口。无论何种设备,它们向用户提供的接口是相同的。比如,在对各种设备的读/写操作,在应用程序中都统一使用read/write命令。

5.3 设备驱动程序

5.3.1 概述

与硬件直接相关,负责具体实现OS对设备发出的操作命令,驱动I/O设备工作的驱动程序。
它是I/O进程与设备控制器之间的通信程序,通常以进程的形式存在。
设备驱动程序向上层用户程序提供一组标准接口以屏蔽不同设备之间的差异,同时这还用于接收上层软件发来的抽象I/O要求,然后将抽象要求转换为具体命令发送给设备控制器。控制I/O设备工作。当然,它也接收设备控制器发过来的信号,然后将其传递给上层软件。

一个设备驱动程序对应同一类型的设备(一类设备),而不对应特定类型的特定设备。

5.4 中断处理程序

5.4.1 概述

用于保存被中断进程的CPU环境,然后转入相应的中断处理程序进行处理,处理完毕后再恢复原来的CPU现场,然后返回到被中断进程。

5.4.2 功能

进行进程的上下文切换,对处理中断信号源进行测试,读取设备状态和修改进程状态等。

由于中断处理与硬件密切相关,因此置于OS的底层。

6.应用程序I/O接口

6.1 字符设备接口

get:从缓冲区(由于字符设备不可寻址,只能顺序读取,因此通常为字符设备健康一个字符缓冲区)中获取一个字符。
put:往缓冲区输入一个字符。
in-control:包含了许多参数,每个参数表示一个与具体设备相关的特定功能。(由于字符设备种类繁多,因而设立该命令来处理这种情况)
互斥共享:由于字符设备属于独占设备,因此还需要提供加锁与解锁指令,以实现互斥访问。

6.2 块设备接口

隐藏磁盘的二维结构:将每个扇区的地址用磁道号和扇区号表示。

计算柱面号、磁道号、扇区号的工作是由设备驱动程序负责完成的。

抽象命令映射为低级命令:将上层发来的对文件或设备的打开、读、写等相关抽象命令转换为设备能够识别的较低层的具体操作。
内存映射接口通过内存的字节数来访问磁盘,而不提供读/写磁盘的操作。映射文件到内存的系统调用将返回一个包含文件副本的虚拟内存地址,只需要在访问内存映像时,才由虚拟存储器调页。

6.3 网络设备接口

许多OS提供的网络设备接口上网络套接字接口,套接字接口的系统调用使应用程序能够创建本地的套接字连接到远程的应用程序创建的套接字,从而借此发送和接收数据。

OS中的I/O接口还分为:阻塞与非阻塞I/O接口。
阻塞I/O:进程进行I/O操作时,将被阻塞,需要等待I/O操作完成。(大多数OS提供的I/O接口)
非阻塞I/O:进程进行I/O操作时,不被阻塞,进程需要通过轮询的方式来查询I/O操作是否完成。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW叶片厚度远程监控

LabVIEW叶片厚度远程监控 随着网络技术的高速发展,远程监控广泛应用在各个领域。本文介绍了一种基于LabVIEW的植物叶片厚度远程监控系统,旨在实现对植物生长状况的精准监测和分析。 该系统利用LabVIEW软件开发工具,通过TCP网络协议实现数据…

关于反爬虫的的概述

目录 前言 一、验证码验证 二、IP限制 三、User-Agent限制 四、动态页面加载 总结 前言 反爬虫是一种防止网站被自动程序(爬虫)访问和抓取数据的技术手段。在网络爬虫的发展和使用过程中,有一部分爬虫是用于非法获取网站数据、侵犯隐私…

删除有序数组中的重复项 II[中等]

优质博文:IT-BLOG-CN 一、题目 给你一个有序数组nums,请你原地删除重复出现的元素,使得出现次数超过两次的元素只出现两次 ,返回删除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(1)额…

Java基于SpringBoot+Vue的美容院管理系统,附源码,文档

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

20240202在Ubuntu20.04.6下使用whisper.cpp的显卡模式

20240202在Ubuntu20.04.6下使用whisper.cpp的显卡模式 2024/2/2 19:43 【结论:在Ubuntu20.04.6下,确认large模式识别7分钟中文视频,需要356447.78 ms,也就是356.5秒,需要大概5分钟!效率太差!】 …

electron项目在内网环境的linux环境下进行打包

Linux需要的文件: electron-v13.0.0-linux-x64.zip appimage-12.0.1.7z snap-template-electron-4.0-1-amd64.tar.7z 下载慢或者下载失败的情况可以手动下载以上electron文件复制到指定文件夹下: 1.electron-v13.0.0-linux-x64.zip 复制到~/.cache/electron/目录下…

web前端--------渐变和过渡

线性渐变,是指颜色沿一条直线进行渐变,例如从上到下、从左到右。 当然,CSS中也支持使用角度来设置渐变的方向,角度单位为deg。 0deg,为12点钟方向,表示从下到上渐变。 90deg,为3点钟方向&…

海外社媒营销平台及运营规则,如何降低封号率?

社交媒体已经成为人们生活和日常习惯不可或缺的一部分,在跨境电商出海过程中,海外社媒营销平台可以起到非凡的助力;而平台的选择以及平台的运营技巧、规则都各有不同。很多海外社媒工作者经常会被封号,这也是难度之一,…

吸猫毛空气净化器哪个好?推荐除猫毛效果好的宠物空气净化器品牌

如今,越来越多的家庭选择养宠物,使家庭变得更加温馨。然而,养宠物可能会带来异味和空气中的毛发增多,这可能会成为一大困扰,并对健康造成问题。 为了不让家里充斥着异味,特别是来自宠物便便的味道&#xf…

无人零售模式下,“IoT+鸿蒙”实现零代码搭建自动售货机监控大屏的可能性摸索

前言 新零售模式下,对loT的探索与应用还在继续。 而数字时代,数字化转型在零售行业中蔓延,而对于新的消费方式的探索,也在如火如荼的进行中。于是,一种新零售的形式——无人零售逐渐形成概念。 如果说,人…

微信小程序新手入门教程二:认识JSON配置文件

在上一篇我们介绍了微信小程序的注册和基本使用方式,并且写出了一个简单的页面,但是依然没有解释目录中的各种.json文件是做什么的。这篇我们就来认识一下各种JSON配置文件及其配置项。 一 认识JSON 首先先来认识一下JSON是什么。 JSON 指的是 JavaScri…

25.泛型

泛型 1.泛型1.1 概述1.2 代码示例 2. 泛型类2.1 概述2.2 代码示例 3. 泛型方法3.1 概述3.2 代码示例 4. 泛型接口4.1 概述4.2 代码示例 5. 泛型特点5.1 概述5.2 代码示例 6. 泛型通配符6.1 概述6.2 代码示例 7. 综合案例8. 注意事项 1.泛型 泛型是Java编程语言的一项重要功能&…

故障诊断 | 一文解决,CNN-LSTM卷积神经网络-长短期记忆神经网络组合模型的故障诊断(Matlab)

效果一览 文章概述 故障诊断 | 一文解决,CNN-LSTM卷积神经网络-长短期记忆神经网络组合模型的故障诊断(Matlab) 模型描述 CNN-LSTM模型是一种结合了卷积神经网络(Convolutional Neural Network)和长短期记忆神经网络(Long Short-Term Memory)的组合模型,常用于数据故障…

FPGA解码MIPI视频:Xilinx Artix7-35T低端FPGA,基于MIPI CSI-2 RX Subsystem架构实现,提供工程源码和技术支持

目录 1、前言免责声明 2、相关方案推荐我这里已有的 MIPI 编解码方案本方案在Xilinx Artix7-100T上解码MIPI视频的应用本方案在Xilinx Kintex7上解码MIPI视频的应用本方案在Xilinx Zynq7000上解码MIPI视频的应用本方案在Xilinx Zynq UltraScale上解码MIPI视频的应用纯VHDL代码解…

vite和vue-cli实现原理和优化及区别

Vite: 1. 实现原理: Vite 是一个基于 ESModule 的构建工具。它利用原生 ESModule 的特性,将每个文件作为一个模块,通过浏览器去解析和执行,而不需要提前将文件打包成一个单独的 bundle。Vite 利用浏览器的原生 ESMod…

适用于汽车 4D 成像雷达的双器件毫米波级联参考设计(TI文档)

说明 该汽车雷达参考设计是一个 76GHz 至 81GHz 的级联雷达传感器模块。这包括由 AWR2243 器件和AM2732R 雷达处理器构成的双器件级联阵列。在这一级联雷达配置中,一个主器件向主器件和辅助器件分配20GHz 的本机振荡器 (LO) 信号,使这两个器件作为单个射…

Windows Server 2019 Web服务器搭建

系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 例如:第一章 Python 机器学习入门之pandas的使用 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目…

idea配置tomcat

推荐链接:IntelliJ IDEA中配置Tomcat(超详细)_idea怎么配置tomcat服务器-CSDN博客 1,官员下载链接:Apache Tomcat - Welcome! 附本人下载的 tomcat9 的百度网盘链接 链接:https://pan.baidu.com/s/1DpyBGnG4mUGTm5Z…

AI-数学-高中-18-三角函数-同角三角函数关系及计算

原作者视频:三角函数】5同角三角函数关系(易中档)_哔哩哔哩_bilibili 辅助三角形(计算速度快):1.画一个辅助计算的任意直接三角形;2.利用初中方法先计算sin、cos、tan值;3.看象限确定…

【每日一题】石子游戏 VI

文章目录 Tag题目来源解题思路方法一:贪心排序 写在最后 Tag 【贪心排序】【数组】【2024-02-02】 题目来源 1686. 石子游戏 VI 解题思路 方法一:贪心排序 思路 假设有两个石子 i 和 j,Alice 和 Bob 认为它们的价值分别为 a i a_i ai​…