CXL寄存器介绍(2)- CXL DVSEC



🔥点击查看精选 CXL 系列文章🔥
🔥点击进入【芯片设计验证】社区,查看更多精彩内容🔥


📢 声明

  • 🥭 作者主页:【MangoPapa的CSDN主页】。
  • ⚠️ 本文首发于CSDN,转载或引用请注明出处【https://mangopapa.blog.csdn.net/article/details/132553156】。
  • ⚠️ 本文目的为 个人学习记录知识分享。因个人能力受限,存在协议解读不正确的可能。若您参考本文进行产品设计或进行其他事项并造成了不良后果,本人不承担相关法律责任。
  • ⚠️ 若本文所采用图片或相关引用侵犯了您的合法权益,请联系我进行删除。
  • 😄 欢迎大家指出文章错误,欢迎同行与我交流 ~
  • 📧 邮箱:mangopapa@yeah.net
  • 💬 直达博主:loveic_lovelife 。(搜索或点击扫码)

文章目录

  • 1. PCIe DVSEC for CXL Devices (DVSEC _ID=0x0000)
    • Header
    • Capability
    • Control
    • Status
    • Range
    • Lock
  • 2. Non-CXL Function Map DVSEC (DVSEC _ID=0x0002)
  • 3. CXL Extensions DVSEC for Ports (DVSEC _ID=0x0003)
  • 4. GPF DVSEC for CXL Ports (DVSEC _ID=0x0004)
  • 4. GPF DVSEC for CXL Devices (DVSEC _ID=0x0005)
  • 6. PCIe DVSEC for Flex Bus Port (DVSEC _ID=0x0007)
    • Capability
    • Control
    • Status
  • 7. Register Locator DVSEC (DVSEC _ID=0x0008)
  • 8. MLD DVSEC (DVSEC _ID=0x0009)
  • 9. PCIe DVSEC for Test Capability (DVSEC _ID=0x000a)
  • 10. 参考


  上文《CXL寄存器分类》简单介绍了 CXL 的寄存器分布,接下来进一步介绍下 CXL 相关的 DVSEC。



1. PCIe DVSEC for CXL Devices (DVSEC _ID=0x0000)

  PCIe DVSEC for CXL Devices(CXL 1.1 时称为 Flex Bus Devices,协议中有时简称为 CXL PCIe DVSEC),该能力结构中具备实现 CXL 所需的最基本的寄存器,用以指示 CXL 能力、控制相关能力/特性的开关及状态指示。

  CXL PCIe DVSEC 能力结构寄存器布局如下图所示,其中有 Capability 寄存器、能力控制寄存器、状态指示寄存器、Range 配置寄存器及配置锁定寄存器。

在这里插入图片描述

  PCIe 枚举时,软件根据 Device 是否实现了该 CXL PCIe DVSEC 来判断 Device 为 PCIe Device 还是 CXL Device 。进一步讲,若 CXL Device 为 RCD,其以 RCiEP 的形式展示给 Host,枚举过程中以该 RCD 所在的 Bus 作为 Root Bus 创建一个新的枚举 Hierarchy;若 CXL Device 非 RCD,则按照标准的 PCIe EP 进行枚举。无论哪种情况,CXL Device 的 Device0 Function0 配置空间中均应实现 CXL PCIe DVSEC 能力结构,并应用于该 Device 内的所有 Device/Function。

Header

  CXL PCIe DVSEC Header 中,CXL DVSEC ID=0x00 表示当前 DVSEC 为 CXL PCIe DVSEC,Revision ID 指示该能力结构所适用的 CXL 协议版本, 0/1/2 分别代表 CXL 1.1/2.0/3.0 。RCD 的版本可以为 0 及以上,非 RCD 的版本为 1 及以上。

Capability

  CXL 链路训练过程中 Modified TS 中部分字段源于该 Capability 寄存器,Capability 能力指示寄存器指示该 Device:

  • 是否支持 CXL.io、CXL.cache 及 CXL.cache 协议;
  • 是否支持 Memory 的硬件初始化,是否为 MLD 设备,支持的 HDM 范围数量;
  • 是否支持 Cache 的 Writeback 及 Invalidate;
  • 是否支持复位,各种复位之后的默认 Volatile HDM 状态;
  • 是否支持 Viral 处理、PM 初始化完成上报;
  • Cache Size 单位及数量;
  • 是否支持 Fallback Mode。

Control

  能力控制寄存器对相关能力/特性进行配置、开关控制,其控制的能力/特性包括:

  • 是否开启 CXL.io、CXL.cache、CXL.mem、Viral 处理;
  • Cache SF 的粒度、是否开启 Cache SF 的 Coverage;
  • 关闭对新 Cacheline 的 Caching 或关闭 Cache;
  • 发起 Cache 中 Modified Cacheline 的 Write Back 并 Invalidate 所有 Cacheline;
  • 发起 CXL 复位,等等。

Status

  CXL PCIe DVSEC 中的状态指示寄存器用以指示以下状态:

  • Viral 状态;
  • Cache Invalid 状态;
  • CXL 复位完成、复位错误;
  • Volatile HDM 保护出错;
  • PM 初始化完成状态。

Range

  CXL Device 支持最多 2 个 HDM Range,CXL PCIe DVSEC 中的 CXL Range 相关寄存器对各个 HDM 基地址及 Size 进行配置及指示。其中,CXL Range Size 还能够指示 Memory 是否 Active、Memory 类型、Interleave 方案等等。

  注意:CXL Range 寄存器不适用于 FMLD,且只有在 Mem _Capable=1 时有效。

Lock

  Lock 寄存器用以锁定 CXL PCIe DVSEC 中所有 RWL 类型的寄存器,锁定之后这些寄存器访问属性变为 RO。



2. Non-CXL Function Map DVSEC (DVSEC _ID=0x0002)

  Non-CXL Function Map DVSEC 能力结构用以指示 CXL Device 中不支持 CXL.cache/mem 协议的 Function。

  我们知道,RCD 内部支持多个 Device 和 Function,非 RCD 类型的 CXL Device 内部支持一个 Device 及多个 Function。我们还知道,CXL Device 0 Function 0 配置空间中的 CXL PCIe DVSEC 该 Device 内的适用于所有 Device/Function。实际情况中,可能存在部分 Device 或 Function 不支持 CXL.cache/mem 协议,这部分 Device/Function 即通过 Non-CXL Function Map DVSEC 来指示。

  Non-CXL Function Map DVSEC 能力结构寄存器布局如下图所示,其中包含 8 个 32b 宽的 Non-CXL Function Map 寄存器,每个 bit 对应一个特定的 Device/Function。

在这里插入图片描述

  根据 Device 是否支持 ARI 分为两种情况:

  • 对于支持 ARI 的 Device,5b Device Number 合入 3b Function Number,最多支持 256 个 Function,8 个 32b 宽的 Non-CXL Function Map 寄存器每 1b 对应一个 Function。比如 Non-CXL Function Map Reg3 的 bit4 为 1,表示 Function 100 (3*32+4=100) 不支持 CXL.cache/mem 协议。
  • 对于不支持 ARI 的 Device,8 个 Non-CXL Function Map Reg 对于 Function [0:7],每个寄存器中的 32b 对应 32 个 Device。比如 Non-CXL Function Map Reg3 的 bit4 为 1,表示 Device 4 的 Function 3 不支持 CXL.cache/mem 协议。

  CXL Device 的 Device 0 Function 0 必须支持 CXL.cache/mem 协议,这也意味着 Non-CXL Function Map Reg0 Bit0 不能为 1。



3. CXL Extensions DVSEC for Ports (DVSEC _ID=0x0003)

  CXL Extensions DVSEC for Ports 能力结构,仅用于 RP、DSP 及 USP,在 PCIe 枚举层级之外维护一条 RCH-RCD 层级,其能力结构寄存器布局如下图所示。

在这里插入图片描述

  该能力结构具有以下功能:

  • 对该 Port 的 PM 初始化完成状态、Viral 状态进行指示;
  • 对该 Port 的控制寄存器中的 Secondary Bus Reset (SBR)、Link Disable 字段解屏蔽,使能该 Port 的 Alt Memory ID Space、Alt BME (Bus Master Enable)、UIO to HDM、Viral 生成等功能;
  • 配置 Alt Bus/Memory/Prefetch Memory 的 Base 及 Limit;
  • 使能并配置该 Port 的 RCRB 地址。

  CXL RP、DSP、USP 必须实现该能力结构。当 RP 或 Switch 下挂载了 eRCD 时,该 DVSEC 可以来指示 RCRB Base、Alt Bus Base/Limit、Alt Memory Base/Limit。

  *BME: Bus Master Enable,用以控制 Memory/IO 读写请求的开关

  *MSE: Memory Space Enable,用以使能 Memory Space



4. GPF DVSEC for CXL Ports (DVSEC _ID=0x0004)

  GPF DVSEC for CXL Ports 能力结构用于 CXL Port 中的 GPF 相关能力,主要用以控制 GPF Phase1、Phase2 的 Timeout 值。该能力结构寄存器布局如下图所示。

在这里插入图片描述



4. GPF DVSEC for CXL Devices (DVSEC _ID=0x0005)

  GPF DVSEC for CXL Devices 能力结构用于 CXL Device 中的 GPF 相关能力,主要用以指示 GPF Phase2 的 Timeout 值及 Phase2 期间的功耗。该能力结构寄存器布局如下图所示。

在这里插入图片描述



6. PCIe DVSEC for Flex Bus Port (DVSEC _ID=0x0007)

  PCIe DVSEC for Flex Bus Port(又称 Flex Bus Port DVSEC)用以控制及指示 Flex Bus 相关能力,CXL 链路训练期间 Modified TS 中的 Flex Bus 相关信息多来源于该能力结构中的寄存器,接收到对端发来的 Modified TS Info 也会记录在该能 DVSEC 相关寄存器中。

  所有 CXL Port 都要实现 Flex Bus Port DVSEC 能力结构。对于没有实现 RCRB 的 CXL RP 及 CXL Switch USP/DSP,该能力结构 位于 CXL Device 的 Device 0 Function 0 的配置空间内 ;对于实现了 RCRB 空间的 RCH 及 RCD,Flex Bus Port DVSEC 实现于 RCRB 空间

  Flex Bus Port DVSEC 能力结构寄存器布局如下图所示,其中主要为 Flex Bus Capability、Control 及 Status 寄存器。

在这里插入图片描述

Capability

  CXL 链路训练过程中 Modified TS 中部分字段源于该 Capability 寄存器,Capability 能力指示寄存器指示该 Flex Bus Port:

  • 是否支持 CXL.io、CXL.cache 及 CXL.mem 协议;
  • 是否支持 68B、Latency-Optimized 256B、PBR 等 Flit Mode;
  • 是否支持 MLD;
  • 是否支持 NOP Hint。

  该 DVSEC Capability 寄存器中部分字段于 CXL PCIe DVSEC Capability 存在重复,是给未来单个 Port 下存在多个具备不同 Capability 的 Device 的场景准备的。

Control

  能力控制寄存器对相关能力/特性进行配置、开关控制,其控制的能力/特性包括:

  • 是否开启 CXL.io、CXL.cache、CXL.mem 等协议;
  • 是否开启 Sync Header Bypass、Drift Buffer;
  • 是否开启 68B/VH、Latency-Optimized 256B、PBR Flit Mode;
  • 是否开启对 MLD、NOP Hint 的支持;
  • 配置并指示 CXL 链路上是否存在 Retimer1/2。

Status

  Flex Bus Port DVSEC 中的状态指示寄存器用以指示以下状态:

  • 所使能的 CXL 协议;
  • Flit Mode 使能状态;
  • Sync Header Bypass 及 Drift Buffer 使能状态;
  • Even Half 错误状态、CXL Frame Error 状态;
  • Retimer1/2 Present 状态,等等。


7. Register Locator DVSEC (DVSEC _ID=0x0008)

  Register Locator DVSEC 内存放有一个或多个寄存器块的 Entry。下图为 3 个 Entry 的 Register Locator DVSEC 能力结构寄存器布局。

在这里插入图片描述

  上述 Entry 每个 Entry 占用 2DW 寄存器,Entry 内含有相关信息来指示当前 Entry 归属于哪个寄存器块、位于哪个 BAR 范围内、在 BAR 内的地址偏移(64KB 对齐)是多少。



8. MLD DVSEC (DVSEC _ID=0x0009)

  MLD DVSEC 用于 MLD 相关 Capability,比如指示支持的 LD 数量、LD-ID 热复位向量。MLD DVSEC 仅适用于 FM 所属的 LD,其能力结构寄存器布局如下图所示。

在这里插入图片描述



9. PCIe DVSEC for Test Capability (DVSEC _ID=0x000a)

  该 DVSEC 用于 CXL Compliance 测试。CXL Compliance 测试过程中对该 DVSEC 进行配置,并根据该 DVSEC 内容进行相关测试。下图是 CXL 协议建议的一种寄存器布局。

在这里插入图片描述



10. 参考

  1. CXL Base Spec, r3.0

— END —


🔥 精选往期 CXL 协议系列文章,请查看【 CXL 专栏】🔥

⬆️ 返回顶部 ⬆️

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

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

相关文章

TiDB 一栈式综合交易查询解决方案获“金鼎奖”优秀金融科技解决方案奖

日前,2023“金鼎奖”评选结果揭晓, 平凯星辰(北京)科技有限公司研发的 TiDB 一栈式综合交易查询解决方案获“金鼎奖”优秀金融科技解决方案奖 , 该方案已成功运用于 多家国有大行、城商行和头部保险企业 。 此次获奖再…

【AI】《动手学-深度学习-PyTorch版》笔记(二十一):目标检测

AI学习目录汇总 1、简述 通过前面的学习,已经了解了图像分类模型的原理及实现。图像分类是假定图像中只有一个目标,算法上是对整个图像做的分类。 下面我们来学习“目标检测”,即从一张图像中找出需要的目标,并标记出位置。 2、边界框 边界框:bounding box,就是一个方…

我想开通期权?如何开通期权账户?

场内期权的合约由交易所统一标准化定制,大家面对的同一个合约对应的价格都是一致的,比较公开透明,期权开户当天不能交易的,期权开户需要满足20日日均50万及半年交易经验即可操作,下文科普我想开通期权?如何…

Java设计模式:四、行为型模式-10:访问者模式

一、定义:访问者模式 访问者模式:核心在于同一个事物不同视角下的访问信息不同。 在一个稳定的数据结构下,例如用户信息、雇员信息等,增加易变的业务访问逻辑。为了增强扩展性,将两部分的业务解耦的一种设计模式。 二…

详解 SpringMVC 中获取请求参数

文章目录 1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、[RequestParam ](/RequestParam )4、[RequestHeader ](/RequestHeader )5、[CookieValue ](/CookieValue )6、通过POJO获取请求参数7、解决获取请求参数的乱码问题总结 在Spring MVC中,获取请…

自建音乐播放器之一

这里写自定义目录标题 1.1 官方网站 2. Navidrome 简介2.1 简介2.2 特性 3. 准备工作4. 视频教程5. 界面演示5.1 初始化页5.2 专辑页 前言 之前给大家介绍过 Koel 音频流服务,就是为了解决大家的这个问题:下载下来的音乐,只能在本机欣赏&…

【pyqt5界面化工具开发-12】QtDesigner图形化界面设计

目录 0x00 前言 一、启动程序 二、基础的使用 三、保存布局文件 四、加载UI文件 0x00 前言 关于QtDesigner工具的配置等步骤(网上链接也比较多) 下列链接非本人的(如果使用pip 在命令行安装过pyqt5以及tools,那么就可以跳过…

springboot整合SpringSecurity

先写了一个配置类 给这个访问路径,加上角色权限 package com.qf.config;import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; impo…

【网络编程上】

目录 一.什么是互联网 1.计算机网络的定义与分类(了解) (1)计算机网络的定义 (2)计算机网络的分类 ① 按照网络的作用范围进行分类 ②按照网络的使用者进行分类 2.网络的网络 (理解&#xf…

苹果Mac系统如何优化流畅的运行?提高运行速度

Mac系统的稳定性和流畅性一直备受大家称赞,这也是大多数人选择Mac的原因,尽管如此,我们仍不时地对Mac进行优化、调整,以使其比以前更快、更流畅地运行。以下是小编分享给各位的Mac优化方法,记得保存哦~ 一、释放被过度…

【笔记】常用 js 函数

数组去重 Array.from(new Set()) 对象合并 Object.assign . 这里有个细节:当两个对象中含有key相同value不同时,会以 后面对象的key:value为准 保留小数点后几位 toFixed 注意: Number型,用该方法处理完,会…

Markdown Preview Plus Chrome插件使用

Markdown Preview Plus Chrome插件使用 1.插件说明2.插件下载3.插件配置4.文档样式4.1 网页显示4.2 导出PDF 系统:Win10 Chrome:113.0.5672.127 Markdown Preview Plus:0.7.3 1.插件说明 一般 markdown 工具自带的预览功能比较简单&#xff…

RTPEngine 通过 HTTP 获取指标的方式

文章目录 1.背景介绍2.RTPEngine 支持的 HTTP 请求3.通过 HTTP 请求获取指标的方法3.1 脚本配置3.2 请求方式 1.背景介绍 RTPEngine 是常用的媒体代理服务器,通常被集成到 SIP 代理服务器中以减小代理服务器媒体传输的压力,其架构如下图所示。这种使用方…

人工智能论文通用创新点(一)——ACMIX 卷积与注意力融合、GCnet(全局特征融合)、Coordinate_attention、SPD(可替换下采样)

1.ACMIX 卷积与注意力融合 论文地址:https://arxiv.org/pdf/2111.14556.pdf 为了实现卷积与注意力的融合,我们让特征图经过两个路径,一个路径经过卷积,另外一个路径经过Transformer,但是,现在有一个问题,卷积路径比较快,Transformer比较慢。因此,我们让Q,K,V通过1*1的…

jmeter 线程组

在jmeter中,通过指定并发数量、启动延迟时间和持续时间,并组织示例(Samplers)在多个线程之间的执行方式,实现模拟并发用户的行为。 添加线程组: 在测试计划中,右键点击“添加” -> “Thread…

Android 1.1 背景相关与系统架构分析

目录 1.1 背景相关与系统架构分析 分类 Android 基础入门教程 1.Android背景与当前的状况 2.Android系统特性与平台架构 系统特性: 平台架构图: 架构的简单理解: 3.本节小结: 1.1 背景相关与系统架构分析 分类 Android 基础…

服务器数据恢复-vmware ESXI虚拟机数据恢复案例

服务器数据恢复环境: 从物理机迁移一台虚拟机到ESXI,迁移后做了一个快照。该虚拟机上部署了一个SQLServer数据库,存放了5年左右的数据。ESXI上有数十台虚拟机,EXSI连接了一台EVA存储,所有的虚拟机都在EVA存储上。 服务…

Unity中Shader的遮罩的实现

文章目录 前言一、遮罩效果的实现主要是使用对应的纹理实现的,在属性中暴露对应的遮罩纹理,对其进行采样后,最后相乘输出即可二、如果需要像和主要纹理一样流动,则需要使用和_Time篇一样的方法实现流动即可 前言 Unity中Shader的…

protues仿真时有时候串口虚拟中端不弹窗的问题

在使用proteus的时候,有时候你会发现点击调试开始运行后,串口虚拟终端没有自动弹窗的问题,其实照成这种现象的原因是你在使用的过程中移动了器件位置或者是对整个视窗使用鼠标滚动进行缩放了,如果要重新弹窗则需要进行以下操作: …

Echart笔记

Echart笔记 柱状图带背景色的柱状图将X与Y轴交换制作为进度条 柱状图 带背景色的柱状图 将X与Y轴交换制作为进度条 //将X与Y轴交换制作为进度条 option { xAxis: {type: value,min:0,max:100,show:false,//隐藏x轴},yAxis: {type: category,data:[进度条],show:false,//隐…