#### 

Architectures, Solutions, and Community VIRTUAL EVENT, APRIL 11-12, 2023

## Introduction to CXL Fabrics

Presented by Vincent Haché Director of Systems Architecture, Rambus



### Introduction to CXL Fabrics

- CXL 3.0 Overview
- Transport Level Details
- Routing Model
- Fabric Management Architecture
- Specification Roadmap



### **CXL 3.0 Specification**

Fabric capabilities and management

Improved memory sharing and pooling

Symmetric coherency

**Peer-to-peer** 

## Expanded capabilities for increasing scale and optimizing resource utilization

- Fabric capabilities and fabric attached memory
- Enhance fabric management framework
- Memory pooling and sharing
- Peer-to-peer memory access
- Multi-level switching

- Near memory processing
- Multi-headed devices
- Multiple Type 1/Type 2 devices per root port
- Fully backward compatible to CXL 2.0, 1.1, and 1.0
- Supports PCIe® 6.0



### CXL 3.0 Spec Feature Summary

| Features                                     | CXL 1.0 / 1.1 | CXL 2.0      | CXL 3.0      |
|----------------------------------------------|---------------|--------------|--------------|
| Release date                                 | 2019          | 2020         | 2022         |
| Max link rate                                | 32GTs         | 32GTs        | 64GTs        |
| Flit 68 byte (up to 32 GTs)                  | $\checkmark$  | $\checkmark$ | $\checkmark$ |
| Flit 256 byte (up to 64 GTs)                 |               |              | ✓            |
| Type 1, Type 2 and Type 3 Devices            | $\checkmark$  | ✓            | $\checkmark$ |
| Memory Pooling w/ MLDs                       |               | ✓            | $\checkmark$ |
| Global Persistent Flush                      |               | ✓            | $\checkmark$ |
| CXL IDE                                      |               | ✓            | ✓            |
| Switching (Single-level)                     |               | ✓            | $\checkmark$ |
| Switching (Multi-level)                      |               |              | ✓            |
| Direct memory access for peer-to-peer        |               |              | ✓            |
| Symmetric coherency (256 byte flit)          |               |              | ✓            |
| Memory sharing (256 byte flit)               |               |              | ✓            |
| Multiple Type 1/Type 2 devices per root port |               |              | ✓            |
| Fabric capabilities (256 byte flit)          |               |              | $\checkmark$ |

Not supported

Supported



### CXL Fabrics – Motivation and Overview

- Disaggregated, Composable Systems Pooled Host, Device and Memory Resources
- Scale-out Systems HPC/ML/Analytics
- Add capabilities to expand CXL from node to small number of racks
- Limited by 12b ID space (4k IDs)
- Scale beyond tree-based topologies
- Does not compromise node level properties



Where m <= 4K Source Port IDs



### CXL Fabrics – Composability

EP binding from across fabric:

- Host sees up to 2 layers of standard switches: host edge and downstream edge
- Enables re-use of existing host SW







### **CXL** Fabrics – Scale-Out

- Global Fabric Attached Memory (G-FAM):
- Highly-scalable memory pool e.g., 2000+ hosts accessing a memory pool of 2000+ G-FAM devices (GFDs)
- Accessible by all hosts through Fabric Address Segment Table (FAST)





Architectures, Solutions, and Community VIRTUAL EVENT, APRIL 11-12, 2023



### **Transport Level Details**

8 | © SNIA. All Rights Reserved.

### **Transport Level Details**

Host-Based Routing (HBR)

- Covers CXL 1.1/2.0 transport protocol definitions
- Reads and writes requests are address routed
- Restricts links to a single VH cannot resolve routing otherwise





### **Transport Level Details**

- Port-Based Routing (PBR)
- Brand new flit mode in 3.0
- Transactions routed by PBR-ID:
  - Destination PBR-ID (DPID) carried by all transactions
  - Source PBR-ID (SPID) carried by select transactions as needed
- Inter-switch links can carry traffic from multiple VHs
- Supported only in 256B flit mode



#### **Transport Level Details**

PBR mode negotiated during Alternate Protocol Negotiation based on capabilities advertised in Symbols 12-14:

| 12-14 | See PCIe Base Specification<br>Specific proprietary usage when Usage =<br>010b | <ul> <li>Bits[7:0]: Flex Bus Mode Selection:         <ul> <li>Bit[0]: PCIe Capable/Enable</li> <li>Bit[1]: CXL.io Capable/Enable</li> <li>Bit[2]: CXL.mem Capable/Enable</li> <li>Bit[3]: CXL.cache Capable/Enable</li> <li>Bit[3]: CXL.cache Capable/Enable</li> <li>Bit[4]: CXL 68B Flit and VH Capable/<br/>Enable (formerly known as CXL 2.0<br/>Capable/Enable)</li> <li>Bits[7:5]: Reserved</li> </ul> </li> <li>Bits[23:8]: Flex Bus Additional Info:         <ul> <li>Bits[23:8]: Flex Bus Additional Info:</li> <li>Bits[9]: Reserved</li> <li>Bit[9]: Reserved</li> <li>Bit[10]: Sync Header Bypass<br/>Capable/Enable</li> <li>Bit[11]: Latency-Optimized 256B Flit<br/>Capable/Enable</li> <li>Bit[12]: Retimer1 CXL Aware<sup>1</sup></li> <li>Bit[13]: Reserved</li> <li>Bit[14]: Retimer2 CXL Aware<sup>2</sup></li> <li>Bit[15]: CXL.io Throttle Required at<br/>64 GT/s</li> <li>Bits[17:16]: CXL NOP Hint Info[1:0]</li> <li>Bits[23:19]: Reserved</li> </ul> </li> <li>Bits[23:19]: Reserved</li> </ul> |
|-------|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-------|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



Architectures, Solutions, and Community VIRTUAL EVENT, APRIL 11-12, 2023



### **Routing Model**

### **Routing Model**

- Host requests begin in HBR format
- Host edge PBR switch converts to PBR format
- Any intermediate switches route by DPID



COMPUTE + MEMORY

STORAGE SUMMIT

### **Routing Model**

- GFDs support PBR flit mode
- All other EP types connected to Downstream edge switch
- Downstream edge converts to HBR



COMPUTE + MEMORY

STORAGE SUMMIT

Architectures, Solutions, and Community VIRTUAL EVENT, APRIL 11-12, 2023



### **Fabric Management Architecture**

### Fabric Management Architecture

Fabric Manager (FM) is responsible for:

- Fabric discovery and initialization
- Composition (binding)
- Inter-switch link management
- GFD Management
- Unbound EPs

Host manages its edge link and bound EPs





Architectures, Solutions, and Community VIRTUAL EVENT, APRIL 11-12, 2023



### **Specification Roadmap**

### **Specification Roadmap**

Items to be defined in future specification release:

- CXL Fabric Management Specification
  - PBR Switch Management
  - GFD Management
- Host-to-Host communication
- Device-to-Device communication
- Cross-domain traffic



Architectures, Solutions, and Community VIRTUAL EVENT, APRIL 11-12, 2023



### Please take a moment to rate this session.

Your feedback is important to us.