SSD PCIe接口综述

  • SSD 的接口当前以PCIe为主,因为其速度远快于SATA接口。

  • PCIe 特征

    • 已经从PCIe1.0发展到了6.0, 其中3.0的双向带宽:单通道(Lane)为2GB/s, 32通道为64GB/s
    • 全双工模式,发送和接收通道可以同时工作(SATA为半双工模式)
    • PCIe是串行总线,因此速度快于PCI
    • 物理层使用128/130编码(即传输128位有效数据外加2为校验数据,也有8b/10b编码方式),传输比率增大
    • 可以通过增加通道数扩展带宽,提升速度。但成本和空间占用以及能耗也会随之增加。
    • PCI采用总线型拓扑结构,PCIe采用树型拓扑结构,实现点到点(Endpoint to Endpoint)的通信方式
    • 交换机扩展了PCIe的端口,并完成数据上下游的转发,每个设备独享通道带宽。
    • 每个PCIe设备和交换机都需要实现PCIe的3层结构功能
  • PCIe 分层结构,共分为3层,由上之下依次为:事务层(Transaction Layer),数据链路层(Data Link Layer)和物理层(Physical Layer),下层为上层服务。数据以数据包(Packet)形式传输,每层都有固定格式。数据由事务层生成,发送端向下逐层包装,接收端将数据接收后进行校验,校验错误则通知重传,校验正确则逐层解开包装,向上层传递。

    • 事务层:创建(发送)或者解析(接收)TLP(Transaction Layer Packet)、流量控制、QoS、事务排序等。
    • 数据链路层:创建(发送)或者解析(接收)DLLP(Data Link Layer Packet)、ACK/NAK协议(链路层检错和纠错)、流控、电源管理等。
    • 物理层:处理所有数据包中数据的物理传输,发送端将数据分发到各个Lane中进行传输,接收端将各个Lane上的数据进行汇总,并进行加扰,去扰,8/10或128/130编码解码等工作。
  • PCIe TLP数据。事务层可以产生4种不同的TLP请求:

    • 内存(Memory),用于访问内存空间
    • I/O,用于访问I/O空间,主要为了兼容以前的旧设备,后续会逐渐取消
    • 配置(Configuration),用于访问配置空间,并非常态,一般只发生在上电枚举和配置阶段
    • 消息(Message),终端消息,错误消息等内容,非主流,只有在中断或有错误的情况下发送消息
    • TLP分为Non-posted 和Posted两种,前者是需要对方响应的,后者不需要对方响应。内存写和消息不需要响应,其他都需要响应。
    • 一个TLP最多携带4KB有效数据。
  • TLP数据结构: Header+data+ECRC

    • TLP的header分类:内存,配置,消息,响应
    • 每个PCIe设备都有唯一的ID,包括RC,交换机和终端
  • PCIe 配置空间

    • 每个PCIe设备可能具有多个功能,比如硬盘功能,网卡功能等,因此至少有一个配置空间:通过读取该空间数据,可以获取该设备的基本信息,也可以通过该空间来配置该设备。
    • 配置空间是协议规定好的,地址和内容是有定义的。
    • 配置空间就是一系列寄存器的集合。64B 的Header和192B 的Capability数据结构 + 3840B 扩展配置空间(合计4KB)
    • 一个PCIe系统,可以最多有256条总线,每个总线上最多可以挂32个设备,每个设备最多可以实现8个功能,每个功能对应4KB的配置空间。
  • PCIe共有3种路由方式:

    • 基于地址(Memory Address)的路由
    • 基于设备ID(BDF)的路由
    • 隐式(Implicit)路由

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

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

相关文章

python3基础知识-学习目录

本次学习的内容是以python3.X为平台,详细的阐述python编程的基础知识和高级技巧。虽然之前学习过相关的知识,但是并未真正掌握python的原理,此次的学习更是为了加深自己的印象,并更深入的理解python的高阶知识。 为了学习效率更好…

【python入门】day12:bug及其处理思路

bug的常见类型 粗心 / 没有好习惯 思路不清 lst[{rating:[9.7,2062397],id:1292052,type:[犯罪,剧情],title:肖申克的救赎,actors:[蒂姆罗宾斯,摩根弗里曼]},{rating:[9.6,1528760],id:1291546,type:[剧情,爱情,同性],title:霸王别姬,actors:[张国荣 ,张丰毅 , 巩俐 ,葛优]},{r…

redis重启后数据丢失问题解决(亲测好用)

redis修改密码重启后发现redis中的数据丢失了 解决办法: 首先在redis的安装目录下查找重启之前的dump.rdb文件,发现只有当天的一个dump.rdb文件,确认不是重启备份的文件 然后我就全盘找一下dump.rdb的备份文件,找到前一天的备份…

喜讯丨上海和今信息科技有限公司入选2023年上海市专精特新中小企业名单

近日,上海市经济和信息化委员会公示了 2023 年上海市专精特新中小企业名单,上海和今信息科技有限公司凭借多年专注数据智能领域、领先的产品技术实力、专业的创新研发能力以及卓越的行业影响力,顺利通过专家评审和综合评估,荣获上…

WRF进阶:使用Grid Nudging同化Upper-air

Nudging Nudging是一种应用较为广泛的同化方法,通过在控制方程中加上强迫项,逐渐把模式状态向观测状态逼近。这些强迫项相对于方程中的各项量级较小,保证了在每个积分步长中各物理量之间的动力平衡(Stauffer D R, Seaman N L. 19…

MO 2023 年度回顾

PART-ONE 行业态势 随着供需关系的变化,数据库的竞争在经历了 3 年 “百花齐放” 般的发展后,终于在 2023 年进入到了一个相对收拢的阶段。 2023 年,各个数据库厂商间很有默契地在两个方面达成了一致: HTAP 已经成为新一代数据…

源码安全静态扫描工具对比

Checkmarx CxSuite 介绍参见:https://cloud.tencent.com/developer/article/2249914 这家报价接近90W人民币/ 一年,据我们联系的人说 这家销售觉得我们预算不够,高高在上。。。。 sonarqube 参见:GitHub - SonarSource/sonarqu…

【Storm实战】1.2 图解Storm的架构及其组件

文章目录 0. 前言1. 图解架构及其组件2. Storm的主要架构组件 0. 前言 上一章节,我们为了好理解,将storm中的抽象概念 通过画了一个水力发电系统的工作模式,相信大家一定可以直观地理解Storm中的流 (Stream) 、拓扑 (Topology)、Spout、Bolt…

How to understand DataArts Insight in Huawei Cloud

How to understand DataArts Insight in Huawei Cloud 概述什么是DataArts Insight为什么选择华为云DataArts Insight多业务场景全覆盖,实现企业智能分析产品架构产品功能数据接入数据加工仪表板数据大屏交互式分析嵌入式分析智能分析助手智能洞察BI内存引擎企业级数…

编译好的opencv3.1.0_mingw版下载可用

网上转载:感谢网友提供,学习啦! 最近正在学习OpenCV ,为毕业设计做准备。Windows版本的OpenCV都默认提供对VS的支持,其在VS中的配置比较简单,网上也有大批教程详细描述了配置步骤。但在使用Qt Creator时的…

Vue中的计算属性与监听器

聚沙成塔每天进步一点点 ⭐ 专栏简介 Vue学习之旅的奇妙世界 欢迎大家来到 Vue 技能树参考资料专栏!创建这个专栏的初衷是为了帮助大家更好地应对 Vue.js 技能树的学习。每篇文章都致力于提供清晰、深入的参考资料,让你能够更轻松、更自信地理解和掌握 Vue.js 的核心概念和技…

vite项目配置项目可通过局域网访问

vite.config.js配置如下 import { defineConfig } from vite import vue from vitejs/plugin-vueexport default defineConfig({server: {port: 3001, // 访问端口号host: 0.0.0.0, // 配置项目可以局域网访问cors: true, // 默认启用并允许任何源plugins: [vue()],base: ./, …

大数据开发与低代码:加速数据处理与解决方案开发

随着数据量的爆炸式增长,大数据开发变得愈发重要。然而,传统的大数据开发方法往往需要复杂的编码和开发过程,消耗时间和资源。而低代码开发平台的出现为大数据开发带来了全新的解决方案。本文将介绍大数据开发和低代码的概念,并探…

python的课后练习总结4(while循环)

for循环用于针对序列中的每个元素的一个代码块。 while循环是不断的运行&#xff0c;直到指定的条件不满足为止。 while 条件&#xff1a; 条件成立重复执行的代码1 条件成立重复执行的代码2 …….. i 1while i < 5:print(i)i i 11、使用wh…

WMS仓储管理系统与WCS系统:功能差异与特点对比

在物流行业的现代化管理中&#xff0c;WMS仓储管理系统和WCS仓库控制系统扮演着举足轻重的角色。虽然它们都是仓库管理软件系统&#xff0c;但是它们在功能和应用场景上存在显著的差异。本文将详细阐述这两者的功能和区别。 一、WMS仓储管理系统 WMS是一种综合性的软件系统&…

制药企业符合CSV验证需要注意什么?

在制药行业中&#xff0c;计算机化系统验证&#xff08;CSV&#xff09;是确保生产过程的合规性和数据完整性的关键要素。通过CSV验证&#xff0c;制药企业可以保证其计算机化系统的可靠性和合规性&#xff0c;从而确保产品质量和患者安全。然而&#xff0c;符合CSV验证并不是一…

通过回答自然语言问题进行事件抽取(EMNLP2020)

1、写作动机&#xff1a; 以往的事件抽取方法都基于神经网络模型抽取的密集特征和预训练语言模型的上下文表示。但是&#xff0c;它们&#xff08;1&#xff09;严重依赖实体识别进行事件论元抽取&#xff0c;特别是通常需要采用多步骤方法来进行事件论元抽取。&#xff08;2&…

Android linephone-android sdk设置语音编码问题

1.遇到的问题 今天遇到linphone-android sdk需要解决语音编码问题&#xff0c;需要指定编码。查了下配置&#xff0c;里面没有发现类似的配置。 ## Start of factory rc # This file shall not contain path referencing package name, in order to be portable when app is r…

如何搭建中后台管理系统

vue3 TS vite 搭建中后台管理系统 前言1、搭建步骤及方法2、集成多种插件功能&#xff0c;实现中后台按需使用3、新手学TS如何快速进入状态、定义TS类型4、layout搭建四款常见风格6、大屏搭建效果5、vue3Ts运营管理系统总结&#xff1a; 前言 要成功&#xff0c;先发疯&…

【QT】中英文切换

很高兴在雪易的CSDN遇见你 前言 本文分享QT中如何进行中英文切换&#xff0c;希望对各位小伙伴有所帮助&#xff01; 感谢各位小伙伴的点赞关注&#xff0c;小易会继续努力分享&#xff0c;一起进步&#xff01; 你的点赞就是我的动力(&#xff3e;&#xff35;&#xff3e…