

| TITLE:             | Addition for performance monitoring events for CXL |
|--------------------|----------------------------------------------------|
|                    | memory devices                                     |
| DATE:              | Introduced date: 3/20/2024                         |
| AFFECTED DOCUMENT: | CXL 3.1                                            |
| SPONSOR:           | Rita Gupta, AMD                                    |
|                    | Raj Ramanujan, WD                                  |
|                    |                                                    |

# <u>Part I</u>

### 1. Summary of Functional Changes

This ECN defines additional set of performance events to be included as part of CXL performance monitoring unit (CPMU) definition.

#### 2. Benefits as a Result of the Changes

Enhanced performance telemetry to be available at system level for CXL device performance, especially for CXL memory devices which are part of system memory.

#### 3. <u>Assessment of the Impact</u> This is an optional feature. It will have no impact on existing implementations.

#### 4. Analysis of the Hardware Implications

This is an optional normative feature. The CXL components supporting CPMU may add additional event counters and advertise in CPMU capabilities.

#### 5. Analysis of the Software Implications

This is an optional normative feature. To take advantage of this feature, software will be required to discover and configure the bits as described in this document.

# Analysis of the Compliance and Test Implications This ECN does not repurpose any reserved bits and as such, does not impact existing C&I tests.

## <u>Part II</u>

#### **Detailed Description of the change**

Section 13.2

Addition to Table 13-5

| Event Group                  | Event Id | Mnemonic  | Event Description                                                                                                                            | Filters        | MEC |
|------------------------------|----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----|
| 8000h<br>(DDR<br>Interface)2 | 00h      | ACT Count | Counts the number of DRAM Activate commands that were issued by the Memory Controller associated with this CPMU.                             | Filter<br>ID=1 | Add |
|                              | 01h      | PRE Count | Counts the number of all DRAM Precharge commands that were issued by the Memory Controller associated with this CPMU.                        | Filter<br>ID=1 |     |
|                              | 02h      | CAS Rd    | Counts the number of all DRAM Column Address Strobe<br>read Commands that were issued by the Memory Controller<br>associated with this CPMU. | Filter<br>ID=1 |     |

|             | 03h     | CAS Wr                             | Counts the number of all DRAM Column Address Strobe write commands that were issued by the Memory Controller associated with this CPMU.                                                                                                                                                                       | Filter<br>ID=1 |    |
|-------------|---------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----|
|             | 04h     | Refresh                            | Counts the number of all DRAM Refresh commands that were issued by the Memory Controller associated with this CPMU.                                                                                                                                                                                           | Filter<br>ID=1 |    |
|             | 05h     | Self Refresh<br>Entry              | Counts the number of Self Refresh Entry commands that were issued by the Memory Controller associated with this CPMU.                                                                                                                                                                                         | Filter<br>ID=1 |    |
|             | 06h     | RFM                                | Counts the number of Refresh Management (RFM)<br>commands that were issued by the Memory Controller<br>associated with this CPMU.                                                                                                                                                                             | Filter<br>ID=1 |    |
|             | 07h     | CAS Rd AP                          | Counts the number of DRAM Column Address Strobe read<br>Commands with Auto Precharge that were issued by the<br>Memory Controller associated with this CPMU.                                                                                                                                                  | Filter<br>ID=1 |    |
|             | 08h     | CAS Wr AP                          | Counts the number of DRAM Column Address Strobe write<br>Commands with Auto Precharge that were issued by the<br>Memory Controller associated with this CPMU.                                                                                                                                                 | Filter<br>ID=1 |    |
| •           | 09h     | Refresh All<br>Banks               | Counts the number of DRAM Refresh All banks that were<br>issued by the Memory Controller associated with this CPMU.                                                                                                                                                                                           | Filter<br>ID=1 |    |
|             | 0Ah     | Refresh Same<br>Bank               | Counts the number of DRAM Refresh Same banks that were issued by the Memory Controller associated with this CPMU.                                                                                                                                                                                             | Filter<br>ID=1 |    |
|             | 0Bh     | Power Down<br>Entry                | Counts the number of DRAM Power down Entry that were issued by the Memory Controller associated with this CPMU.                                                                                                                                                                                               | Filter<br>ID=1 |    |
|             | 0Ch     | Power Down<br>Exit                 | Counts the number of DRAM Power down Exit that were issued by the Memory Controller associated with this CPMU.                                                                                                                                                                                                | Filter<br>ID=1 |    |
|             | Dh      | RD/WR DDR<br>bus switching         | count the number of times -Read to write or vice versa DDR<br>bus mode switching (DDR turnarounds) for memory<br>controller bus                                                                                                                                                                               | Filter<br>ID=1 |    |
|             | 0Eh     | Incoming Read<br>requests          | Command count for incoming read requests at memory<br>controller interface. The event is supported only in CPMU<br>associated with memory controller block. Memory controller<br>interface point and requests being counted are vendor<br>specific, additional vendor-supplied information may be<br>needed.  | Filter<br>ID=1 |    |
|             | 0Fh     | Incoming write<br>requests         | Command count for incoming write requests at memory<br>controller interface. The event is supported only in CPMU<br>associated with memory controller block. Memory controller<br>interface point and requests being counted are vendor<br>specific, additional vendor-supplied information may be<br>needed. | Filter<br>ID=1 |    |
|             | 10h-1Fh | Reserved                           | Reserved                                                                                                                                                                                                                                                                                                      |                |    |
|             |         |                                    |                                                                                                                                                                                                                                                                                                               |                |    |
| ueue<br>cy) | Üh      | RD Queue<br>Occupancy              | # of clock cycles read queue occupied is above the specified<br>threshold in the counter configuration. The event is<br>supported only when the controller implements separate<br>read and write queues.                                                                                                      | Filter<br>ID=1 | NA |
|             | 1h      | WR Queue<br>Occupancy              | # of clock cycles write queue occupied is above the specified threshold in the counter configuration. The event is supported only when the controller implements separate read and write queues.                                                                                                              | Filter<br>ID=1 | NA |
|             | 2h      | Rd/WR<br>merged Queue<br>Occupancy | # of clock cycles merged RD/WR queue occupied is above<br>the specified threshold in the counter configuration. The<br>event is supported only when the controller does not<br>implement separate read and write queues.                                                                                      | Filter<br>ID=1 | NA |
|             | 03h     | pwrdn event                        | CKE power down cycles or residency in PDN state (# of clocks )                                                                                                                                                                                                                                                | Filter<br>ID=1 | NA |

|                               | 4-1Fh               | Reserved                                           | Reserved                                                                                                                                                                                                                                                                   |                |     |
|-------------------------------|---------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----|
|                               |                     |                                                    |                                                                                                                                                                                                                                                                            |                |     |
| 8002h(Queue<br>Residency)     | Oh                  | Memory<br>controller<br>Read<br>residency<br>count | The accumulative number of clock cycles there is any<br>outstanding read pending for completion to be sent out<br>from memory controller. This counter can be used to<br>determine average latency over large number of<br>transactions when combined with command counts  | Filter<br>ID=1 | NA  |
|                               | 1h                  | Memory<br>controller write<br>residency<br>count   | The accumulative number of clock cycles there is any<br>outstanding write pending for completion to be sent out<br>from memory controller. This counter can be used to<br>determine average latency over large number of<br>transactions when combined with command counts | Filter<br>ID=1 | NA  |
|                               | 02h-1Fh             | Reserved                                           | Reserved                                                                                                                                                                                                                                                                   |                |     |
| $\mathbf{O}$                  |                     |                                                    |                                                                                                                                                                                                                                                                            |                |     |
| 8003h(Retry<br>rvents)        | Oh                  | Retry event<br>triggered by<br>read crc            | Count the retry event triggered by listed error event for the memory controller associated with this CPMU. Include host issued transaction and/or internal (patrol scrub)                                                                                                  | Filter<br>ID=1 | ADD |
| $\boldsymbol{\Theta}$         | 1h                  | Retry event<br>triggered by<br>write crc           | Count the retry event triggered by listed error event for the<br>memory controller associated with this CPMU. Include host<br>issued transaction and/or internal (patrol scrub)                                                                                            | Filter<br>ID=1 | ADD |
|                               | 2h                  | Retry event<br>triggered by<br>CA parity           | Count the retry event triggered by listed error event for the<br>memory controller associated with this CPMU. Include host<br>issued transaction and/or internal (patrol scrub)                                                                                            | Filter<br>ID=1 | ADD |
|                               | 3h                  | Retry event<br>triggered by<br>ECC                 | Count the retry event triggered by listed error event for the<br>memory controller associated with this CPMU. Include host<br>issued transaction and/or internal (patrol scrub)                                                                                            | Filter<br>ID=1 | ADD |
|                               | 4h-1Fh              | Reserved                                           | Reserved                                                                                                                                                                                                                                                                   |                |     |
| U                             |                     |                                                    |                                                                                                                                                                                                                                                                            |                |     |
| 8004h<br>(Throttle<br>Events) | 0h                  | Thermal<br>Throttle event                          | Count of cycles (# of clocks ) when the CXL memory device<br>is in any thermally throttled state (throttle state definition<br>is left to implementation choice)                                                                                                           |                | NA  |
|                               | 1h                  | Power Throttle<br>event                            | Count of cycles (# of clocks ) when the CXL memory device<br>is in any power throttled state (throttle state definition is<br>left to implementation choice)                                                                                                               |                | NA  |
| V                             | 2h-1fh              | Reserved                                           | Reserved                                                                                                                                                                                                                                                                   | NA             | NA  |
| 8005h-FFFFh                   | Reserved            | Reserved                                           | Reserved                                                                                                                                                                                                                                                                   | NA             | NA  |
|                               |                     | -                                                  | -                                                                                                                                                                                                                                                                          |                |     |
| 26h-2Fh                       | Reserved            | Reserved                                           | Reserved                                                                                                                                                                                                                                                                   | NA             | NA  |
| 30h(Devload)                  | Devload<br>encoding | Devload<br>signaled by<br>the device               | Count the # of clock cycles the device is in devload= event ID condition                                                                                                                                                                                                   |                | NA  |
| 31h(M2S<br>Residency)         | Oh                  | M2S Req<br>residency<br>count                      | The accumulative number of clock cycles there is any<br>outstanding M2S Req pending for completion to be sent out<br>to host. This counter can be used to determine average<br>latency over large number of transaction when combined<br>with command counts               |                | NA  |

|                         | 1h M2S RwD<br>residency<br>count |          | The accumulative number of clock cycles there is any<br>outstanding M2S RwD pending for completion to be sent<br>out to host. This counter can be used to determine average<br>latency over large number of transaction when combined<br>with command counts |    | NA |
|-------------------------|----------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|
|                         | 2h-1Fh                           | Reserved | Reserved                                                                                                                                                                                                                                                     |    |    |
| 32h-7FFFh               | Reserved                         | Reserved | Reserved                                                                                                                                                                                                                                                     | NA | NA |
| $\overline{\mathbf{S}}$ |                                  |          |                                                                                                                                                                                                                                                              |    |    |
|                         |                                  |          |                                                                                                                                                                                                                                                              |    |    |
| 2                       |                                  |          |                                                                                                                                                                                                                                                              |    |    |
|                         |                                  |          |                                                                                                                                                                                                                                                              |    |    |
| Ø                       |                                  |          |                                                                                                                                                                                                                                                              |    |    |
| alua                    |                                  |          |                                                                                                                                                                                                                                                              |    |    |