CXL寄存器介绍(3)- CXL MMIO

2023-12-01 19:10
文章标签 介绍 寄存器 cxl mmio

本文主要是介绍CXL寄存器介绍(3)- CXL MMIO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



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


📢 声明

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

文章目录

  • 0. 引言
  • 1. CXL RCRB
    • 1.1 RCRB 基地址
    • 1.2 RCH DP RCRB
    • 1.3 RCD UP RCRB
  • 2. CXL Component Registers
    • 2.1 RCH/RCD Component Register
    • 2.2 Component Register for ALL Other CXL Components
    • 2.3 CXL CHBCR
  • 3. 参考


0. 引言

  CXL Device/Port 相关寄存器一部分位于 PCIe 配置空间内,一部分位于 MMIO 空间内。早前《CXL寄存器分类》简单介绍了 CXL 的寄存器分布及 CXL 相关的 DVSEC,接下来进一步介绍下 MMIO 中的 CXL RCRB 及 Component Registers。



1. CXL RCRB

  CXL RCH DP 及 RCD UP 没有配置空间,通过扫描 PCIe 配置空间的方式无法发现 RCH DP 及 RCD UP。RCH DP 及 RCD UP 相关的寄存器实现在了 RCRB 范围内。

  RCRB 功能类似于 PCIe 配置空间,其内部实现了 CXL 链路相关控制、状态寄存器及各种所需的能力结构。Flex Bus Port DVSEC 是所有 Port RCRB 中必须实现的能力结构,相关介绍可参考《CXL DVSEC》PCIe DVSEC for Flex Bus Port。

1.1 RCRB 基地址

  RCRB 的基地址由 System Firmware 指定,

  • 对于 eRCD,其 RCRB 基地址由 System Firmware 直接指定;
  • 对于工作在 RCD Mode 的 RP 或 DSP,System Firmware 通过配置 PCIe 配置空间中的 CXL DVSEC ID3 中的 RCRB Base/Base_High 并使能 RCRB 来指示 RCRB 的基地址;
  • 对于 RCD UP(只能是 eRCD UP 不能为 USP,eRCH 下不能直接挂载 USP),RCD 捕获复位之后收到的第一笔 MRd(CXL 1.1 时 MWr/MRd 均可)的地址(低 12b 清零)作为 RCRB 地址。

  上述 RCH 和 RCD 的 RCRB 占用相邻的两个 4KB 地址空间,RCRB 的地址范围不能与 Device 配置空间及内存空间出现交叠。

1.2 RCH DP RCRB

  下图是 RCH DP RCRB 寄存器布局图,其带有 Type 1 类型的配置头。RCRB 中的 MEMBAR0 用以指示该 Port 相关的 Component 寄存器在 MMIO 中的基地址。

在这里插入图片描述

1.3 RCD UP RCRB

  下图是 RCD UP RCRB 寄存器布局图,其带有 Type 0 类型的配置头。对于 RCD UP RCRB,其:

  • MEMBAR0 用以指示该 Port 相关的 Component 寄存器在 MMIO 中的基地址;
  • Config Header 中 的 Command 寄存器及 Status 寄存器 Reserved;
  • Device Capabilities、Control、Status 及 Device Capabilities 2、Control 2、Status 2 Reserved;
  • Device/Port Type、Slot 实现、中断消息数量等字段均 Reserved。

在这里插入图片描述



2. CXL Component Registers

  早前简单介绍了 CXL 的寄存器分布、CXL 相关的 DVSEC 及 MMIO 中的 CXL RCRB,接下来进一步介绍下 MMIO 中的 Component Registers。

2.1 RCH/RCD Component Register

  CXL Component Register 包括 CXL.io、CXL.cachemem、CXL ARB/MUX 寄存器等常规 CXL Component 的寄存器,对于实现了 RCRB 的 RCH 及 RCD,该寄存器块唯一 RCRB MEMBAR 内;对于未实现 RCRB 的 RCD 该寄存器块位于 Register Locator DVSEC 指定的 PCIe BAR MMIO 空间内;对于 CXL Host Bridge,该寄存器块位于 CHBCR 内,由 ACPI CEDT 指定其在 Memory Mapped 空间内的基地址。

  CXL Component Register 寄存器块 Size 为 64KB,按照地址从前到后的顺序分别为:

  • CXL.io 寄存器块,4KB;预留。
  • CXL.cachemem 寄存器块 1,4KB;
  • 预留给 CXL.cachemem 的扩展寄存器块,48KB;
  • CXL ARB/MUX 寄存器块,1KB;
  • 预留 7KB。

2.2 Component Register for ALL Other CXL Components

  其他 CXL Component 的寄存器块,比如:

  • BAR Virtualization ACL Register Block
  • CPMU Register Block
  • CXL Device Register
  • Designated Vendor Specific Register

  这组寄存器的具体类型及位置 由 Register Locator DVSEC 来指定。

2.3 CXL CHBCR

  CXL 主桥中用以控制一到多个 RP 相关功能的 Component Register Block,其基地址从 ACPI CEDT 中取得。



3. 参考

  1. CXL Base Spec, r3.0

— END —


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

⬆️ 返回顶部 ⬆️

这篇关于CXL寄存器介绍(3)- CXL MMIO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优

Java实现本地缓存的常用方案介绍

《Java实现本地缓存的常用方案介绍》本地缓存的代表技术主要有HashMap,GuavaCache,Caffeine和Encahche,这篇文章主要来和大家聊聊java利用这些技术分别实现本地缓存的方... 目录本地缓存实现方式HashMapConcurrentHashMapGuava CacheCaffe

Spring Security介绍及配置实现代码

《SpringSecurity介绍及配置实现代码》SpringSecurity是一个功能强大的Java安全框架,它提供了全面的安全认证(Authentication)和授权(Authorizatio... 目录简介Spring Security配置配置实现代码简介Spring Security是一个功能强

JSR-107缓存规范介绍

《JSR-107缓存规范介绍》JSR是JavaSpecificationRequests的缩写,意思是Java规范提案,下面给大家介绍JSR-107缓存规范的相关知识,感兴趣的朋友一起看看吧... 目录1.什么是jsR-1072.应用调用缓存图示3.JSR-107规范使用4.Spring 缓存机制缓存是每一

Java中 instanceof 的用法详细介绍

《Java中instanceof的用法详细介绍》在Java中,instanceof是一个二元运算符(类型比较操作符),用于检查一个对象是否是某个特定类、接口的实例,或者是否是其子类的实例,这篇文章... 目录引言基本语法基本作用1. 检查对象是否是指定类的实例2. 检查对象是否是子类的实例3. 检查对象是否

什么是ReFS 文件系统? ntfs和refs的优缺点区别介绍

《什么是ReFS文件系统?ntfs和refs的优缺点区别介绍》最近有用户在Win11Insider的安装界面中发现,可以使用ReFS来格式化硬盘,这是不是意味着,ReFS有望在未来成为W... 数十年以来,Windows 系统一直将 NTFS 作为「内置硬盘」的默认文件系统。不过近些年来,微软还在研发一款名

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式