IEEE SGL与NVMe SGL的区别?

2024-03-02 22:36
文章标签 区别 ieee nvme sgl

本文主要是介绍IEEE SGL与NVMe SGL的区别?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在HBA(Host Bus Adapter)驱动程序中,IEEE SGL(Institute of Electrical and Electronics Engineers Scatter-Gather List)和NVMe SGL(Non-Volatile Memory Express Scatter-Gather List)是两种不同的数据传输机制,它们均用于描述主机内存中分散的物理内存区域,以便在一次I/O操作中传输多个不连续的数据块。虽然它们的基本作用相似,但在原理和应用场景上有所区别:

IEEE SGL

  • 原理:IEEE SGL通常是指在PCIe(Peripheral Component Interconnect Express)体系结构中使用的一种数据传输技术,用于传统SCSI(Small Computer System Interface)或者其他存储设备。SGL由一系列描述符组成,每个描述符包含了内存区域的起始物理地址和长度信息,使得控制器可以访问非连续的内存区域。
  • 应用场景:IEEE SGL广泛应用在各种支持scatter/gather功能的存储控制器上,例如某些HBA卡在处理SCSI、ATA、SAS等接口的硬盘I/O时,尤其是在处理大数据块传输、文件系统或数据库操作时,可以大大提高效率。

NVMe SGL

  • 原理:NVMe SGL是NVMe协议专门针对非易失性内存设备(如NVMe SSD)定义的一种更为优化的数据传输方式。在NVMe协议中,SGL表现为Physical Region Page (PRP) List或SGL Descriptor List。PRP List由一系列物理地址组成,每个地址指向一个4KB对齐的物理内存页,而SGL Descriptor List则除了包含物理地址外,还包含每个内存段的长度信息,因此对于非4KB对齐的数据也能精确描述。
  • 应用场景:NVMe SGL主要用于NVMe SSD的高性能读写操作,尤其在处理大量小型、非连续数据块或者需要跨多个内存页面的大数据块时,通过SGL能够减少数据预处理和内存复制,极大地提高了I/O性能和资源利用率。

总结起来,IEEE SGL和NVMe SGL都是为了提高数据传输效率而设计的,但NVMe SGL在NVMe SSD环境中进行了特别优化,能够更好地适应闪存存储设备的特性,并且在硬件层面提供了更多的灵活性和更好的性能。

NVMe(Non-Volatile Memory Express)协议对SGL(Scatter-Gather List)的优化主要体现在以下几个方面,使得它相比传统的IEEE SGL更适合NVMe SSD设备:

  1. 物理区域页(PRP)列表
    NVMe协议采用了PRP List,这是一种精简版的SGL,专为NVMe SSD设计。PRP List仅包含指向4KB对齐物理页的地址列表,每个条目都是一个64位物理地址,直接指向数据所在的物理内存页。对于连续的物理内存,这种方法极为高效,因为NVMe控制器可以直接通过硬件访问,无需额外的地址解析开销。
  2. SGL Descriptor List
    NVMe 1.1及更高版本增加了对SGL Descriptor的支持,它比基础的PRP List更灵活,每个SGL Descriptor不仅包含物理地址,还包含数据段的长度信息。这意味着NVMe可以处理非4KB对齐的数据,无需预先调整数据布局,从而适应更广泛的数据分布情况。
  3. 硬件优化
    NVMe SSD控制器硬件针对PRP和SGL进行了深度优化,能够快速、高效地处理这些列表,最大限度地减少CPU干预,提高I/O操作的性能。而传统的IEEE SGL在非NVMe环境下的实现可能需要更多的软件参与和间接寻址,从而导致性能下降。
  4. 低延迟和高带宽
    NVMe协议和SSD控制器设计紧密配合,利用PCIe总线的高速特性,加上SGL的优化,能够实现极低的延迟和高带宽的数据传输,这对于数据中心、高性能计算、云计算等场景至关重要,而在这些场景中,IEEE SGL可能无法提供足够的性能优势。

简而言之,NVMe SGL(包括PRP和SGL Descriptor List)是针对NVMe SSD固态存储设备的特性专门优化的数据传输机制,能够在硬件层面提供更强的性能和效率,优于传统的IEEE SGL在其他类型的存储设备上的应用。

这篇关于IEEE SGL与NVMe SGL的区别?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767636

相关文章

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod

Golan中 new() 、 make() 和简短声明符的区别和使用

《Golan中new()、make()和简短声明符的区别和使用》Go语言中的new()、make()和简短声明符的区别和使用,new()用于分配内存并返回指针,make()用于初始化切片、映射... 详细介绍golang的new() 、 make() 和简短声明符的区别和使用。文章目录 `new()`

Python中json文件和jsonl文件的区别小结

《Python中json文件和jsonl文件的区别小结》本文主要介绍了JSON和JSONL两种文件格式的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下... 众所周知,jsON 文件是使用php JSON(JavaScripythonpt Object No

结构体和联合体的区别及说明

《结构体和联合体的区别及说明》文章主要介绍了C语言中的结构体和联合体,结构体是一种自定义的复合数据类型,可以包含多个成员,每个成员可以是不同的数据类型,联合体是一种特殊的数据结构,可以在内存中共享同一... 目录结构体和联合体的区别1. 结构体(Struct)2. 联合体(Union)3. 联合体与结构体的

什么是 Ubuntu LTS?Ubuntu LTS和普通版本区别对比

《什么是UbuntuLTS?UbuntuLTS和普通版本区别对比》UbuntuLTS是Ubuntu操作系统的一个特殊版本,旨在提供更长时间的支持和稳定性,与常规的Ubuntu版本相比,LTS版... 如果你正打算安装 Ubuntu 系统,可能会被「LTS 版本」和「普通版本」给搞得一头雾水吧?尤其是对于刚入

python中json.dumps和json.dump区别

《python中json.dumps和json.dump区别》json.dumps将Python对象序列化为JSON字符串,json.dump直接将Python对象序列化写入文件,本文就来介绍一下两个... 目录1、json.dumps和json.dump的区别2、使用 json.dumps() 然后写入文

native和static native区别

本文基于Hello JNI  如有疑惑,请看之前几篇文章。 native 与 static native java中 public native String helloJni();public native static String helloJniStatic();1212 JNI中 JNIEXPORT jstring JNICALL Java_com_test_g

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否