Verification Continuum™

# VC Verification IP CXL Subsystem Test Suite Release Notes

Version S-2021.06, June 2021



# **Copyright Notice and Proprietary Information**

© 2021 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, modification, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### Disclaimer

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at http://www.synopsys.com/company/legal/trademarks-brands.html.

All other product or company names may be trademarks of their respective owners.

# Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

# **Third-Party Links**

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

www.synopsys.com

# **Release Notes**

# 1 Introduction

Compute Express Link (CXL) Subsystem Test Suite provides a test environment to verify CXL Device designs implementing Compute Express Link Specification, June 2019, Revision: 1.1 and Revision: 2.0, Oct 2020.

This version of CXL Test Suite is internally qualified with updated version of 5.95a release of Synopsys DWC CXL controller for Serial topology. You can contact Synopsys support if you need to use the PIPE topology.

Refer the CXL Test Suite user guide for product features and usage.

# 2 Methodology Support

This release of the CXL Subsystem Test Suite supports the UVM methodology (version 1.1d and version 1.2).

# 3 Supported Simulators

Simulator support: VCS/VCSMX 2020.12/2020.03

# 4 Documentation

Refer the 'README' file from installed testbench for more information on example usage.

"\$DESIGNWARE\_HOME/vip/svt/cxl\_test\_suite\_svt/latest/examples/sverilog/tb\_dut\_cxl/README"

You can contact Synopsys support for CXL Subsystem Test Suite - DW Controller Integration Guide.

# 4.1 Protocol

- Compute Express Link Specification, June 2019, Revision: 1.1
- Compute Express Link Specification, Oct 2020, Revision 2.0

# 5 Notes for S-2021.06

These are the enhancements for this release:

- ❖ Added the support for PHY DUT integration in CXL TS. Refer the CXL Subsystem Test Suite UVM User Guide for features and usage notes.
  - ♦ With behavioral model, it has been validated with Pipe5.1 in SerDes architecture with PCLK as phy input and output modes.
  - ♦ With actual PHY model, it has been validated with Pipe5.1 in SerDes architecture with PCLK as phy input mode.
- ❖ Added the support for Back-Annotation of Test Pass/Fail Results (From VDB). Refer the *CXL Subsystem Test Suite UVM User Guide* for details.
- ❖ Enhanced the following PL tests involving enabling of sync header bypass to work with Host as DUT:
  - ♦ cxl\_compliance\_pl\_sync\_header\_bypass
  - ♦ cxl\_compliance\_pl\_skp\_scheduling
  - ♦ cxl\_compliance\_pl\_skp\_exiting\_data\_stream
- ♦ Updated the test cxl\_compliance\_ras\_cpl\_timeout for robustness.

# 5.1 E-STARs

Table 1 shows the list of Enhancements.

#### Table 1 Enhancements

| STAR ID | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3674797 | <b>Problem</b> : CXL Compliance 2.0: 14.13.13,14,15,16                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         | <ul> <li>Resolution: Enhanced the CXL Test Suite such that it is compliant with</li> <li>14.13.13: MMR Device Status registers capabilities header register.</li> <li>14.13.14: MMR primary mailbox register capabilities header register.</li> <li>14.13.15: MMR secondary mailbox register capabilities header register.</li> <li>14.13.16: MMR Memory device register header capabilities register.</li> </ul>                                                                                                  |
| 3686334 | Problem: CXL Compliance 2.0: 14.13.10 CXL_COMPLIANCE_MMR_HDM_DE                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|         | Resolution: Fixed the MMR test "cxl_compliance_mmr_hdm_decoder_zero_size_commit" for swap payload and timeout issue observed.                                                                                                                                                                                                                                                                                                                                                                                      |
| 3699259 | <b>Problem</b> : CXL Test APP Layer to check for Cache & Mem Enabled or not before initiating the traffic                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | <ul> <li>Pesolution:</li> <li>Updated the CXL Subsystem Test APP Layer to check for APN negotiation before initiating traffic for Cache/Mem device.</li> <li>Added the CXL Test APP Layer status attribute to pass DUT side of APN negotiation status "modified_ts_status". You can control the Cache/mem traffic generation based on this attribute.</li> <li>Full Stack topology automatically pass this information from VIP Modified TS2 Status. Other topologies by default enable both Cache-Mem.</li> </ul> |

Table 1 Enhancements

| STAR ID | Description                                                                                                                                                                         |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3373055 | Problem: CXL TS V plan information                                                                                                                                                  |
|         | Resolution: Updated the CXL Test Suite HVP to support Test Pass/Fail via VDB.                                                                                                       |
| 686098  | <b>Problem</b> : Need to create separate test lists for PCIe TS test cases and CXL applicable test cases                                                                            |
|         | Resolution: Added the PCle TS test list by-default in CXL TS. You can disable the default-inclusion with the help of macro "SVT_CXL_SUBSYSTEM_EXCLUDE_ALL_PCIE_TS_TESTS_INCLUSION". |

#### 5.2 B-STARs

Table 2 shows the list of fixed Bugs.

Table 2 Fixed Bugs

| STAR ID | Description                                                                                                                                                                                |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3689403 | Problem: False failure in CXL compliance test cxl_compliance_pl                                                                                                                            |
|         | Resolution: Fixed the PL test  "cxl_compliance_pl_link_initialization_resolution" for an observed issue in  "check_supported_spec_ver" API and its usage in the test suite.                |
| 3687345 | Problem: CXL Compliance 2.0: 14.13.10 CXL_COMPLIANCE_MMR_HDM_DE                                                                                                                            |
|         | <b>Resolution</b> : Fixed the MMR test "cxl_compliance_mmr_device_capabilities_array" for an observed failure wherein the capabilities header base address was not allocated valid values. |

# 5.3 Backward Incompatibility Changes

From this release onwards, the LPIF testlist(cxl\_lpif\_testlist.svi) and AMUX testlist(cxl\_arb\_mux\_testlist.svi) empty files are removed. The user needs to remove these files from their top.sv, if they have included them.

# 6 Known Limitations

- 1. The test enters retrain for the second time and cache/mem DL intermittently reports duplicate packet and fails. This requires VIP update and would be resolved in subsequent release.
  - ♦ cxl\_compliance\_amux\_almp\_error\_test
  - ♦ cxl\_compliance\_amux\_entry\_into\_10\_synchronization
- 2. These tests are failing with Designware CXL controller as handling of unexpected ALMP is not supported by the controller:
  - ♦ cxl\_compliance\_amux\_almp\_error\_test
  - ♦ cxl\_compliance\_amux\_recovery\_re\_entry\_test

- ♦ cxl\_compliance\_amux\_unexpected\_status\_almp\_test
- 3. Designware CXL controller after being in L0 and when the link goes to Recovery and comes back to L0, has the following issues:
  - ◆ Spurious Retry Frame before Recovery entry
  - ◆ Protocol flit before RetryAck while exiting Recovery

You can contact Synopsys support.

4. The tests cxl\_compliance\_pl\_uncorrectable\_framing\_error and cxl\_compliance\_pl\_uncorrectable\_mismatched\_pid\_error are failing with Designware CXL Controller with the following error:

```
UVM_ERROR [register_fail:ACTIVE_DL:SEQ_NUM:dl_receive_illegal_seq_num]
ProcessReceivedTLP: Received TLP with invalid seq num = 1, next_rcv_seq = 0
```

5. The test cxl\_compliance\_ll\_crc\_error\_injection\_retry\_abortDesignware CXL Controller version 5.90a GA is reporting the following failure and needs to be demoted:

```
UVM_ERROR [CXL_PROT_TYPE_CACHE].m_cxlChannelInitAgent.m_cxlChannelInitMasterDriver [m_cxlChannelInitMasterDriver] Ack is not deasserted by CXL Controller in 10000 cycles
```

- 6. The default value of Synopsys controller for CXL Cache and Mem Component registers filed array\_size is invalid. Therefore, CXL Subsystem VIP enumerate\_cxl\_device API is tweaked such that it cannot access capabilities with value greater than 8.
- 7. Synopsys DW Controller as DUT: VIP check phy\_flexbus\_tlp\_ending\_on\_flit\_boundary fails when both CXL.io and CXL.cache/mem traffic is exchanged. Synopsys DW controller sends a TLP that ends on the flit boundary.
  - Contact Synopsys support for assistance. Currently this strict rule is being discussed with CXL Consortium. Until then, this error is demoted in CXL TS.
- 8. cxl\_compliance\_amux\_almp\_error\_test might fail for few seeds with expected\_retry\_req\_received check failure.
- 9. Currently FLR Compliance Tests for section 14.9.4 (FLR Test), 14.9.5 (Flexbus Range Setup Time), 14.9.6 (FLR Memory Test) are supported for CXL 1.1 version only.
- 10. For these tests, you can contact Synopsys support:
  - ♦ cxl\_compliance\_rit\_flexbus\_range\_setup\_time
- 11. Following tests have been validated only with VIP-VIP b2b set up and should be excluded from simulations with DWIP because of known limitations.
  - a. CXL Power Management:
    - ♦ ts.cxl\_compliance\_amux\_l1x\_state\_resolution.sv
    - ts.cxl\_compliance\_amux\_l1x\_pm\_state\_request\_rejection\_test.sv
    - \$ ts.cxl\_compliance\_amux\_active\_to\_12\_transition\_test.sv
    - ♦ ts.cxl compliance amux active to l1x transition.sv
    - ♦ ts.cxl\_compliance\_amux\_l1x\_to\_active\_transition.sv
  - b. Drift Buffer and Sync Header Bypass are not supported till 5.90a version of IIP:
    - ts.cxl\_compliance\_pl\_sync\_header\_bypass.sv
    - \$ ts.cxl\_compliance\_pl\_skp\_scheduling.sv
    - ts.cxl\_compliance\_pl\_skp\_exiting\_data\_stream.sv

- \$ ts.cxl\_compliance\_pl\_drift\_buffer\_enable.sv
- c. Device DWIP tries to enter into L1 state when D3 is initialized. For 1.1, this is a limitation and for 2.0 specification ambiguity is observed, which is being discussed with Consortium. Below tests also require PM VDM response from RTL. (DWIP does not support PM VDM. So RTL/Application has to perform this handshake)
  - ts.cxl\_compliance\_rit\_warm\_reset.sv
  - ts.cxl\_compliance\_rit\_sleep\_state.sv
  - ts.cxl\_compliance\_rit\_cold\_reset.sv
- d. Control and Status registers, and Memory Mapped register feature tests (14.8, 14.13):
  - ♦ IDE, HDM, device Capability, GPF, DOE, Non-CXL Function, Register locator: These capabilities need to be implemented out of DW CXL Controller.
  - ♦ CXL TS validated these tests with VIP-VIP setup only.
- e. Security Feature Tests (14.11):
  - ♦ IDE feature is not supported by DW CXL Controller.
  - ♦ CXL TS validated these tests with VIP-VIP setup only.
- 12. The cxl\_compliance\_amux\_reset\_entry and cxl\_compliance\_pl\_protocol\_id\_check tests may fail for few seeds with transaction\_inactivity\_timeout failure and the following error:

```
UVM ERROR
```

uvm\_test\_top.env.host\_env.cache\_mem\_env.host[0].tl\_driver [sample\_response\_and\_data]
{ADDR('h0) TYPE(CACHE\_D2H\_DATA\_CH\_XACT) OPCODE() ID('hd28) TAG('h0)} Received
CACHE\_D2H\_DATA\_CH\_XACT response with id('hd28), Tag('h0), LDID(0). But There is no
transaction waiting for CACHE\_D2H\_DATA\_CH\_XACT response. Hence, ignoring it.

This error is observed as currently CXL VIP doesn't support data before response scenarios for H2D Snoop transactions.

- 13. Following test may fail with the mentioned UVM\_WARNING due to one of the VIP behaviors which is being discussed:
  - ♦ cxl\_compliance\_pl\_eds\_token

```
UVM WARNING
```

[register\_fail:ACTIVE\_DL:REPLAY:dl\_replay\_timer\_timeout] UpdateReplayTimer: Replay timer
timed out. replay\_timer\_limit = 31000

Contact Synopsys support for the same.

- 14. Following PL tests are currently not applicable for Host DUT mode:
  - ♦ cxl\_compliance\_pl\_sync\_header\_bypass
  - ♦ cxl\_compliance\_pl\_skp\_scheduling
  - ♦ cxl\_compliance\_pl\_skp\_exiting\_data\_stream
- 15. Following MMR tests may fail when run with Synopsys IIP as controller, since Synopsys IIP does not program respective memory mapped registers by default. Contact Synopsys support for any further details.
  - ♦ cxl\_compliance\_mmr\_device\_capabilities\_array
  - ♦ cxl\_compliance\_mmr\_device\_status\_registers\_capabilities\_header\_register

- ♦ cxl\_compliance\_mmr\_primary\_mailbox\_registers\_capabilities\_header\_register
- ♦ cxl\_compliance\_mmr\_secondary\_mailbox\_registers\_capabilities\_header\_register
- cxl\_compliance\_mmr\_memory\_device\_registers\_capabilities\_header\_register
- 16. Following Arb-Mux compliance tests may fail with the error signature as illustrated when run with 'CXL.IO only' topology in CXL 2.0 mode.
  - ♦ cxl\_compliance\_amux\_almp\_error\_test
  - ◆ cxl compliance amux entry into 10 synchronization
  - ♦ cxl\_compliance\_amux\_recovery\_re\_entry\_test
  - ♦ cxl\_compliance\_amux\_unexpected\_status\_almp\_test
  - ♦ cxl\_compliance\_amux\_rst\_to\_active\_transition

## **Error Signature:**

UVM\_ERROR [body : SNPS\_CXL\_TS\_COMPLIANCE] Sequence is not applicable when only one protocol(IO only) is enabled

17. The SVT\_DEBUG\_OPTS is not supported for CXL TestSuite Test Application layer component.

# 7 Notes for Previous Releases

#### 7.1 Notes for R-2021.03-2

These are the enhancements for this release:

- ❖ Fixed the PL Drift Buffer test for an observed constraint failure issue under all topologies.
- ❖ DWIP version specific example compile files are delivered as part of TS (under *tb\_dut\_cxl/dut/iip\_<version>* directory). Refer *Appendix A* section in *CXL Subsystem Test Suite UVM User Guide* for details.
- ❖ Added back the support for native application interface (Channel protocol interface) for Cache.Mem for 5.80a version of DWIP also. There is no backward incompatibility now.
- ❖ Added raise and drop objection for 'svt\_cxl\_subsystem\_ts\_base\_sequence' class so that it is not required to set in the derived sequences.
- ♦ Updated the svt\_cxl\_subsystem\_ts\_compliance\_crt\_doe\_capabilities\_sequence for lookup for CRT table access DOE in all different DOE capabilities.
- ❖ Updated the `include\_file macro to resolve compile failure when using the VCS p1800\_macro\_expansion option.
- Enhanced the TLP Ends on Flit Boundary and sticky register tests to run with Full stack and IO only topologies. Checks related to Cache-Mem memory mapped registers are bypassed during IO only runs as the Cache-Mem memory mapped registers are not enumerated when Cache-Mem is absent.
- ❖ Fixed the CXL 1.1 MDT tests (14.7.1 and 14.7.2). These tests can now run seamlessly with IIP versions that are CXL 2.0 capable but runs in CXL 1.1 mode.
- ❖ Added the Compliance Test for section 14.11.3.5.3:
  - ts.cxl\_compliance\_ide\_no\_mac\_inserted\_in\_mac\_epoch.sv

#### 7.1.1 E-STARs

Table 3 shows the list of Enhancements.

Table 3 Enhancements

| STAR ID | Description                                                                                                                                                                                                                     |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3627217 | Problem: Multiple DOE Capability Enumeration                                                                                                                                                                                    |
|         | Resolution: DOE capabilities base addr is stored in ep_enumeration_status.ext_cap_base_addr[index] where index is => {24'h0,8'h DOE Cap Instance,16'h Cap ID, 16'h Target BDF}. DOE Types enumeration via all DOE capabilities. |
| 3647193 | Problem: Compilation issue with the PCIe TS tests included as part of CXL TS execution.                                                                                                                                         |
|         | <b>Resolution</b> : Added the PCIe TS packages import in top module to resolve the issue:  import svt_pcie_test_suite_uvm_pkg::*;  import snps_pcie_test_suite_pkg::*;                                                          |
| 3644300 | Problem: Enhancement: CXL Device Capabilities Array Register                                                                                                                                                                    |
|         | Resolution: Updated the cxl_compliance_mmr_device_capabilities_array test for Steps 5 to 11 in section 14.13.12                                                                                                                 |

#### 7.1.2 B-STARs

Table 4 shows the list of fixed Bugs.

Table 4 Fixed Bugs

| STAR ID | Description                                                                                                                                                    |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3644348 | Problem: UVM FATAL for ep_enumeration_status for Device Full stack VIP                                                                                         |
|         | <b>Resolution</b> : Added check for Host VIP to enable EP enumeration status get via config DB. Refer <i>CXL Subsystem VIP documents</i> for more information. |

# 7.2 Notes for R-2021.03-1

These are the enhancements for this release:

- ❖ Enabled the parameter, "enable\_gen4\_added\_imp\_note" by default for PCIe TS tests used in CXL framing.
- ❖ Updated the EP Enumeration status for DVSEC/VSEC storage. Refer CXL Subsystem Release notes for more information.
- ♦ Moved the macros, "`SVT\_CXL\_SUBSYSTEM\_TS\_GEN\_TL\_CACHE\_MEM\_TRAFFIC" and
  "`SVT\_CXL\_SUBSYSTEM\_TS\_GEN\_CXL\_IO\_TRAFFIC" with
  "svt\_cxl\_subsystem\_ts\_api\_base\_sequence.sv" base sequence API
  "generate\_random\_cxl\_io\_traffic" and "generate\_random\_cxl\_tl\_cm\_traffic".
  Refer the HTML Class Reference Guide present at the following location for details on the API:

\$DESIGNWARE\_HOME/vip/svt/cxl\_test\_suite\_svt/latest/doc/cxl\_test\_suite\_svt\_uvm\_reference/html/index

\* CXL enumeration for PCIe TS Tests:

While executing the PCIe TS tests, CXL Memory mapped registers enumeration supported is added in CXL TS.

- ◆ Use plusargs "EN\_CXL\_ENUMERATION\_FOR\_PCIE\_TS\_TEST\_IN\_CXL" or base test attribute "enable\_cxl\_enumeration\_for\_pcie\_ts\_test" when executing PCIe TS tests in CXL Mode.
- ◆ Added the PCIe TS configurations for this support using the test "svt\_cxl\_subsystem\_with\_pcie\_ts\_base\_test".
  - ♦ Virtual method "configure\_pcie\_ts\_for\_cxl\_enumeration" has been added with following configuration. You can override this method in extended class.
    - "enable\_post\_enumeration\_user\_seq" is set through config db. This has been added to setup Post enumeration user sequence for PCIe TS.
    - "enable\_user\_sequece" config DB is enabled.
- ◆ Added the "initiate\_enumeration\_for\_pcie\_ts\_tests" in CXL Base test that gets triggered in "run\_phase".
  - ♦ Wait for PCIe Enumeration done and de-assert the status attribute for further processing.
  - ♦ Trigger CXL Memory mapped registers enumeration based on spec version negotiated.
  - ♦ Again assert "enumeration\_done" of PCIe TS status class.
- ♦ Added the sequence

"svt\_pcie\_ts\_device\_system\_virtual\_tl\_post\_enumeration\_seq" in CXL Env sequence collection. The overall responsibility of this sequence is to delay the PCIe TS test execution after enumeration so that CXL memory mapped registers can be enumerated first.

- ♦ This sequence wait for "enumeration\_done" to be de-asserted first and then wait for assertion.
- ♦ Alternate implementation is available in the sequence to use "delay" based approach.

To enable this feature, you can set the config-db for

"enumeration\_status\_or\_delay\_based\_framework" and set the delay using "hold\_pcie\_test\_exec\_delay\_in\_ns".

- ❖ CXL 1.1 device: Removed the first MWr TLP for RCRB area in "enumerate\_cxl\_device" as "CXL 1.1 Upstream Port RCRB" section of CXL 2.0 specification states that TLP should be MRd.
- Links Enhanced the Sticky Register test (ts.cxl\_compliance\_srt\_sticky\_register.sv) to work in Full Stack topology.
- ❖ Updated the base test API, "initiate\_primitive\_io\_cm\_basic\_init\_seq" as illustrated:
  - ♦ Added a wait for cxl\_enumeration\_completed before reading the PCIe capability register base address required for FLR testing (reading FLR capability).
- Corrected the register checking for Drift Buffer test (ts.cxl\_compliance\_pl\_drift\_buffer\_enable.sv) to qualify it for VIP-IIP.
- ❖ Updated the enumeration API, enumerate\_cxl\_device() to trigger only when APN has been negotiated successfully and the flexbus component is enabled.

- ❖ Updated the API call for enumerate\_cxl\_cache\_mem\_memory\_mapped\_registers() to enable the calling only when the cache-mem is active. The API initially was getting called even when the cache-mem was not active.
- Updated the TLP end on flit boundary test/sequence (ts.cxl\_compliance\_pl\_tlp\_ends\_on\_flit\_boundary.sv) to avoid constraint failure in internal regressions.
- **CXL2.0** Version support for FLR Tests (EA):
  - ♦ cxl\_compliance\_rit\_flr\_test
  - ♦ cxl\_compliance\_rit\_flr\_memory\_test

This test fails if the DUT is not mem capable.

- ♦ cxl\_compliance\_rit\_flr\_flexbus\_range\_setup\_time
  - ♦ This test fails if the DUT is not mem capable.
  - ♦ Uses Hot Reset (link down) in CXL 1.1 mode.
  - ♦ Initiates CXL Device Reset via 8.1.3.4 DVSEC CXL Control2 (Offset 10h) bit[2] in CXL 2.0 mode.
- ◆ Added the new compliance test, cxl\_compliance\_rit\_cxl\_reset\_test (applicable only for CXL 2.0).
- ◆ Verified the cxl\_compliance\_rit\_cxl\_reset\_test and cxl\_compliance\_rit\_flr\_flexbus\_range\_setup\_time in VIP back to back setup.

**Note**: It is not yet validated with Synopsys DWC CXL controller.

All 4 Reset tests mentioned above are expected to undergo some structural updates in the April monthly release for more effective use model. You can refer the CXL User Guide for more details.

- Updated the RAS Feature Tests:
  - cxl\_compliance\_ras\_unexpected\_cpl
  - cxl\_compliance\_ras\_cpl\_timeout

  - ◆ Updated the API call by passing relevant arguments to subroutine

```
set_cxl_ts_app_algorithm_configuration(app_cfg,enable_host)
```

- ◆ Removed the redundant API call for initiate\_primitive\_io\_cm\_basic\_init\_seq(). The API was getting triggered twice while executing cxl\_compliance\_ras\_unexpected\_cpl test.
- ◆ Validated the tests with Synopsys Controller with error injection from VIP end.
- ❖ Added the following tests as part of section 14.13.9 CXL HDM Decoder Commit CXL2.0 MMR Compliance Test implementation:
  - ♦ ts.cxl compliance mmr hdm decoder commit.sv
- Updated the AMUX tests to enable the enumeration for VIP-DUT scenario.

#### 7.3 Notes for R-2021.03

These are the enhancements for this release:

Tests added for the sections:

- **♦** 14.9.5, 14.9.9
- **♦** 14.8.24
- **♦** 14.15.1
- **♦** 14.11.3.5.1
- **♦** 14.13.8, 14.13.10, 14.13.12.
- ❖ License Changes CXL 2.0 TestSuite is enabled in LIBRARY-19.
- ♦ The mem\_bar\_mapped\_to\_internal\_reg attribute is mapped to CSR Status class.
- ❖ The global timeout enable issue has been fixed. The default value of disable\_global\_timeout must be disabled.
- ❖ CXL 1.1 Specification applicable RCRB next capability offset as '100h' check is fixed .To disable this check a variable disable\_cxl\_1\_1\_upstream\_port\_rcrb\_nxt\_cap\_off\_check =0 has been added.
- ❖ Updated the enumeration API enumerate\_cxl\_device() to use link\_num in the CFG/MEM traffic generation.
- ❖ Fixed the typos in the enumeration API in Device Register interface.
- CXL 2.0 compliance tests for Section 14.9.9, 14.13.8, 14.13.10 and 14.13.12 are validated in VIP-VIP mode only.
- Removed calling of create\_cfg() multiple times. (Tests are not required to guard code with create\_cfg\_called flag of base test) create\_cfg() method is now called only once.
- ♦ Host DUT Address randomization in macro SVT\_CXL\_SUBSYSTEM\_TS\_GEN\_CXL\_IO\_TRAFFIC is updated to exclude memory ranges.

#### 7.4 Notes for R-2020.12-2-T-20200129

These are the enhancements for this release:

- CXL 2.0 Compliance Tests added for the sections:
  - **♦** 14.8.9, 14.8.15, 14.8.16, 14.8.17, 14.8.18, 14.8.19, 14.8.20
  - **◆** 14.13.1, 14.13.2, 14.13.4, 14.13.5, 14.13.7
  - **♦** 14.11.3.3
  - **♦** 14.14.1, 14.14.2.
- ❖ CXL 1.1 Compliance Tests added for the sections:
  - **♦** 14.4.5
  - **◆** 14.5.15.1

# 7.5 Notes for R-2020.12-2

These are the enhancements for this release:

A new attribute disable\_global\_timeout is added in svt\_cxl\_subsystem\_base\_test to enable or disable the global timeout mechanism with the default setting of global timeout in disabled mode. If it is enabled, then the global\_timeout attribute is used to configure the global timeout of the test

and you can override this attribute in extended test.

Also, you can re-define the macro in testbench SVT\_CXL\_SUBSYSTEM\_TEST\_TIMEOUT to override the default value.

- CXL 2.0 Compliance Tests added for the sections:
  - **♦** 14.11.3.4
  - **♦** 14.11.3.1

#### 7.6 Notes for R-2020.12-1-T-20201221

These are the enhancements for this release:

- ❖ CXL 1.1 Compliance Tests for sections 14.4.9.3, 14.9.5, 14.10.1.2, and 14.10.1.9
- CXL 2.0 Compliance Tests added for the sections:
  - **♦** 14.4.1, 14.4.2, 14.4.3
  - **◆** 14.6.15, 14.6.16
  - **♦** 14.8.1, 14.8.2, 14.8.3, 14.8.4, 14.8.5, 14.8.6, 14.8.7, 14.8.8, 14.8.23
  - **♦** 14.9.8.2
  - **♦** 14.10.1
- ❖ Existing CXL 1.1 Tests updated to support Execution with CXL 2.0 Device DUT

#### 7.7 Notes for R-2020.12

These are the enhancements for this release:

❖ VIP version is updated as R-2020.12.

## 7.8 Notes for R-2020.09-3-T20201125

These are the enhancements for this release:

❖ Added Compliance tests for section 14.9 and 14.10.

## 7.8.1 Backward Incompatibility Changes

From this release onwards for Test Suite, the Cache.Mem stack support with DWC CXL controller version can be 5.90-ea01 or later (The impact is only when channel protocol environment in VTB is used as a BFM to communicate with VIP CacheMem TL, which indicates FULL\_STACK mode with DWC CXL controller).

This is because of backward incompatible change introduced in CXL Channel Protocol environment related packages/agents of DWC CXL Controller (For example, cxlPkg is now split to cxlTypesPkg).

#### 7.9 Notes for R-2020.09-2-T-20201030

These are the enhancements for this release:

- ❖ Added a new sequence for back door programming to enable Cache/Mem for Synopsys DWC CXL Controller.
- ♦ Added compliance tests for Sections: 14.4, 14,5, 14.9, and 14.10.

#### 7.10 Notes for R-2020.09-1

- ❖ For all compliance (cxl\_compliance\_\*) tests, Type(1/2/3) of the CXL Device is updated based on flexbus capability after APN negotiation is successful.
- svt\_cxl\_subsystem\_ts\_virtual\_tasks\_to\_be\_overriden\_by\_user\_sequence class is added which contains virtual methods/tasks that need to be overridden by you based on DUT implementation. Compliance test sequences invoke those methods in their body() methods.
- Compliance Tests for Section: 14.4.3, 14.4.4, 14.4.6, 14.4.8

Note: Validation criteria for above mentioned tests are limited to VIP-VIP b2b set up.

- Enumeration Updates
  - CXL DVSEC and CXL Test DVSEC finding loop is modified to exit at null extended capability only.
  - ◆ Fixed the Capability ID capture from payload from proper bits.
  - ◆ Updated Enumeration to resolve conflict with RCRB, MEMBAR0 and BAR Ranges.

## 7.11 Notes for Q-2020.06-3

- CXL Test Application Layer for Device DUT.
  - ◆ Algorithm 1a,1b and 2 for CXL.Cache.

**Note**: Full cache-line is processed currently.

♦ Compliance test for sections: 14.3.6.1.2, 14.3.6.1.3, 14.4.2, 14.5.10, 14.5.11, 14.5.12, 14.7.1, 14.7.2, 14.8.1.

#### 7.12 Notes for Q-2020.06-2

- Env framework for integration of DWC\_CXL Controller DUT Protocol If: PIPE 5.1(SerDes Arch), Application IF: CXL.\$ Native IF (Product: Compile Only).
- \* Remove '+define+SVT\_CXL\_SUBSYSTEM\_EXCLUDE\_PCIE\_TS\_DATA' from the sim\_build\_options if you are doing the following:
  - a. Integrating DUT
  - b. Running PCIe TestSuite Tests

Removing this define will bring in PCIe TestSuite.

- CXL.Cache Integration Test
- CXL Test Application Layer for Device DUT:
  - ◆ Algorithm 1b & 2 for CXL.io Device.
  - ◆ Algorithm 1a,1b & 2 for CXL.Mem
- **❖** Compliance tests for section: 14.3.6.1.4, 14.4.1, 4.5.7.

# 7.13 Notes for Q-2020.06-1-T-20200619

- CXL Upstream port RCRB and MEMBAR0 enumeration and hooks in enumeration sequence.
- CXL Test Application Layer for Device DUT to support Algorithm 1a for CXL.io Device.
- Env framework for integration of DWC\_CXL Controller DUT Protocol If: Serial IF, Application IF: CXL Cache/Memory Native only (Product: Compile Only).

- ♦ 10 Compliance Tests added from chapter 14.5 and 14.6.
- ♦ tb\_dut\_cxl testbench is enhanced to disable Subsystem Internal debug prints. You can enable through ENABLE\_CXL\_SUBSYSTEM\_MESSAGES.

# 7.14 Notes for Q-2020.03-3-T-20200522

❖ This is the first release for CXL Subsystem Test Suite.