Linux BIO如何下发到HDD?

在Linux操作系统中,当创建一个Block I/O请求(BIO)时,它会被封装成适合硬件交互的数据结构,并通过内核存储子系统传递到对应的硬件控制器上,如SAS(Serial Attached SCSI)HBA(Host Bus Adapter)卡。以下是该过程的详细分析和解读:

BIO创建

在用户空间或内核空间的应用程序发起读写磁盘操作时,会调用相应的系统调用(例如read()write()或者直接使用io_uring等异步I/O接口),这些调用最终转化为对块设备的I/O请求。

这些请求被包装为内核中的struct bio数据结构,即BIO,它包含了诸如起始扇区地址、要传输的数据长度以及指向实际数据缓冲区的指针等信息。

调度与合并

Linux内核的块层(block layer)会对BIO进行调度和可能的合并操作,以优化I/O性能。例如,如果连续的多个小I/O可以合并为一个大的I/O,那么内核就会这样做,减少硬件操作次数。

通过I/O调度器

调度后的BIO经过I/O调度器(如CFQ, Deadline, Noop等),按照特定策略将I/O请求排序并决定何时将其发送给下一层驱动。

到达SCSI中间层

对于SAS硬盘,BIO接着会传递到SCSI子系统,进一步转换为SCSI命令描述符块(CDBs)。这一过程中,Linux的scsi_midlayer组件负责处理从块设备抽象到具体SCSI协议之间的转换。

SAS HBA驱动介入

当请求到达SAS HBA驱动层时,驱动程序将CDB及相关的BIO信息映射到适配器的命令队列中。SAS HBA驱动主要负责与硬件通信,包括控制寄存器的操作、DMA数据传输管理以及处理中断等。

硬件执行

驱动程序将准备好的SCSI命令发送至SAS HBA卡。HBA卡收到命令后,通过其内部逻辑处理,并通过SAS总线将命令传输到目标SAS硬盘。

SAS硬盘响应

SAS硬盘接收到命令后,根据指令完成相应操作,可能是读取数据或写入数据。完成后,硬盘通过SAS链路返回状态信息和(如有必要)数据。

数据传输与确认

HBA卡接收到来自硬盘的响应后,驱动程序开始处理回传的数据,如果是读操作,则将硬盘返回的数据复制到原始BIO所关联的内存区域;如果是写操作,则确认数据已经正确写入硬盘。

完成通知

当所有数据传输完毕并且相关事务处理结束时,HBA驱动向内核块层发出I/O完成通知,从而释放相关的资源,并允许等待的进程继续执行。

在Linux系统中,一个创建的BIO经历了层层转化与调度,最终通过SAS HBA驱动成功地与底层的SAS HDD交互,实现了数据的读写操作。

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

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

相关文章

Linux ---- Shell编程之函数与数组

目录 一、函数 1、函数的基本格式 2、查看函数列表 3、删除函数 4、函数的传参数 5、函数返回值 实验: 1.判断输入的ip地址正确与否 2. 判断是否为管理员用户登录 6、函数变量的作用范围 7、函数递归(重要、难点) 实验&#xff1…

《Q年文峰》GPT应用的交互式非线性体验

Phoncent博客创始人庄泽峰把自己的小说《Q年文峰》做成GPT应用,显然这是一件值得探索且具有创新意义的事情。 因为传统的阅读体验是线性的,读者只能按照固定的情节顺序进行阅读,而把小说制作成GPT应用后,读者阅读小说的方式是非线…

力扣0085——最大矩形

最大矩形 难度:困难 题目描述 给定一个仅包含 0 和 1 、大小为 rows x cols 的二维二进制矩阵,找出只包含 1 的最大矩形,并返回其面积。 示例1 输入:matrix [["1","0","1","0",&qu…

分布式id-雪花算法

一、雪花算法介绍 Snowflake,雪花算法是有Twitter开源的分布式ID生成算法,以划分命名空间的方式将64bit位分割成了多个部分,每个部分都有具体的不同含义,在Java中64Bit位的整数是Long类型,所以在Java中Snowflake算法生…

2024年项目基金撰写与技巧及GPT融合

详情点击链接:2024年项目基金撰写与技巧及GPT融合 一:国自然项目 1.1项目 1.2接收情况 1.3受理情况 1.4近五年资助情况 1.5国自然改革解读 1.6博后项目 二:基金的撰写技巧 2.1 问题属性与评阅标准 2.2 前期准备工作-如何去选题 2.…

在线商城系统设计

设计一个在线商品商店的数据库模式涉及多个方面,包括产品、订单、用户、支付等。 数据库设计: 用户表 (Users): UserID (主键)用户名密码电子邮件地址电话号码 产品表 (Products): ProductID (主键)产品名称描述价格库存数量分类ID (外键,连接…

203.移除链表元素(力扣LeetCode)

文章目录 203.移除链表元素题目描述原链表删除元素虚拟头节点 203.移除链表元素 题目描述 给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val val 的节点,并返回 新的头节点 。 示例 1: 输入:head …

Ubuntu20.04添加桌面启动、侧边栏启动和终端启动

桌面启动 新建XX.desktop文件 在桌面新建一个XX.desktop文件,以QtCreator为例。 (注意这里不能使用sudo,因为这样会把文件的权限归为root,导致后续设置可执行程序不方便) gedit qtcreator.desktop在XX.desktop文件中…

【DeepLearning-9】YOLOv5模型网络结构中加入MobileViT模块

一、神经网络的前中后期 在神经网络中,特别是在深度卷积神经网络(CNN)中,“网络早期(低层)”、“网络中期(中层)”和“网络后期(高层)”通常指的是网络结构中…

【云原生】初识Docker,安装以及了解操作命令

一、为什么要使用容器? 背景:以前开发、测试、生产为不同的环境,痛点是发现开发测试以后没问题,但是在生产环境无法运行。给测试、开发、运维人员造成了大量的工作。最终结果是发版更新速度也跟不上,效率低 我认为使…

JAVA 学习 面试(十)枚举、注解、基本原则

枚举 默认继承 java.lang.Enum 类,不能继承其他父类,并自动添加了values(获取枚举类中的所有枚举值)和valueOf(获取对应的枚举类型)方法, java.lang.Enum 类实现了 java.lang.Serializable 和 …

翻译: GPT-4 with Vision 升级 Streamlit 应用程序的 7 种方式二

GPT-4 Vision 系列: 翻译: GPT-4 with Vision 升级 Streamlit 应用程序的 7 种方式一 GPT-4 Vision 的 7 个实际用例 Pre-requisites:先决条件: 订阅 ChatGPT Plus 以访问 GPT-4 Vision。如果您不熟悉 Streamlit,请按照安装步骤操作。 1. 绘制您的应…

C++面试:二叉树和红黑树

目录 二叉树 1. 二叉树的定义 2. 二叉树的遍历 3. 二叉树的应用 4. 实现细节 5. C中的实现 面试准备 红黑树 红黑树的原理 红黑树的用途 示例代码 面试准备 1. 红黑树的工作原理及其规则 2. 红黑树的优势及与其他二叉搜索树(如AVL树)的比较…

尚无忧球馆助教系统源码,助教小程序源码,助教源码,陪练系统源码

特色功能: 不同助教服务类型选择 助教申请,接单,陪练师入住,赚取外快 线下场馆入住 设置自己服务 城市代理 分销商入住 优惠券 技术栈:前端uniapp后端thinkphp 独立全开源

.NET高级面试指南专题一【委托和事件】

在C#中,委托(Delegate)和事件(Event)是两个重要的概念,它们通常用于实现事件驱动编程和回调机制。 委托定义: 委托是一个类,它定义了方法的类型,使得可以将方法当作另一个…

pyqt添加菜单栏

参考: https://blog.csdn.net/seniorwizard/article/details/109820641 import sys from PyQt5 import QtCore, QtGui, QtWidgets from PyQt5.QtCore import Qt from PyQt5.QtWidgets import (QApplication, QMainWindow, QMenuBar, QMenu, QAction, QPlainTextEdi…

HarmonyOS鸿蒙ArkTS,封装http网络请求

HarmonyOS鸿蒙ArkTS,封装http网络请求 前提: 要想使用http请求,系统必须要具备ohos.permission.INTERNET权限,在model.json5文件中的module模块下添加如下请求权限: 在module.json5文件中 配置 "requestPermi…

踩坑(6)Redisson调用unlockAsync方法释放锁失败

问题描述 通过redisson的lockAsync异步方法获取到锁之后&#xff0c;再业务执行完成后调用lock.unlockAsync()无法释放当前锁&#xff0c;导致后续的方法被阻塞 public void asyncLock() {RLock lock redissonClient.getLock("asyncLock");RFuture<Void> fut…

LeetCode 热题 100 | 矩阵

目录 1 73. 矩阵置零 2 54. 螺旋矩阵 3 48. 旋转图像 4 240. 搜索二维矩阵 II 菜鸟做题第二周&#xff0c;语言是 C 1 73. 矩阵置零 解题思路&#xff1a; 遍历矩阵&#xff0c;寻找等于 0 的元素&#xff0c;记录对应的行和列将被记录的行的元素全部置 0将被记录的…

k8s 进阶实战笔记 | Scheduler 调度策略总结

文章目录 Scheduler 调度策略总结调度原理和过程调度策略nodeSelect亲和性和反亲和性NodeAffinify亲和验证PodAffinity 亲和验证PodAntiAffinity 反亲和验证污点与容忍跳过 Scheduler 调度策略 调度策略场景总结 Scheduler 调度策略总结 调度原理和过程 Scheduler 一直监听着…