

# **Arm® Server Base System Architecture**

Revision: r3p0

# **Architecture Compliance Test Scenario**

**Non-Confidential** 

Issue 04

Copyright © 2018, 2020 Arm Limited (or its affiliates). All rights reserved.

PJDOC-2042731200-3439

#### **Arm® Server Base System Architecture**

#### **Architecture Compliance Test Scenario**

Copyright © 2018, 2020 Arm Limited (or its affiliates). All rights reserved.

#### Release information

#### **Document history**

| Issue | Date              | Confidentiality  | Change                                                       |
|-------|-------------------|------------------|--------------------------------------------------------------|
| 02    | 05 May 2018       | Non-Confidential | Changes from REL 1.0. The document now follows a new format. |
| 03    | 20 March 2020     | Non-Confidential | Changes from REL 2.3 and REL 2.4                             |
| 04    | 30 September 2020 | Non-Confidential | Changes for REL 3.0                                          |

#### **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm. No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any click through or signed written agreement covering this document with Arm, then the click through or signed written agreement prevails over and supersedes the conflicting provisions of these terms. This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with  $^{\circ}$  or  $^{\text{m}}$  are registered trademarks or trademarks of Arm Limited (or its affiliates) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document

may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at <a href="http://www.arm.com/company/policies/trademarks">http://www.arm.com/company/policies/trademarks</a>.

Copyright <sup>©</sup> 2018, 2020 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

LES-PRE-20349

#### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to.

Unrestricted Access is an Arm internal classification.

#### **Product Status**

The information in this document is Final, that is for a developed product.

#### **Web Address**

www.arm.com

# **Contents**

| 1               |           | oduction                                                   |           |  |
|-----------------|-----------|------------------------------------------------------------|-----------|--|
| 1.1             |           | duct revision status                                       |           |  |
| 1.2             |           |                                                            |           |  |
| 1.3             |           | ventions                                                   |           |  |
|                 | 3.1       | Glossary                                                   |           |  |
| 1.              | 3.2       | Typographical conventions                                  |           |  |
| 1.5             | Fee       | dback                                                      |           |  |
| 1.              | 5.1       | Feedback on this product                                   | 12        |  |
| 1.              | 5.2       | Feedback on content                                        | 12        |  |
| 2               |           | out this document                                          |           |  |
| 2.1             |           | ns and abbreviations                                       |           |  |
| 2.2             |           | pe                                                         |           |  |
| 3               |           | oduction to SBSA                                           |           |  |
| <b>4</b><br>4.1 |           | ss reference to architecture and tests                     |           |  |
| 4.1             |           |                                                            |           |  |
|                 |           |                                                            |           |  |
| 4.3             |           | er                                                         |           |  |
| 4.4             |           | chdog                                                      |           |  |
| 4.5             |           | <u>.</u>                                                   |           |  |
| 4.6             |           | rciser                                                     |           |  |
| 4.7             |           | keup semantics                                             |           |  |
| 4.8             |           | pherals                                                    |           |  |
| 4.9             |           | /irtualization (SMMU)                                      |           |  |
| 4.10            |           | 3 – Trusted Firmware                                       |           |  |
| <b>5</b><br>5.1 |           | t scenarios<br>APIs                                        | <b>39</b> |  |
| 5.2             | • • • • • | Ar IS                                                      |           |  |
|                 | 2.1       | Number of PEs                                              |           |  |
|                 |           |                                                            |           |  |
|                 | 2.2       | PEs must implement SIMD extensions                         |           |  |
|                 | 2.3       | PEs must implement 16-bit ASIDsupport                      |           |  |
| 5.2.4           |           | PEs must support 4KB and 64KB at stage 1 and 2             |           |  |
|                 | 2.5       | Cache are implemented as VIPT or PIPT                      |           |  |
| 5.              | 2.6       | All PEs are coherent and in the same Inner Shareabledomain | 40        |  |

|    | 5.2.7 F             | PEs must implement Cryptographyextensions                                                                                     | 40  |
|----|---------------------|-------------------------------------------------------------------------------------------------------------------------------|-----|
|    | 5.2.8 F             | PEs must have LE support                                                                                                      | 42  |
|    | 5.2.9 F             | PEs must implement EL2                                                                                                        | 42  |
|    | 5.2.10              | PEs must implement AArch64                                                                                                    | 42  |
|    | 5.2.11              | PMU overflow signal                                                                                                           | 42  |
|    | 5.2.12              | PMU counters                                                                                                                  | 41  |
|    | 5.2.13              | PEs must implement a minimum of four synchronous watchpoints                                                                  | 41  |
|    | 5.2.14              | Breakpoints                                                                                                                   | 41  |
|    | 5.2.15              | All PEs are architecturally symmetric                                                                                         | 41  |
|    | 5.2.16              | EL3 must be implemented                                                                                                       | 42  |
|    | 5.2.17              | CRC32 instruction must beimplemented                                                                                          | 42  |
|    | 5.2.18              | PMBIRQ will be wired as PPI21                                                                                                 | 42  |
|    | 5.2.19              | All PEs must implement the RAS extension introduced in Armv8.2                                                                | 42  |
|    | 5.2.20              | All PEs must implement support for 16-bitVMD                                                                                  | 44  |
|    | 5.2.21              | All PEs must implement virtual hostextensions                                                                                 | 44  |
|    | 5.2.22<br>defined   | If PEs implement Armv8.3 pointer signing, the PEs must provide the standard algorithm by the Armarchitecture                  | .44 |
|    | 5.2.23              | All PEs must implement enhanced nested Virtualization                                                                         | 44  |
|    | 5.2.24<br>propose   | All PEs must support changing of page table mapping size using level 1 and level 2 solution d in the Armv8.4extension         |     |
|    | 5.2.25<br>introduc  | All PEs must provide support for stage 2 control of memory types and Cacheability, as sed by Armv8.4extensions                | .44 |
|    | 5.2.26              | All PEs must implement the Activity Monitors Extension                                                                        | 45  |
|    | 5.2.27<br>SHA512    | Where export control allows, all PEs must implement cryptography support for SHA3 and 45                                      |     |
|    | 5.2.28<br>least 25  | Where PEs implement the scalar vector extension, the vectorlength maximum must be at 6 bits                                   |     |
|    | 5.2.29              | PEs must implement restrictions on speculation introduced in the Arm v8.5 extensions                                          | .45 |
|    | 5.2.30              | PEs must implement Speculative Store Bypass Safe                                                                              | 45  |
|    | 5.2.31              | PEs must implement the SB speculation barrier read                                                                            | 46  |
|    | 5.2.32              | PEs must implement the CFP RCTX, DVP RCTX, CPP RCTX instructions                                                              | 46  |
|    | 5.2.33              | PEs must provide support for Branch Target Identification                                                                     | 46  |
|    | 5.2.34              | PEs must protect against timing faults being used to guess page table mappings                                                | 46  |
|    | 5.2.35              | PEs will provide support for enhanced virtualization traps                                                                    | 46  |
|    | 5.2.36              | All PEs will implement Armv8.5-PMU                                                                                            | 46  |
|    | 5.2.37<br>(SPE), th | If PEs implement the Scalable Vector Extension (SVE) and the Statistical Profiling Extension e PEs will implement Armv8.3-SPE |     |
|    | 5.2.38              | Hardware updates to Access flag and Dirty state in translation tables, must be supported                                      | 47  |
| 5. | .3 GIC              |                                                                                                                               | 47  |

|    | 5.3.1                    | GIC version                                                                                                                                                               | 47  |
|----|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|    | 5.3.2<br>LPI             | If the system includes PCI Express, then the GICv3 interrupt controllerwill implement ITS and 48                                                                          | t   |
|    | 5.3.3                    | The GICv3 interrupt controller will support two Security states                                                                                                           | 48  |
|    | 5.3.4                    | GIC maintenance interrupt shall be wired as PPI25                                                                                                                         | 48  |
| 5. | .4 Sys                   | tem and Generic Timer                                                                                                                                                     | 48  |
|    | 5.4.1<br>freque          | System counter of the Generic Timer will run at a minimum frequencyof 10 and at a maximuncy of 400MHz                                                                     |     |
|    | 5.4.2                    | The local PE timer when expiring must generate a PPI when the EL1 physical timer expires                                                                                  | 49  |
|    | 5.4.3                    | The local PE timer when expiring must generate a PPI when the virtual timer expires                                                                                       | 49  |
|    | 5.4.4                    | The local PE timer when expiring must generate a PPI when the EL2 physical timer expires                                                                                  | 50  |
|    | 5.4.5                    | The Local PE timer when expiring must generate a PPI when the EL2 virtual timer expires                                                                                   | 50  |
|    | 5.4.6<br>secure          | In systems that implement EL3, the memory mapped timer must be mapped into the Non-address space (the CNTBaseN frame and associated CNTCTLBase frame)                     | 51  |
|    | 5.4.7<br>specifi         | Unless all of the local PE timers are always on, the base server system will implement a syste c system wakeuptimer                                                       |     |
|    | 5.4.8                    | System-specific system timer shall generate an SPI                                                                                                                        | 52  |
| 5. | .5 Wa                    | tchdog                                                                                                                                                                    | 52  |
|    | 5.5.1                    | System implements a Generic Watchdog as specified in SBSA specification                                                                                                   | 52  |
|    | 5.5.2                    | Watchdog Signal 0 is routed as SPI (or LPI) and usable as an EL2 interrupt                                                                                                | 52  |
|    | 5.5.3<br>units, <i>i</i> | A system compatible with level 5 will implement a generic counter which counts in nanosecons strongly recommends that such systems use revision 1 of the generic watchdog |     |
| 5. | .6 Per                   | ipherals and memory                                                                                                                                                       | 53  |
|    | 5.6.1<br>(XHCI v         | If the system has a USB2.0 (USB3.0) host controller peripheral, itmust conform to EHCI v1.1 v1.0) or later                                                                |     |
|    | 5.6.2                    | If the system has a SATA host controller peripheral, it must conform to AHCI v1.3 or later                                                                                | 53  |
|    | 5.6.3<br>Generi          | Base server system will include a Generic UART as specified in Appendix B. Check that that ic UART is mapped to Non-secure address space                                  | 53  |
|    | 5.6.4                    | The UARTINTR interrupt output is connected to the GIC.                                                                                                                    | 54  |
|    | 5.6.5                    | Memory access to an unpopulated part of the addressable memory space                                                                                                      | 55  |
|    | 5.6.6                    | Non-secure access to Secure address must causeexception.                                                                                                                  | 55  |
| 5. | .7 Pov                   | ver states and wakeup                                                                                                                                                     | 55  |
|    | 5.7.1                    | In state B, a PE must be able to wake on receipt of an SGI, PPI or SPIthat directly targets the 55                                                                        | PE. |
| 5. | .8 10\                   | /irtualization                                                                                                                                                            | 52  |
|    | 5.8.1                    | SMMU if present is compatible with Arm SMMUv1                                                                                                                             | 52  |
|    | 5.8.2                    | SMMU if present, must support a 64KB translationgranule                                                                                                                   | 52  |
|    | 5.8.3                    | All the System MMUs in the system must be compliant with the same architecture version                                                                                    | 52  |
|    | 5.8.4                    | If PCIe, check the stall model                                                                                                                                            | 52  |

| 5.  | .8.5             | If SMMUv3 is in use, check the compliance with Appendix E: SMMUv3 integration                                                                                              | 53 |
|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 5.  | .8.6             | If SMMUv2 is in use, Each context bank must present a unique physical interrupt to the GIC                                                                                 | 53 |
| -   |                  | Each function, or virtual function, that requires hardware I/O Virtualization is associated with MU context                                                                |    |
| 5.  | .8.8             | SMMU Version Check                                                                                                                                                         | 53 |
| 5.  | .8.9             | SMMU must implement support for 16-bit VMID.                                                                                                                               | 54 |
| 5.  | .8.10            | SMMU must implement support for 16-bit ASID.                                                                                                                               | 54 |
| 5.  | .8.11            | SMMU must support the translation granule sizes supported by the PEs                                                                                                       | 54 |
| 5.  | .8.12            | If PEs implement Armv8.2-LVA, the SMMU must support extended virtual addresses                                                                                             | 54 |
| 5.  | .8.13            | If PEs implement Armv8.2-LPA, SMMU must support a 52 bit output size                                                                                                       | 55 |
| 5.  | .8.14            | The SMMU must implement coherent access to memory structures, queues, and page tabl 55                                                                                     | es |
|     | .8.15<br>ransla  | The SMMU must support HTTU of the Access flag and the Dirty state of the page for AArch tion tables                                                                        |    |
|     | .8.16<br>ne en   | SMMU will support little endian for translation table walks, and at a minimum must match dianness support of the PEs                                                       |    |
|     | .8.17<br>f the   | The DVM capabilities of all DVM receivers (SMMUs and PEs) must be the same or a superson DVM capabilities of all DVM initiators (PEs). Check for TLB Range Invalidation    |    |
| 5.9 | PCII             | <u> </u>                                                                                                                                                                   | 56 |
| _   | .9.1<br>nhano    | Systems must map memory space to PCI Express configuration space, using the PCI Express ced Configuration Access Mechanism (ECAM)                                          | 56 |
| 5.  | .9.2             | ECAM value present in MCFG                                                                                                                                                 | 57 |
| 5.  | .9.3             | PEs are able to access ECAM                                                                                                                                                | 57 |
| 5.  | .9.4             | PCIe space is device or non-cacheable                                                                                                                                      | 57 |
|     | .9.5<br>naligr   | When PCI Express memory space is mapped as normal memory, the system must support ned accesses to that region                                                              | 57 |
|     | .9.6<br>xpres    | In systems that are compatible with level 3 or above of the SBSA, the addresses sent by PCI s devices must be presented to the memory system or SMMU unmodified            | 57 |
| _   | .9.7<br>ent by   | In a system with an SMMU for PCI Express there are no transformations to addresses being PCI Express devices before they are presented as an input address to the SMMU     | 58 |
| 5.  | .9.8             | Support for Message Signaled Interrupts (MSI/MSI-X) is required for PCI Express devices                                                                                    | 58 |
|     | .9.9<br>egiste   | Each unique MSI(-X) shall trigger an interrupt with a unique ID and the MSI(-X) shall target GI rs requiring no hardware-specific software to service the interrupt        |    |
| 5.  | .9.10            | All MSIs and MSI-x are mapped to LPI                                                                                                                                       | 58 |
| 5.  | .9.11            | If the system supports PCIe PASID, then at least 16 bits of PASID must be supported                                                                                        | 60 |
| 5.  | .9.12            | The PCI Express root complex is in the same Inner Shareable domain as the PEs                                                                                              | 60 |
|     | .9.13<br>evel se | Each of the 4 legacy interrupt lines must be allocated a unique SPI ID and is programmed a ensitive                                                                        |    |
|     | .9.14<br>ontro   | All Non-secure on-chip masters in a base server system that are expected to be under the of the OS or hypervisor must be capable of addressing all of the NS address space | 60 |

| 5.9.15           | Memory Attributes of DMA traffic                                                                                                                                         | 61 |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 5.9.16<br>tables | PCI Express transactions not marked as No_snoop accessing memorythat the PE tra attribute as cacheable and shared are I/O Coherent with the PEs                          |    |
| 5.9.17<br>compl  | For Non-prefetchable (NP) memory, type-1 headers only support 32bit address, systaint with SBSA level 4 or above must support 32bit programming of NP BARs on such er 61 |    |
| 5.9.18           | Root Port must implement minimal ACS features if P2P supported                                                                                                           | 61 |
| 5.9.19           | All switches must implement minimal ACS features if P2P supported                                                                                                        | 62 |
| 5.9.20           | Multifunction devices must implement minimal ACS features if P2P supported                                                                                               | 62 |
| 5.9.21           | Type 0/1 common config rules check                                                                                                                                       | 62 |
| 5.9.22           | Type 0 config header rules check                                                                                                                                         | 62 |
| 5.9.23           | Type 1 config header rules check                                                                                                                                         | 63 |
| 5.9.24           | PCle capability rules check                                                                                                                                              | 63 |
| 5.9.25           | Device capabilites register rules check                                                                                                                                  | 63 |
| 5.9.26           | Device Control register rule check                                                                                                                                       | 63 |
| 5.9.27           | Device capabilities 2 register rules check                                                                                                                               | 64 |
| 5.9.28           | Device control 2 reg rules check                                                                                                                                         | 64 |
| 5.9.29           | Power management capability rules check                                                                                                                                  | 64 |
| 5.9.30           | Power management/status rule check                                                                                                                                       | 64 |
| 5.9.31           | Check Command Register memory space enable functionality                                                                                                                 | 61 |
| 5.9.32           | Type0/1 BIST Reg verification rule                                                                                                                                       | 61 |
| 5.9.33           | Check HDR CapPtr Reg verification rule                                                                                                                                   | 61 |
| 5.9.34           | Max payload size supported check                                                                                                                                         | 61 |
| 5.9.35           | BAR memory space and Type rule check                                                                                                                                     | 62 |
| 5.9.36           | Function level reset rule check                                                                                                                                          | 62 |
| 5.9.37           | Check ARI forwarding support rule                                                                                                                                        | 62 |
| 5.9.38           | Check OBFF supported rule                                                                                                                                                | 62 |
| 5.9.39           | Check CTRS and CTDS rule                                                                                                                                                 | 63 |
| 5.9.40           | Check i-EP atomicop rule                                                                                                                                                 | 63 |
| 5.9.41           | Check Root Port ATS and PRI rule                                                                                                                                         | 63 |
| 5.9.42           | Check MSI and MSI-X support rule                                                                                                                                         | 63 |
| 5.9.43           | Check Power Management rules                                                                                                                                             | 64 |
| 5.9.44           | Check ARI forwarding enable rule                                                                                                                                         | 64 |
| 5.9.45           | Check device under RP in same ECAM                                                                                                                                       | 64 |
| 5.9.46           | Check all RP under a HB is in same ECAM                                                                                                                                  | 64 |
| 5.9.47<br>4-byte | The Root port must comply with the byte enable rules and must support 1 byte, 2 byte. Configuration read and write                                                       | •  |
| 5.9.48           | Recognition and consumption configuration transactions intended for the Root Port                                                                                        |    |

|                        | Issue 03                                                                                                                                                                                                                                                                                                                            |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| · ·                    | ition space and read/write the appropriate Root Port Configuration register65                                                                                                                                                                                                                                                       |
| non-prefe<br>: Where t | Recognition of transactions received on the primary side of the RP PCI-PCI bridge, targeting etchable memory spaces of devices and switches that are on the secondary side of the bridge he address falls within the non-prefetchable memory window in the type 1 header registers, actions must be forwarded to the secondary side |
| prefetcha<br>Where th  | Recognition of transactions received on the primary side of the RP PCI-PCI bridge, targeting able memory spaces of devices and switches that are on the secondary side of the bridge: e address falls within the prefetchable memory window in the type 1 header registers, the ons must be forwarded to the secondary side         |
|                        | Each legacy interrupt SPI must be programmed as level-sensitive in the appropriate R66                                                                                                                                                                                                                                              |
|                        | For i-EP, the Root port must provide the ability to do a hot reset of the Endpoint using the y Bus Reset bit in bridge Control Register66                                                                                                                                                                                           |
|                        | PCIe ATS capability must be supported if the RCiEP or i-EP has a software visible cache for ranslations67                                                                                                                                                                                                                           |
| 5.9.54                 | If the PCIe hierarchy allows peer-to-peer transactions, Root Port must support ACS capability 67                                                                                                                                                                                                                                    |
|                        | If the PCIe hierarchy allows peer-to-peer transactions, the root port must support ACS error detection, Logging and reporting must be through the usage of AER mechanism67                                                                                                                                                          |
| supports               | If the Root port supports peer-to-peer traffic with other root ports then - If the root port Address Translation services and peer-to-peer traffic with other root ports, then it must ACS direct translated P2P                                                                                                                    |
|                        | If the i-EP endpoint is capable of sending transactions to a peer endpoint (RCiEP or i-EP or discrete), then the i-EP root port must have ACS capability                                                                                                                                                                            |
|                        | ACS capability must be present in the RCiEP or i-EP endpoint functions if the RCiEP or i-EP ISA multi-function device and supports peer to peer traffic between its functions68                                                                                                                                                     |
| 5.10 EL3 -             | - Trusted firmware69                                                                                                                                                                                                                                                                                                                |
|                        | Watchdog Signal 1 is available. This may be confirmed in the data base. This may not be confirmed in the data base. This may not be confirmed in the data base. This may not be confirmed in the data base. This may not be                                                                                                         |
| 5.10.2                 | Must implement at least 56 bits                                                                                                                                                                                                                                                                                                     |
| 5.10.3                 | The local PE timer when expiring must generate a PPI when EL3 physical timer expires70                                                                                                                                                                                                                                              |
|                        | Any local timers that are marked by PE as always ON must be able to wake up the system. es to expiry of all Secure views of the localtimer (CNTPS)72                                                                                                                                                                                |
|                        | Secure Generic UART is present. It is not aliased in Non-secure address space. The UARTINTR the Secure generic UART is connected to the GIC as an SPI72                                                                                                                                                                             |
| 5.10.6                 | A Secure system wakeup timer is present and the interrupt is presented to GIC as a SPI72 $$                                                                                                                                                                                                                                         |
| Appendix A F           | Revisions                                                                                                                                                                                                                                                                                                                           |

# 1 Introduction

#### 1.1 Product revision status

The rmpn identifier indicates the revision status of the product described in this book, for example, r1p2, where:

rm Identifies the major revision of the product, for example, r1.

рn

Identifies the minor revision or modification status of the product, for example, p2.

#### 1.2 Intended audience

This document is for engineers who are verifying an implementation of Arm® Server Base System Architecture.

#### 1.3 Conventions

The following subsections describe conventions used in Arm documents.

#### 1.3.1 Glossary

The Arm Glossary is a list of terms used in Arm documentation, together with definitions for those terms. The Arm Glossary does not contain terms that are industry standard unless the Arm meaning differs from the generally accepted meaning.

See the Arm Glossary for more information: https://developer.arm.com/glossary.

## 1.3.2 Typographical conventions

| Convention             | Use                                                                                                                                                                                                       |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| italic                 | Introduces citations.                                                                                                                                                                                     |
| bold                   | Highlights interface elements, such as menu names. Denotes signal names. Also used for terms in descriptive lists, where appropriate.                                                                     |
| monospace              | Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.                                                                                               |
| monospace <b>bold</b>  | Denotes language keywords when used outside example code.                                                                                                                                                 |
| monospace<br>underline | Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.                                                                   |
| <and></and>            | Encloses replaceable terms for assembler syntax where they appear in code or code fragments.  For example:  MRC p15, 0, <rd>, <crn>, <crm>, <opcode_2></opcode_2></crm></crn></rd>                        |
| SMALL CAPITALS         | Used in body text for a few terms that have specific technical meanings, that are defined in the Arm® Glossary. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE. |
| Caution                | This represents a recommendation which, if not followed, might lead to system failure or damage.                                                                                                          |
| Warning                | This represents a requirement for the system that, if not followed, might result in system failure or damage.                                                                                             |
| Danger                 | This represents a requirement for the system that, if not followed, will result in system failure or damage.                                                                                              |
| Note                   | This represents an important piece of information that needs your attention.                                                                                                                              |
| - Tip                  | This represents a useful tip that might make it easier, better or faster to perform a task.                                                                                                               |
| Remember               | This is a reminder of something important that relates to the information you are reading.                                                                                                                |

## 1.4 Additional reading

This document contains information that is specific to this product. See the following documents for other relevant information:

#### **Table 1-1 Arm publications**

| Document name                                                      | Document ID     | Licensee only |
|--------------------------------------------------------------------|-----------------|---------------|
| Server Base System Architecture (Version 6.0)                      | ARM DEN 0029C   | No            |
| Arm® Architecture Reference Manual ARMv8, for Armv8-A architecture | ARM DDI 0487F.a | No            |

#### **Table 1-2 Other publications**

|   | Document ID | Document name |
|---|-------------|---------------|
| Ī | -           | -             |

#### 1.5 Feedback

Arm welcomes feedback on this product and its documentation.

#### 1.5.1 Feedback on this product

If you have any comments or suggestions about this product, contact your supplier and give:

- The product name.
- The product revision or version.
- An explanation with as much information as you can provide. Include symptoms and diagnostic procedures if appropriate.

#### 1.5.2 Feedback on content

If you have comments on content, send an email to support-enterprise-acs@arm.com and give:

- The title Arm® SBSA Architecture Compliance Test Scenario.
- The number PJDOC-2042731200-3439.
- If applicable, the page number(s) to which your comments refer.
- A concise explanation of your comments.

Arm also welcomes general suggestions for additions and improvements.



Arm tests the PDF only in Adobe Acrobat and Acrobat Reader and cannot guarantee the quality of the represented document when used with any other PDF reader.

# 2 About this document

This document describes the test scenarios for SBSA Architecture Compliance.

#### 2.1 Terms and abbreviations

This document uses the following terms and abbreviations.

| Term  | Meaning                                    |
|-------|--------------------------------------------|
| ACPI  | Advanced Configuration and Power Interface |
| LPI   | Low Power Interrupt                        |
| MSI   | Message Signaled Interrupts                |
| PAL   | Platform Abstraction Layer                 |
| PASID | Process Address Space ID                   |
| PE    | Processing Element                         |
| PMU   | Performance Monitoring Unit                |
| PIPT  | Physically Indexed Physically Tagged       |
| PPI   | Private Peripheral Interrupt               |
| SBSA  | Server Base System Architecture            |
| SGI   | Software Generated Input                   |
| SMC   | Secure Monitor Call                        |
| SMMU  | System Memory Management Unit              |
| SPI   | Shared Peripheral Interrupt                |
| VIPT  | Virtually Indexed Physically Tagged        |
|       |                                            |

## 2.2 Scope

This document describes the verification scenarios and the strategy that is followed for creating Architecture Compliance Suite (ACS) tests for configuration system features described in SBSA architecture.

## 3 Introduction to SBSA

The SBSA specifies a hardware system architecture that is based on Arm 64-bit architecture. The server system software such as operating systems, hypervisors, and firmware can rely on this architecture. It addresses PE features and key aspects of system architecture.

The primary goal is to ensure enough standard system architecture to enable a suitably built single OS image to run on all hardware compliant with this specification. A driver-based model for advanced platform capabilities beyond basic system configuration and boot are required. However, that is outside the scope of this document. Fully discoverable and describable peripherals aid the implementation of such a driver model.

SBSA also specifies features that firmware can rely on, allowing for some commonality in firmware implementation across platforms.

# 4 Cross reference to architecture and tests

The tests are divided into a hierarchy of subcategories depending on the runtime environment and the component submodules that are required for achieving the verification. The top level of the hierarchy is consistent with the target hardware subsystem which is validated by the test.

These are compliance level 0 to compliance level 5 as per SBSA specification version 6.0.

A test may check for different parameters of the hardware subsystem based on the level of compliance requested.

Also, the tests are further subclassified as required, to run in an EL3 environment. The communication between the ACS and the EL3 firmware is through Arm SMC.

The tests are classified as:

- PE
- GIC
- Timer
- Watchdog
- PCIe
- Exerciser
- Wakeup semantics
- Peripherals
- IO Virtualization (SMMU)
- EL3 Trusted Firmware

#### 4.1 PE

PE tests require the following tests in the table to run all the PEs in the system, requiring a Software-Generated Interrupt (SGI) is broadcast with the test address as an entry point.

| Test<br>ID | Test case                          | System<br>interface<br>dependency | Requirement of<br>Secure firmware | Level      |
|------------|------------------------------------|-----------------------------------|-----------------------------------|------------|
| 1          | Number of PEs does not             | ACPI MADT                         | No                                | Level 0, 1 |
|            | exceed 8                           | table                             |                                   |            |
|            | Number of PEs does not exceed 2^28 |                                   |                                   | Level 2+   |

| Test<br>ID | Test case                                                                                | System<br>interface<br>dependency             | Requirement of<br>Secure firmware | Level    |
|------------|------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------|----------|
| 2          | PEs implement Advanced SIMD extensions                                                   | CPU System<br>Register Read                   | No                                | Level 0+ |
| 3          | PE will implement 16-bit<br>ASID support                                                 | CPU System<br>Register Read                   | No                                | Level 0+ |
| 4          | PE will support 4KB and 64KB at stage 1 and 2                                            | CPU System<br>Register Read                   | No                                | Level 0+ |
| 5          | Cache is implemented as VIPT or PIPT                                                     | CPU System<br>Register Read                   | No                                | Level 0+ |
| 6          | All PEs are coherent and in the same Inner Shareable domain                              | CPU System<br>Register Read                   | No                                | Level 0+ |
| 7          | PEs must implement<br>Cryptography Extensions                                            | CPU System<br>Register Read                   | No                                | Level 0+ |
| 8          | PEs will implement little-<br>endian support                                             | CPU System<br>Register Read<br>and functional | No                                | Level 0+ |
| 9          | PEs will implement EL2                                                                   | CPU System<br>Register Read                   | No                                | Level 0+ |
| 10         | PEs will implement<br>AArch64 at all ELs                                                 | CPU System<br>Register Read                   | No                                | Level 0+ |
| 11         | PMU overflow signal<br>from each PE must be<br>wired to a unique PPI or<br>SPI interrupt | ACPI MADT and functional                      | No                                | Level 0+ |
| 12         | Each PE implements a minimum of four programmable PMU counters                           | CPU System<br>Register Read                   | No                                | Level 0  |
|            | Each PE implements a minimum of six programmable PMU counters                            |                                               |                                   | Level 1+ |

| Test<br>ID | Test case                                                                                                             | System<br>interface<br>dependency             | Requirement of<br>Secure firmware | Level    |
|------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------|----------|
| 13         | Each PE implements a minimum of four synchronous watchpoints                                                          | CPU System<br>Register Read                   | No                                | Level 0+ |
| 14         | Each PE implements a minimum of four breakpoints                                                                      | CPU System<br>Register Read                   | No                                | Level 0  |
|            | Each PE implements a minimum of six breakpoints                                                                       |                                               |                                   | Level 1+ |
| 15         | All PEs are architecturally symmetric except for permitted differences                                                | CPU System<br>Register Read                   | No                                | Level 0+ |
| 16         | Each PE will implement the EL3 Exception level                                                                        | CPU System<br>Register Read                   | No                                | Level 3+ |
| 17         | Each PE implements CRC32 instructions                                                                                 | CPU System<br>Register Read                   | No                                | Level 3+ |
| 18         | PMBIRQ signal must be wired to PPI ID 21                                                                              | CPU System<br>Register Read<br>and functional | Yes                               | Level 2+ |
| 19         | All PEs must implement<br>the RAS extension<br>introduced in Armv8.2                                                  | CPU System<br>Register Read<br>and functional | No                                | Level 4+ |
| 20         | All PEs must implement support for 16-bit VMD                                                                         | CPU System<br>Register Read<br>and functional | No                                | Level 4+ |
| 21         | All PEs must implement virtual host extensions                                                                        | CPU System<br>Register Read<br>and functional | No                                | Level 4+ |
| 22         | If PEs implement Armv8.3 pointer signing, the PEs must provide the standard algorithm defined by the Arm architecture | CPU System<br>Register Read<br>and functional | No                                | Level 4+ |

| Test<br>ID | Test case                                                                                                                                              | System<br>interface<br>dependency             | Requirement of<br>Secure firmware | Level    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------|----------|
| 23         | All PEs must implement enhanced nested Virtualization                                                                                                  | CPU System<br>Register Read<br>and functional | No                                | Level 5+ |
| 24         | All PEs must support changing of page table mapping size using level 1 and level 2 solution proposed in the Armv8.4 extension. Level 2 is recommended. | CPU System<br>Register Read<br>and functional | No                                | Level 5+ |
| 25         | All PEs must provide support for stage 2 control of memory types and Cacheability, as introduced by Armv8.4 extensions                                 | CPU System<br>Register Read<br>and functional | No                                | Level 5+ |
| 26         | All PEs must implement<br>the Activity Monitors<br>Extension                                                                                           | CPU System<br>Register Read<br>and functional | No                                | Level 5+ |
| 27         | Where export control<br>allows, all PEs must<br>implement cryptography<br>support for SHA3 and<br>SHA512                                               | CPU System<br>Register Read<br>and functional | No                                | Level 5+ |
| 28         | Where PEs implement<br>the scalar vector<br>extension, the vector<br>length maximum must be<br>at least 256 bits                                       | CPU System<br>Register Read<br>and functional | Yes                               | Level 3+ |
| 29         | PEs must implement restrictions on speculation introduced in the Arm v8.5 extensions                                                                   | CPU System<br>Register Read<br>and functional | No                                | Level 6+ |
| 30         | PEs must implement<br>Speculative Store Bypass<br>Safe                                                                                                 | CPU System<br>Register Read<br>and functional | No                                | Level 6+ |

| PEs must implement the SB speculation barrier Register Read and functional  PEs must implement the CPU System No Level CFP RCTX, DVP RCTX, and Register Read CPP RCTX instructions and functional  PEs must provide support CPU System No Level for Branch Target Register Read Identification and functional | ure and t |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| CFP RCTX, DVP RCTX, and Register Read CPP RCTX instructions and functional  PEs must provide support CPU System No Level for Branch Target Register Read                                                                                                                                                      | 6+        |
| for Branch Target Register Read                                                                                                                                                                                                                                                                               | 6+        |
|                                                                                                                                                                                                                                                                                                               | 6+        |
| PEs must protect against CPU System No Level timing faults that are Register Read used to guess page table and functional mappings                                                                                                                                                                            | 6+        |
| PEs will support CPU System No Level enhanced virtualization Register Read traps and functional                                                                                                                                                                                                               | 6+        |
| All PEs will implement CPU System No Level Armv8.5-PMU Register Read and functional                                                                                                                                                                                                                           | 6+        |
| 37 If PEs implement SVE and CPU System No Level the Statistical Profiling Register Read Extension (SPE), it will also implement Armv8.5-SPE                                                                                                                                                                   | 6+        |
| Hardware updates to CPU System No Level Access flag and Dirty Register Read state in translation tables and functional must be supported                                                                                                                                                                      | 6+        |

## **4.2 GIC**

GIC functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                                                      | System interface dependency | Requirement of Secure firmware | Level       |
|------------|----------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------|-------------|
| 101        | GICv2 is implemented                                                                                           | ACPI, register read         | No                             | Level 0,1   |
|            | GICv3 is implemented                                                                                           |                             |                                | Level 2+    |
| 102        | If the base server system includes PCI Express then the GICv3 interrupt controller will implement ITS and LPI. | MADT Table                  | No                             | Level<br>2+ |
| 103        | The GICv3 interrupt controller will support two Security states.                                               | GIC System Register Read    | No                             | Level<br>3+ |
| 104        | GIC maintenance interrupt will be wired as PPI 25.                                                             | ACPI Table                  | No                             | Level<br>2+ |

## 4.3 Timer

Timer functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                                                                            | System interface dependency            | Requirement of<br>Secure firmware | Level    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------|----------|
| 201        | The system counter of<br>the Generic Timer will<br>run at a minimum<br>frequency of 10MHz<br>and at a maximum<br>frequency of 400MHz | ACPI GTDT                              | No                                | Level 0+ |
| 202        | The local PE timer when expiring must generate                                                                                       | CPU System Register Write,<br>GIC APIs | No                                | Level 0+ |
|            | a PPI when EL1 physical timer expires                                                                                                |                                        |                                   |          |

| Test<br>ID | Test case                                                                                                                      | System interface dependency            | Requirement of<br>Secure firmware | Level    |
|------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------|----------|
|            | The local PE timer when expiring must generate a PPI when EL1 physical timer expires and PPI                                   |                                        |                                   | Level 2+ |
|            | must be 30                                                                                                                     |                                        |                                   |          |
| 203        | The local PE timer when expiring must generate a PPI when the virtual timer expires                                            | CPU System Register Write,<br>GIC APIs | No                                | Level 0+ |
|            | The local PE timer when expiring must generate a PPI when the virtual timer expires and PPI must                               |                                        |                                   | Level 2+ |
|            | be 27                                                                                                                          |                                        |                                   |          |
| 204        | The local PE timer when expiring must generate a PPI when the EL2 physical timer expires                                       | CPU System Register Write,<br>GIC APIs | No                                | Level 0+ |
|            | The local PE timer when expiring must generate a PPI when the EL2 physical timer expires and                                   |                                        |                                   | Level 2+ |
|            | must be 26                                                                                                                     |                                        |                                   |          |
| 205        | For systems where PEs are v8.1 or greater, local PE timer when expiring must generate a PPI when the EL2 virtual timer expires | CPU System Register Write,<br>GIC APIs | No                                | Level 0+ |

| Test<br>ID | Test case                                                                                                                                                   | System interface dependency | Requirement of<br>Secure firmware | Level    |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|----------|
|            | For systems where PE are v8.1 or greater, local PE timer when expiring must generate a PPI when the EL2 virtual timer expires and must be 28                |                             |                                   | Level 2+ |
| 206        | In systems that implement EL3, the memory mapped timer (the CNTBaseN frame and associated NTCTLBase frame) must be mapped into the Non-secure address space | Read/write to Base address  | No                                | Level 2+ |
| 206        | If the system includes a system wakeup timer, this memory-mapped timer must be mapped on to Non-secure address space                                        | Read/write to Base address  | No                                | Level 3+ |
| 207        | Unless all the local PE timers are always ON, the base server system will implement a system-specific system wakeup timer                                   | ACPI GTDT                   | No                                | Level 1+ |
| 208        | A system-specific system timer will generate an SPI                                                                                                         | Platform-specific           | No                                | Level 0+ |

## 4.4 Watchdog

Watchdog functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                                                                                                                             | System<br>interface<br>dependency | Requirement of<br>Secure firmware | Level    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------|----------|
| 301        | The system implements a Generic Watchdog as specified in Appendix A: Generic Watchdog.                                                                                                | ACPI GTDT                         | No                                | Level 1+ |
|            | The watchdog must have both its register frames mapped on to Non-secure address space, which is referred to as the Non-Secure watchdog.                                               |                                   |                                   | Level 3+ |
| 302        | Watchdog signal 0 is routed as an SPI to the GIC and usable as an EL2 interrupt.                                                                                                      | ACPI GTDT, GIC<br>APIs            | No                                | Level 1+ |
|            | Watchdog signal 0 is routed as an SPI or LPI to the GIC and usable as an EL2 interrupt.                                                                                               |                                   |                                   | Level 2+ |
| 303        | A system compatible with level 5 will implement a generic counter which counts in nanosecond units. Arm strongly recommends that such systems use revision 1 of the generic watchdog. | ACPI GTDT                         | No                                | Level 5+ |

## **4.5 PCle**

PCIe functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                                                                                                                    | System interface dependency                  | Requirement of<br>Secure firmware | Level    |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------|----------|
| 401        | Systems must map memory space to PCI Express configuration space, using the PCI Express Enhanced Configuration Access Mechanism (ECAM). Tests must be robust to ARI that is  | UEFI PCD, FDT,<br>ACPI                       | No                                | Level 1+ |
| 402        | The base address of each ECAM region is discoverable from system firmware data.                                                                                              | ACPI MCFG table                              | No                                | Level 1+ |
| 403        | PEs can access the ECAM region.                                                                                                                                              | PCI Root Bridge<br>IO Protocol<br>read/write | No                                | Level 1+ |
| 404        | All systems must support mapping PCI Express memory space as either device memory or non-cacheable memory.                                                                   | Memory Map and read/write                    | No                                | Level 1+ |
|            | When PCI Express memory space is mapped as normal                                                                                                                            |                                              |                                   |          |
|            | memory, the system must support unaligned accesses to that region.                                                                                                           |                                              |                                   |          |
| 405        | In systems that are compatible with level 3 or above of the SBSA, the addresses that the PCI Express devices send must be presented to the memory system or SMMU unmodified. |                                              | -                                 | Level 3+ |

PJDOC-2042731200-3439 Issue 03 Cross reference to architecture and tests

In a system where the PCI Level 0+ Express does not use an SMMU, the PCI Express devices have the same view of physical memory as the PEs. 406 Level 0+ In a system with an SMMU for PCI Express, there are no transformations to addresses that the PCI Express devices send before they are presented as an input address to the SMMU. Support for Message Signaled Level 1+

407 Support for Message Signaled - Interrupts (MSI or MSI-X) is required for PCI Express devices. MSI and MSI-X are edge-triggered interrupts that are delivered as a memory write transaction.

| Test<br>ID | Test case                                                                                                                                                                                                                                                                                                      | System interface dependency | Requirement of Secure firmware | Level    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------|----------|
| 408        | Each unique MSI or MSI-X will trigger an interrupt with a unique ID and the MSI or MSI-X will target GIC registers requiring no hardware-specific software to service the interrupt.                                                                                                                           | -                           | -                              | Level 1+ |
| 409        | All MSIs and MSI-X are mapped to LPI.                                                                                                                                                                                                                                                                          | -                           | -                              | Level 2+ |
| 410        | If the system supports PCIe<br>PASID, then at least 16 bits of<br>PASID must be supported.                                                                                                                                                                                                                     | -                           | -                              | Level 3+ |
| 411        | The PCI Express Root<br>Complex is in the same Inner<br>Shareable domain as the PEs.                                                                                                                                                                                                                           | -                           | -                              | Level 0+ |
| 412        | Each of the 4 legacy interrupt lines must be allocated a unique SPI ID and is programmed as level sensitive.                                                                                                                                                                                                   | -                           | -                              | Level 1+ |
| 413        | All Non-secure on-chip masters in a base server system that are expected to be under the control of the OS or hypervisor must be capable of addressing all of the NS address space. If the master goes through an SMMU then it must be capable of addressing all of the NS address space when the SMMU is off. | -                           | -                              | Level 3+ |

| Test<br>ID | Test case                                                                                                                                                                                                                                                                                                                                                         | System interface dependency | Requirement of Secure firmware | Level    |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------|----------|
|            | Non-secure off-chip devices that cannot directly address all of the Non-secure address space must be placed behind a stage 1 System MMU compatible with the Arm SMMUv2 or SMMUv3 specification. that has an output address size large enough to address all of the Non-secure address space.                                                                      |                             |                                |          |
| 414        | Memory Attributes of DMA traffic are one of (1) Inner WB, Outer WB, Inner Shareable (2) Inner/Outer Non- Cacheable (3) Device TypeIO coherent DMA is as per (1) Inner/Outer WB, Inner Shareable.                                                                                                                                                                  | -                           | -                              | Level 3+ |
| 415        | PCI Express transactions not marked as No_snoop accessing memory that the PE translation tables attribute as cacheable and shared are I/O coherent with the PEs. I/O coherency fundamentally means that no software coherency management is required on the PEs for the PCI Express root complex, and therefore devices, to get a coherent view of the PE memory. |                             |                                | Level 0+ |
|            | PCI Express transactions marked as No_snoop accessing memory that the PE translation tables attribute as cacheable and shared behave correctly when the appropriate SW coherence is deployed.                                                                                                                                                                     |                             |                                |          |

| Test<br>ID | Test case                                                                                                                                                                                         | System interface dependency | Requirement of Secure firmware | Level    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------|----------|
| 416        | For Non-prefetchable (NP) memory, type-1 headers only support 32-bit address, systems complaint with SBSA level 4 or above must support 32-bit programming of NP BARs on such endpoints.          | -                           | -                              | Level 4+ |
| 417        | In a system where the PCIe hierarchy allows peer to peer transactions, the Root Ports in an Arm-based SoC must implement PCIe access control service (ACS) features.                              | -                           | -                              | Level 3+ |
| 418        | All PCIe switches should support the minimal features, refer D.13 section for features list                                                                                                       | -                           | -                              | Level 3+ |
| 419        | All multi-function devices, SR-IOV and non-SR-IOV, that are capable of peer to peer traffic between different functions should support the minimal features, refer D.13 section for features list | -                           | -                              | Level 3+ |
| 420        | All PCIe devices, must implement the common                                                                                                                                                       | -                           | -                              | Level 3+ |
| 431        | registers of Type 0/1 header, as per requirements in E.3                                                                                                                                          |                             |                                |          |
| 432        | and E.4 section                                                                                                                                                                                   |                             |                                |          |
| 421        | All PCIe devices, must                                                                                                                                                                            | -                           | -                              | Level 3+ |
| 434        | implement the registers of Type 0 header, as per requirements in E.3 section                                                                                                                      |                             |                                |          |
| 422        | All PCIe devices, must implement the registers of Type 1 header, as per requirements in E.4 section                                                                                               | -                           | -                              | Level 3+ |

| Test<br>ID        | Test case                                                                                                                                             | System interface dependency | Requirement of Secure firmware | Level    |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------------------------------|----------|
| 423               | i-EP Root Port must<br>implement the registers of<br>PCIe capability(10h), as per<br>requirements in E.15 section                                     | -                           |                                | Level 3+ |
| 424<br>433<br>435 | All PCIe devices, must implement the Device capability register of PCIe capability(10h), as per requirements in E.14/15 section                       | -                           |                                | Level 3+ |
| 425               | All PCIe devices, must implement the Device Control register of PCIe capability(10h), as per requirements in E.14/15 section                          | -                           |                                | Level 3+ |
| 426<br>436<br>437 | All PCIe devices, must implement the Device capabilities 2 register of PCIe capability(10h), as per requirements in E.14/15 section                   | -                           |                                | Level 3+ |
| 427               | All PCIe devices, must implement the Device control 2 register of PCIe capability(10h), as per requirements in E.14/15 section                        | -                           |                                | Level 3+ |
| 428               | All PCIe devices, must implement the power management capability register of power management capability(01h), as per requirements in E.14/15 section | -                           |                                | Level 3+ |

| Test<br>ID | Test case                                                                                                                                                                       | System interface dependency | Requirement of<br>Secure firmware | Level    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|----------|
| 429        | All PCIe devices, must implement the power management control/status register of power management capability(01h), as per requirements in E.14/15 section                       | -                           | -                                 | Level 3+ |
| 430        | Memory space access should<br>raise Unsupported Request<br>when device Memory Space<br>enable bit is clear                                                                      | -                           | -                                 | Level 3+ |
| 438<br>439 | iEP root port must follow<br>Completion timeout ranges<br>supported, Completion<br>timeout disable supported<br>and AtomicOp routing<br>supported bit as per section<br>E.15.11 | -                           | -                                 | Level 3+ |
| 440        | Root Port must not support<br>ATS and PRS extended<br>capability                                                                                                                | -                           | -                                 | Level 3+ |
| 441        | RCiEP and iEP end point must support MSI or MSI-X interrupts                                                                                                                    | -                           | -                                 | Level 3+ |
| 442        | RCiEP, iEP root port and iEP<br>end point must support<br>Power Management<br>Capability                                                                                        | -                           | -                                 | Level 3+ |
| 443        | Root Port must implement<br>ARI forwarding enable as per<br>in E.15.12 section                                                                                                  | -                           | -                                 | Level 3+ |
| 444        | Root Port Configuration Space must be under same ECAM as the Configuration Space of Endpoints and switches in hierarchy that originates from that port                          | -                           | -                                 | Level 3+ |

| Test<br>ID | Test case                                                                                                                                                                                                                                                     | System interface dependency | Requirement of<br>Secure firmware | Level    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|----------|
| 445        | All Root Port Configuration<br>Space under same Host<br>Bridge must be in same ECAM                                                                                                                                                                           | -                           |                                   | Level 3+ |
| 446        | The Root Port must comply with the byte enable rules and support 1-byte, 2-byte and 4-byte configuration read and write requests                                                                                                                              | -                           |                                   | Level 3+ |
| 447        | Recognition and usage of configuration transactions for the Root Port configuration space and read/write the appropriate Root Port configuration register                                                                                                     | _                           |                                   | Level 3+ |
| 448        | Recognition of transactions received on the primary side of the RP PCI-PCI bridge, targeting NP memory spaces of devices and switches that are on the secondary side of the bridge: Address falls within the NP memory window in the type 1 header registers  | -                           |                                   | Level 3+ |
| 449        | Must recognize transactions received on the primary side of the RP PCI-PCI bridge, targeting P memory spaces of devices and switches that are on the secondary side of the bridge: Address falls within the Pref memory window in the type 1 header registers | -                           |                                   | Level 3+ |
| 450        | Each legacy interrupt SPI must be programmed as level-sensitive in the appropriate GIC_ICFGR                                                                                                                                                                  | -                           |                                   | Level 3+ |

| 451 | For i-EP, the Root Port must<br>provide the ability to do a hot<br>reset of the Endpoint using<br>the Secondary Bus Reset bit<br>in bridge Control Register                        | Leve | el 3+ |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|
| 452 | PCIe ATS capability must be supported if the RCiEP or i-EP has a software visible cache for address translations                                                                   | Leve | el 3+ |
| 453 | If the PCIe hierarchy allows<br>peer-to-peer transactions,<br>Root Port must support ACS<br>capability                                                                             | Leve | el 3+ |
| 454 | If the PCIe hierarchy allows peer-to-peer transactions, The root port must support ACS violation error detection, Logging and reporting must be through the usage of AER mechanism | Leve | el 3+ |
| 455 | If the Root port supports P2P with other root ports then - If the root port supports ATS and P2P traffic with other root ports, then it must support ACS direct translated P2P     | Leve | el 3+ |
| 456 | If the i-EP endpoint is capable of sending transactions to a peer endpoint (RCiEP or i-EP endpoint or discrete), then the i-EP root port must have ACS capability                  | Leve | el 3+ |
| 457 | ACS capability must be present in the RCiEP or i-EP endpoint functions if the RCiEP or i-EP Endpoint ISA multi-function device and supports P2P traffic between its functions.     | Leve | el 3+ |

## 4.6 Exerciser

Exerciser functionality is verified by running the tests on a single PE in the system.

| Test<br>ID | Test case                                                                                                                                                                   | System<br>interface<br>dependency                                   | Requirement of<br>Secure firmware | Level    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------|----------|
| 801        | PEs are able to access the ECAM region                                                                                                                                      |                                                                     |                                   | Level 3+ |
| 802        | PEs are able to access the BAR address of Exerciser                                                                                                                         |                                                                     |                                   | Level 3+ |
| 803        | In a system where the PCI<br>Express does not use an<br>SMMU, the PCI Express<br>devices have the same view<br>of physical memory as the<br>PEs                             | DMA transactions<br>trigger                                         |                                   | Level 3+ |
| 804        | Each unique MSI(-X) shall trigger an interrupt with a unique ID and the MSI(-X) shall target GIC registers requiring no hardware-specific software to service the interrupt | System Interrupt<br>ITS Support,<br>LPI Support,<br>MSI(-X) mapping |                                   | Level 3+ |
| 805        | If the system supports PCIe<br>PASID, then at least 16 bits of<br>PASID must be supported                                                                                   |                                                                     |                                   | Level 3+ |
| 806        | Trigger Legacy Interrupt using<br>Interrupt Pin register                                                                                                                    | System Interrupt and Interrupt Pin mapping                          |                                   | Level 3+ |

| Test<br>ID | Test case                                                                                                                                                       | System<br>interface<br>dependency                                                                               | Requirement of<br>Secure firmware | Level    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------|----------|
| 807        | PCI Express transactions not marked as No_snoop accessing memory that the PE translation tables attribute as cacheable and shared are I/O coherent with the PEs | DMA transactions<br>trigger                                                                                     |                                   | Level 3+ |
| 808        | Memory space access should raise Unsupported Request, when device Memory Space enable bit is clear of RootPort                                                  |                                                                                                                 |                                   | Level 3+ |
| 809        | Configuration transactions indented for secondary bus of root port must be of Type0                                                                             | Platform-specific                                                                                               |                                   | Level 3+ |
| 810        | Configuration transactions indented for subordinate bus range of root port must be of Type1                                                                     | Platform-specific                                                                                               |                                   | Level 3+ |
| 811        | Address Translation Service (ATS) functionality check                                                                                                           | DMA transactions<br>trigger, ATS Support                                                                        |                                   | Level 3+ |
| 812        | Check peer-to-peer ACS source validation and transaction blocking functionality                                                                                 | DMA transactions<br>trigger, P2P<br>functionality, 2<br>Exerciser on<br>different Root port<br>with ACS Support |                                   | Level 3+ |
| 813        | Check peer-to-peer ACS redirected request validation functionality                                                                                              | DMA transactions<br>trigger, P2P<br>functionality, 2<br>Exerciser on<br>different Root port<br>with ACS Support |                                   | Level 3+ |
| 814        | PCI Express transactions marked as No_snoop that are accessing memory must have coherency managed by software.                                                  | DMA transactions<br>trigger                                                                                     |                                   | Level 3+ |

| 815 | Transactions that are targeted at devices must be treated as device-type accesses. They must be ordered and not be merged | Platform-specific | Level 3+ |
|-----|---------------------------------------------------------------------------------------------------------------------------|-------------------|----------|
|     | and allocated in caches.                                                                                                  |                   |          |

# 4.7 Wakeup semantics

Wakeup semantics functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                | System<br>interface<br>dependency  | Requirement of<br>Secure firmware | Level    |
|------------|--------------------------------------------------------------------------|------------------------------------|-----------------------------------|----------|
| 501        | Wake up from power semantic B due to ELO Physical Timer Interrupt (PTI). | System Register<br>write, GIC APIs | No                                | Level 2+ |
| 502        | Wake up from power semantic B due to ELO Virtual Timer Interrupt (VTI).  | System Register write, GIC APIs    | No                                | Level 2+ |
| 503        | Wake up from power semantic B due to EL2 PTI.                            | System Register write, GIC APIs    | No                                | Level 2+ |
| 504        | Wake up from power semantic B due to watchdog WSO interrupt.             | System Register write, GIC APIs    | No                                | Level 2+ |
| 505        | Wake up from power semantic B due to system timer interrupt.             | Platform code                      | No                                | Level 2+ |

### 4.8 Peripherals

Peripheral functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                                                                                                                                                                                | System interface dependency           | Requirement of<br>Secure firmware | Level    |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------|----------|
| 601        | If the system has a USB 2.0 host controller peripheral, it must conform to EHCI v1.1 or later. But peripheral subsystems which do not conform to the same are permitted, provided that they are not required to boot and install an OS.  | USB<br>EHCIHostController<br>Protocol | No                                | Level 0+ |
|            | If the system has a USB 3.0 host controller Peripheral, it must conform to XHCI v1.0 or later. But peripheral subsystems which do not conform to the above are permitted, provided that they are not required to boot and install an OS. | USB<br>XHCIHostController<br>Protocol |                                   |          |
| 602        | If the system has a SATA host controller peripheral it must conform to AHCI v1.3 or later. But peripheral subsystems which do not conform to the above are permitted, provided that they are not required to boot and install an OS.     | SATA<br>AHCIHostController            | No                                | Level 0+ |

| Test<br>ID | Test case                                                                                                                                                                                                                                                                   | System interface dependency | Requirement of<br>Secure firmware | Level    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|----------|
| 603        | For the purpose of system development and bring up, the base server system will include a Generic UART. The Generic                                                                                                                                                         | Protocol                    | No                                | Level 1+ |
|            | UART is specified in Appendix B. The UARTINTR interrupt output is connected to the GIC as an SPI.                                                                                                                                                                           |                             |                                   |          |
|            | Check that the Generic UART is mapped to Nonsecure address space.                                                                                                                                                                                                           | Register read               |                                   | Level 3+ |
| 604        | UARTINTR of the generic<br>UART will be connected as<br>SPI or LPI.                                                                                                                                                                                                         | Yes                         | No                                | Level 2+ |
| 605        | Accesses to the unpopulated part of the memory map must not deadlock and cause a precise Data Abort, SEI or SPU interrupt delivered to the GIC.                                                                                                                             | UEFI Memory Map             | No                                | Level 0+ |
|            | In a memory access to an unpopulated part of the addressable memory space, the accesses must be terminated in a manner that is presented to the PE as either a precise Data Abort or that causes a system error interrupt or SPI, LPI interrupt to be delivered to the GIC. |                             |                                   | Level 2+ |

| Test<br>ID | Test case                                                                                                                                                        | System interface dependency | Requirement of<br>Secure firmware | Level    |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|----------|
| 606        | Secure generic UART is present. It is not aliased in Non-secure address space. The UARTINTR output of the Secure generic UART is connected to the GIC as an SPI. | Register read/write         | Yes                               | Level 3+ |

### 4.9 IO Virtualization (SMMU)

IO Virtualization functionality is verified from running the test on a single PE in the system.

| Test<br>ID | Test case                                                                                                                       | System interface dependency | Requirement of<br>Secure firmware | Level    |
|------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|----------|
| 701        | The SMMU, if present must support a 64KB granule.                                                                               | Register read               | No                                | Level 0+ |
| 702        | All the System MMUs in<br>the system must be<br>compliant with the same<br>architecture version.                                | ACPI IORT<br>table          | No                                | Level 3+ |
| 703        | If SMMUv3 is in use, the integration of the System MMUs is compliant with the specification in Appendix H:  SMMUv3 Integration. | ACPI IORT<br>table          | No                                | Level 3+ |
|            | A System MMU compatible with the Arm SMMUv2 or SMMUv3 specification must provide stage 2 System MMU functionality.              | Register read               | -                                 |          |

| Test<br>ID | Test case                                                                                                                                                | System interface dependency       | Requirement of Secure firmware | Level    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--------------------------------|----------|
| 704        | The SMMUv3 specification requires that PCIe root complex must not use the stall model due to potential deadlock.                                         | ACPI table, Register read         | -                              | Level 3+ |
| 705        | If SMMUv2 is in use, each context bank must present a unique physical interrupt to the GIC.                                                              | Yes                               | -                              | Level 3+ |
| 706        | Each function, or virtual function, that requires hardware I/O Virtualization is associated with an SMMU context. The programming of this association is | -                                 | -                              | Level 1+ |
|            | IMPLEMENTATION DEFINED and is expected to be described by system firmware data.                                                                          |                                   |                                |          |
| 707        | SMMU version check                                                                                                                                       | ACPI IORT table,<br>Register read | -                              | Level 1+ |
| 708        | SMMU must implement support for 16-bit VMID.                                                                                                             | ACPI IORT table,<br>Register read | -                              | Level 6+ |
| 709        | SMMU must implement support for 16-bit ASID.                                                                                                             | ACPI IORT table,<br>Register read | -                              | Level 6+ |

| 710 | SMMU must support<br>the translation granule<br>sizes supported by the<br>PEs.                                                                                                  | ACPI IORT table,<br>Register read | - | Level 6+ |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---|----------|
| 711 | If PEs implement<br>ARMv8.2-LVA, the<br>SMMU must support<br>extended virtual<br>addresses                                                                                      | ACPI IORT table,<br>Register read | - | Level 6+ |
| 712 | If PEs implement<br>Armv8.2-LPA, the<br>SMMU must support a<br>52-bit output size                                                                                               | ACPI IORT table,<br>Register read | - | Level 3+ |
| 713 | SMMU must implement coherent access to memory structures, queues, and page tables                                                                                               | ACPI IORT table,<br>Register read | - | Level 6+ |
| 714 | SMMU must support<br>Hardware Translation<br>Table Update (HTTU) of<br>the Access flag and the<br>Dirty state of the page<br>for AArch64 translation<br>tables.                 | ACPI IORT table,<br>Register read |   | Level 6+ |
| 715 | SMMU supports little endian for translation table walks, and at a minimum must match the endianness support of the PEs.                                                         | ACPI IORT table,<br>Register read | - | Level 6+ |
| 716 | The DVM capabilities of all DVM receivers (SMMUs and PEs) must be the same or a superset of the DVM capabilities of all DVM initiators (PEs). Check for TLB Range Invalidation. | ACPI IORT table,<br>Register read |   | Level 6+ |

### 4.10 EL3 - Trusted Firmware



Running the EL3-Firmware tests is not required for ServerReady certification.

| Test<br>ID | Test case                                                                                                                                          | System<br>interface<br>dependency | Requirement of<br>Secure firmware | Level    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------|----------|
| 901        | Watchdog Signal 1 is available. This may be confirmed in the data base. This may not be possible to exercise as its handling is platform-specific. | Watchdog APIs<br>and GIC APIs     | Yes                               | Level 1+ |
|            | The Watchdog Signal 1 is routed as a SPI to GIC and usable as an EL3 interrupt, directly targeting a single                                        |                                   |                                   | Level 3+ |
|            | PE.                                                                                                                                                |                                   |                                   |          |
| 902        | Must implement at least 56 bits.                                                                                                                   | Timer APIs and PE APIs            | Yes                               | Level 0+ |
|            | The counter shall be sized and programmed to ensure that rollover never occurs in practice.                                                        |                                   |                                   | Level 0+ |
|            | In systems that implement EL3, CNTControlBase should be mapped to Secure address space only.                                                       |                                   |                                   | Level 1+ |
|            | Generic Timer required registers are implemented as specified in section 4.2.3.1 Summary of required                                               |                                   |                                   | Level 1+ |
|            | registers of the CNTControlBase frame.                                                                                                             |                                   |                                   |          |
| 903        | The local PE timer when expiring must generate a PPI when EL3 physical timer expires.                                                              | Secure firmware<br>APIs           | Yes                               | Level 0+ |
|            | The local PE timer when expiring must generate a PPI when EL3 physical timer expires, and PPI must                                                 |                                   |                                   | Level 2+ |
|            | be 29.                                                                                                                                             |                                   |                                   |          |
|            |                                                                                                                                                    |                                   |                                   |          |

| Test<br>ID | Test case                                                                                                                                                                                                      | System<br>interface<br>dependency | Requirement of<br>Secure firmware | Level    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------|----------|
| 904        | Any local timers that are marked by PE as always ON                                                                                                                                                            | Secure firmware APIs              | Yes                               | Level 0+ |
|            | must be able to wake up the system. This applies to expiry of all Secure views of the local timer (CNTPS).                                                                                                     |                                   |                                   |          |
|            | Secure Watchdog is implemented. Secure watchdog is not aliased in Non-secure address space. Signal 0 if Secure watchdog is routed as an SPI and usable as an interrupt to EL3, directly targeting a single PE. |                                   |                                   | Level 3+ |
| 905        | Secure Generic UART is present. It is not aliased in Non-secure address space. The UARTINTR output of the Secure generic UART is connected to the GIC as an SPI.                                               | Secure firmware<br>APIs           | Yes                               | Level 3+ |
| 906        | A Secure system wakeup timer is present, and the interrupt is presented to GIC as a SPI.                                                                                                                       | Secure firmware<br>APIs           | Yes                               | Level 3+ |

### 5 Test scenarios

The test scenarios are divided based on the functionality and the hardware domain access. The test suite follows this division of test scenarios to better categorize the test report.

The level of target compliance is an input to each of these test scenarios. The scenarios are classified into the following:

#### **5.1 VAL APIs**

The following VAL APIs are consumed by all the tests and are not mentioned explicitly for each test.

- val\_initialize\_test
- val\_run\_test\_payload
- val\_pe\_get\_index\_mpid
- val\_pe\_get\_mpid
- val\_set\_status
- val\_report\_status

#### 5.2 PE

The VAL API val\_pe\_create\_info\_table must be called before any of the following test scenarios are executed.

#### 5.2.1 Number of PEs

The PEs referred to in the SBSA specification are those that are running the operating system or hypervisor, not PEs that are acting as devices.

#### Does not exceed 8

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 1       | val_pe_get_num    | 4.1.1                 | Level 0, 1                  |

#### Does not exceed 2^28

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 1       | val_pe_get_num    | 4.1.1                 | Level 2+                    |

#### **5.2.2** PEs must implement SIMD extensions

ID\_AA64PFR0\_EL1 must indicate support bits [23:20].

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 2       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.3 PEs must implement 16-bit ASID support

ID\_AA64MMFR0\_EL1 must indicate support for 16-bit ASIDs in ASIDBits == 0010 for all cores.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 3       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.4 PEs must support 4KB and 64KB at stage 1 and 2

ID AA64MMFR0 EL1 must indicate support for 4KB and 64KB granules for all cores.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 4       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.5 Cache are implemented as VIPT or PIPT

CTR\_ELO bits 15:14 must indicate the instruction cache type.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 5       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.6 All PEs are coherent and in the same Inner Shareable domain

ID\_MMFRO\_EL1.InnerShr must indicate hardware coherency support for InnerShr across all cores, ShreLvI must be 0001 across all cores (later is mandated for Armv8). Functional verification is optional.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 6       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.7 PEs must implement Cryptography extensions

ID\_ISAR5\_EL1 must indicate support for SHA1 and SHA2, AES, and PMULL and PMULL2 instructions. This test must be run only when Export restriction allows Cryptography Extensions.

PJDOC-2042731200-3439 Issue 03 Test scenarios

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 7       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.8 PEs must have LE support

ID\_AA64MMFRO\_EL1 indicates whether mixed-endian support is present. If mixed-endian is not supported then SCTLR\_ELx.EE must strictly read as 0 indicating endianness as little-endian. If mixed-endian is supported, then memory reads with toggled SCTLR\_ELx.EE must return swizzled data.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 8       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.9 PEs must implement EL2

ID\_AA64PFR0\_EL1 bits 11:8 must indicate EL2 is supported.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 9       | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.10 PEs must implement AArch64

ID\_AA64PFR0\_EL1 must indicate support for AArch64 for all levels.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 10      | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.11 PMU overflow signal

The generated PMUIRQ must be wired to unique ID and returned as part of the platform code.

Must be wired to a unique PPI or SPI

| Test ID | VAL APIs consumed                                               | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------|-----------------------|-----------------------------|
| 10      | <pre>val_pe_reg_read val_pe_reg_write val_gic_install_isr</pre> | 4.1.1                 | Level 0, 1                  |
|         | val_pe_get_pmu_gsiv                                             |                       |                             |

#### Must be wired to PPI 23

| Test ID | VAL APIs consumed                                               | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------|-----------------------|-----------------------------|
| 11      | <pre>val_pe_reg_read val_pe_reg_write val_gic_install_isr</pre> | 4.1.1                 | Level 2+                    |
|         | val pe get pmu gsiv                                             |                       |                             |

#### 5.2.12 PMU counters

Implement minimum of 4

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 12      | val_pe_reg_read   | 4.1.1                 | Level 0                     |

#### Implement minimum of 6

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 12      | val_pe_reg_read   | 4.2.1                 | Level 1+                    |

#### 5.2.13 PEs must implement a minimum of four synchronous watchpoints

ID\_AA64DFR0\_EL1.WRPs must indicate a value of at least 3.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 13      | val_pe_reg_read   | 4.1.1                 | Level 0+                    |

#### 5.2.14 Breakpoints

ID\_AA64DFRO\_EL1.BRPs indicates number of breakpoints implemented. ID\_AA64DFRO\_EL1.CTX\_CMPs should read at least 1.

Implement minimum of 4

ID\_AA64DFR0\_EL1.WRPs must indicate a value of at least 3. ID\_AA64DFR0\_EL1.CTX\_CMPs must read at least 1.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 14      | val_pe_reg_read   | 4.1.1                 | Level 0                     |

Implement minimum of 6

ID\_AA64DFR0\_EL1.WRPs must indicate a value of at least 5. ID\_AA64DFR0\_EL1.CTX\_CMPs must read at least 1.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 14      | val_pe_reg_read   | 4.2.1                 | Level 1+                    |

### **5.2.15** All PEs are architecturally symmetric

Read all the processor ID registers from all PEs and then compare the values with the main PE (cpu\_id 0).

| Test ID | VAL APIs consumed    | Specification section | Compliance level applicable |
|---------|----------------------|-----------------------|-----------------------------|
| 15      | val_pe_reg_read      | 4.1.1                 | Level 0+                    |
|         | val_set_test_data    |                       |                             |
|         | val_data_cache_ci_va |                       |                             |

#### 5.2.16 EL3 must be implemented

ID\_AA64PFR0\_EL1 bits 15:12 must indicate EL3 is supported.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 16      | val_pe_reg_read   | 4.4.1                 | Level 3+                    |

#### 5.2.17 CRC32 instruction must be implemented

Read processor register ID\_AA64ISAR0\_EL1 bits 19:16.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 17      | val_pe_reg_read   | 4.4.1                 | Level 3+                    |

#### 5.2.18 PMBIRQ will be wired as PPI 21

The generated PMBIRQ must be wired to unique ID will be returned as part of the platform code.

| Test ID | VAL APIs consumed                                              | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------|-----------------------|-----------------------------|
| 18      | val_pe_reg_read                                                | 4.4.1                 | Level 2+                    |
|         | val_pe_reg_write<br>val_gic_install_isr<br>val_secure_call_smc |                       |                             |
|         | <pre>val_pe_spe_program_under_p rofiling</pre>                 |                       |                             |
|         | val_pe_spe_disable                                             |                       |                             |

#### 5.2.19 All PEs must implement the RAS extension introduced in Armv8.2

Read PE register ID\_AA64PFR0\_EL1 bits 31:28.

PJDOC-2042731200-3439 Issue 03 Test scenarios

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 19      | val_pe_reg_read   | 4.3.1                 | Level 4+                    |

#### 5.2.20 All PEs must implement support for 16-bit VMD

Read PE register ID\_AA64MMFR1\_EL1 bits 7:4.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 20      | val_pe_reg_read   | 4.3.1                 | Level 4+                    |

#### 5.2.21 All PEs must implement virtual host extensions

Read PE register ID\_AA64MMFR1\_EL1 bits 11:8.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 21      | val_pe_reg_read   | 4.3.1                 | Level 4+                    |

### 5.2.22 If PEs implement Armv8.3 pointer signing, the PEs must provide the standard algorithm defined by the Armarchitecture

Read PE register ID\_AA64ISAR1\_EL1 and check bits[7:4], bits[11:8], bits[27:24] and bits[31:28].

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 22      | val_pe_reg_read   | 4.4.1                 | Level 4+                    |

#### 5.2.23 All PEs must implement enhanced nested Virtualization

Read PE register ID\_AA64MMFR2\_EL1.FWB bits 27:24.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 23      | val_pe_reg_read   | 4.4.1                 | Level 5+                    |

### 5.2.24 All PEs must support changing of page table mapping size using level 1 and level 2 solution proposed in the Armv8.4extension

Read PE register ID\_AA64MMFR2\_EL1.FWB bits 55:52.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 24      | val_pe_reg_read   | 4.4.1                 | Level 5+                    |

## 5.2.25 All PEs must provide support for stage 2 control of memory types and Cacheability, as introduced by Armv8.4 extensions

Read PE register ID\_AA64MMFR2\_EL1.FWB bits 43:40.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 25      | val_pe_reg_read   | 4.4.1                 | Level 5+                    |

#### 5.2.26 All PEs must implement the Activity Monitors Extension

Read PE register ID\_AA64PFR0\_EL1 bits 47:44.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 26      | val_pe_reg_read   | 4.4.1                 | Level 5+                    |

### 5.2.27 Where export control allows, all PEs must implement cryptography support for SHA3 and SHA512

Read PE register ID\_AA64ISAR0\_EL1.SHA3 bits [35:32] and bits [15:12].

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 27      | val_pe_reg_read   | 4.4.1                 | Level 5+                    |

### 5.2.28 Where PEs implement the scalar vector extension, the vector length maximum must be at least 256 bits

Read PE register ID AA64PFR0 EL1 bits [35:32] and check PE register RDVL value

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 28      | val_pe_reg_read   | 4.4.1                 | Level 3+                    |

### **5.2.29** PEs must implement restrictions on speculation introduced in the Arm v8.5 extensions

Read PE Register ID\_AA64PFR0\_EL1.CSV2[59:56] = 0b0010 Speculative use of Out of Ctxt Branch Targets and ID\_AA64PFR0\_EL1.CSV3[63:60] = 0b0001 Speculative use of Faulting data

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 29      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

#### 5.2.30 PEs must implement Speculative Store Bypass Safe

Read PE Register ID\_AA64PFR1\_EL1.SSBS[7:4] = 0b0010

| Test in the variable consumed specification section combinate level applicable | Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|--------------------------------------------------------------------------------|---------|-------------------|-----------------------|-----------------------------|
|--------------------------------------------------------------------------------|---------|-------------------|-----------------------|-----------------------------|

| 30 | val pe reg read | 4.5.1 | Level 6+ |
|----|-----------------|-------|----------|

#### 5.2.31 PEs must implement the SB speculation barrier read

Read PE Register ID\_AA64ISAR1\_EL1.SPECRES[43:40] = 0b0001

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 31      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

### 5.2.32 PEs must implement the CFP RCTX, DVP RCTX, CPP RCTX instructions

Read PE Register ID\_AA64ISAR1\_EL1.SPECRES[43:40] = 0b0001 For CFP, DVP, CPP RCTX Instructions

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 32      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

#### 5.2.33 PEs must provide support for Branch Target Identification

Read PE Register ID AA64PFR1 EL1.BT[3:0] = 0b0001 For Branch Target Identification Support

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 33      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

## 5.2.34 PEs must protect against timing faults being used to guess page table mappings

Read ID AA64MMFR2 EL1.E0PD[63:60] = 0b0001 For Support for Protect Against Timing Fault

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 34      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

#### 5.2.35 PEs will provide support for enhanced virtualization traps

Read ID\_AA64MMFR2\_EL1.EVT[59:56] = 0b0010 - Support for Enhanced Virtualization Trap

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 35      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

#### 5.2.36 All PEs will implement Armv8.5-PMU

Read ID\_AA64DFR0\_EL1.PMUVer[11:8] = 0b0110 For Support for PMU v8.5 Support

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 36      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

# 5.2.37 If PEs implement the Scalable Vector Extension (SVE) and the Statistical Profiling Extension (SPE), the PEs will implement Armv8.3-SPE

Read ID\_AA64DFR0\_EL1.PMSVer[35:32] = 0b0010 for v8.3-SPE

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 37      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

# 5.2.38 Hardware updates to Access flag and Dirty state in translation tables, must be supported

Read ID\_AA64MMFR1\_EL1.HAFDBS[3:0] = 0b0010 For Hardware update supported

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 38      | val_pe_reg_read   | 4.5.1                 | Level 6+                    |

#### **5.3 GIC**

The VAL API val\_gic\_create\_info\_table needs to be called before any of the following test scenarios are executed.

#### 5.3.1 GIC version

GIC V2 is implemented

ID registers are at offset 0xFE8 (ICPIDR2.ArchRev) == 0x2. On ACPI tables, GICD structure in MADT must indicate revision 2 for the GIC.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 101     | val_gic_get_info  | 4.1.2                 | Level 0, 1                  |

GIC V3 is implemented

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 101     | val_gic_get_info  | 4.3.2                 | Level 2+                    |

### 5.3.2 If the system includes PCI Express, then the GICv3 interrupt controller will implement ITS and LPI

Check if ECAM is present, if yes, assume the system implements PCIe. Check for the presence of ITS from MADT table and HW register value.

| Test ID | VAL APIs consumed | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 102     | val_gic_get_info  | 4.3.2                 | Level 2+                    |
|         | val_pcie_get_info |                       |                             |

#### 5.3.3 The GICv3 interrupt controller will support two Security states

Check GICD\_CTLR.DS bit (bit6 == 0 : 2 states, bit 6 == 1 : 1 state).

| Test ID | VAL APIs consumed     | Specification section | Compliance level applicable |
|---------|-----------------------|-----------------------|-----------------------------|
| 103     | val_gic_get_gicd_base | 4.4.4                 | Level 3+                    |
|         | val_gic_get_info      |                       |                             |

#### 5.3.4 GIC maintenance interrupt shall be wired as PPI25

The generated GIC maintenance interrupt must be wired as PPI 25.

| Test ID | VAL APIs consumed                                                       | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------|-----------------------|-----------------------------|
| 104     | val_gic_get_info val_gic_install_isr val_gic_reg_read val_gic_reg_write | 4.4.4                 | Level 3+                    |
|         | val_gic_end_of_interrupt                                                |                       |                             |

### **5.4 System and Generic Timer**

Call the VAL API val\_timer\_create\_info\_table before any of the following test scenarios are executed.

### 5.4.1 System counter of the Generic Timer will run at a minimum frequency of 10 and at a maximum frequency of 400MHz

ACPI GTDT table gives the frequency of the timer. The test must check that the frequency matches the value read from CNTFREQ registers. The functional test of the timer clock frequency is beyond the capability of the AVS suite.

| Test ID | VAL APIs consumed      | Specification section | Compliance level applicable |
|---------|------------------------|-----------------------|-----------------------------|
| 201     | val_gic_get_timer_info | 4.1.5                 | Level 0+                    |

### 5.4.2 The local PE timer when expiring must generate a PPI when the EL1 physical timer expires

This must test the overflow when programming CNTP\_TVAL\_ELO or CNTP\_CVAL\_ELO. The test must ensure for each CPU a PPI is generated, and the PPI is the same for all CPUs.

Must be wired to a unique PPI for associated PE

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 202     | val_gic_get_timer_info                       | 4.1.5                 | Level 0, 1                  |
|         | val_gic_install_isr<br>val_timer_set_phy_el1 |                       |                             |

#### Must be wired to PPI 30

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 202     | val_gic_get_timer_info                       | 4.3.2.1               | Level 2+                    |
|         | val_gic_install_isr<br>val_timer_set_phy_el1 |                       |                             |

### 5.4.3 The local PE timer when expiring must generate a PPI when the virtual timer expires

This must test the overflow when programming CNTV\_TVAL\_ELO or CNTV\_VAL\_ELO. The test must ensure for each CPU a PPI is generated, and the PPI is the same for all CPUs.

Must be wired to a unique PPI for the associated PE

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 203     | val_gic_get_timer_info                       | 4.1.5                 | Level 0, 1                  |
|         | val_gic_install_isr<br>val_timer_set_vir_el1 |                       |                             |

#### Must be wired to PPI 27

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 203     | val_gic_get_timer_info                       | 4.3.2.1               | Level 2+                    |
|         | val_gic_install_isr<br>val_timer_set_vir_el1 |                       |                             |

## 5.4.4 The local PE timer when expiring must generate a PPI when the EL2 physical timer expires

This must test the overflow when programming CNTHP\_TVAL\_EL2 or CNTHP\_CVAL\_EL2. The test must ensure for each CPU a PPI is generated, and the PPI is the same for all CPUs.

Must be wired to a unique PPI for the associated PE

| Test ID | VAL APIs consumed                                    | Specification section | Compliance level applicable |
|---------|------------------------------------------------------|-----------------------|-----------------------------|
| 204     | val_gic_get_timer_info                               | 4.1.5                 | Level 0, 1                  |
|         | <pre>val_gic_install_isr val_timer_set_phy_el2</pre> |                       |                             |

#### Must be wired to PPI 26

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 204     | val_gic_get_timer_info                       | 4.3.2.1               | Level 2+                    |
|         | val_gic_install_isr<br>val_timer_set_phy_el2 |                       |                             |

# 5.4.5 The Local PE timer when expiring must generate a PPI when the EL2 virtual timer expires

Must be wired to a unique PPI for the associated PE

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 205     | val_gic_get_timer_info                       | 4.1.5                 | Level 0, 1                  |
|         | val_gic_install_isr<br>val_timer_set_vir_el2 |                       |                             |
|         | val_pe_reg_read                              |                       |                             |

#### Must be wired to PPI 28

| Test ID | VAL APIs consumed                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 205     | val_gic_get_timer_info                       | 4.3.2.1               | Level 2+                    |
|         | val_gic_install_isr<br>val_timer_set_vir_el2 |                       |                             |
|         | val_pe_reg_read                              |                       |                             |

# 5.4.6 In systems that implement EL3, the memory mapped timer must be mapped into the Non-secure address space (the CNTBaseN frame and associated CNTCTLBase frame)

| Test ID | VAL APIs consumed                                              | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------|-----------------------|-----------------------------|
| 206     | <pre>val_gic_get_timer_info val_mmio_read val_mmio_write</pre> | 4.2.3                 | Level 1+                    |

If the system includes a system wakeup timer, this memory-mapped timer must be mapped on to Non-secure address space

| Test ID | VAL APIs consumed                                              | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------|-----------------------|-----------------------------|
| 206     | <pre>val_gic_get_timer_info val_mmio_read val_mmio_write</pre> | 4.3.2.1               | Level 3+                    |

# 5.4.7 Unless all of the local PE timers are always on, the base server system will implement a system-specific system wakeup timer

| Test ID | VAL APIs consumed      | Specification section | Compliance level applicable |
|---------|------------------------|-----------------------|-----------------------------|
| 207     | val_gic_get_timer_info | 4.1.5                 | Level 0+                    |

#### 5.4.8 System-specific system timer shall generate an SPI

| Test ID | VAL APIs consumed                                                                              | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 208     | val_timer_get_info val_timer_skip_if_cntbase_acc ess_not_allowed val_gic_install_isr           | 4.1.5                 | Level 0+                    |
|         | <pre>val_timer_set_system_timer val_timer_disable_system_tim er val_gic_end_of_interrupt</pre> |                       |                             |

### 5.5 Watchdog

Call the VAL API val\_wd\_create\_info\_table before any of the following test scenarios are executed.

#### 5.5.1 System implements a Generic Watchdog as specified in SBSA specification.

| Test ID | APIs consumed   | Specification section | Compliance level applicable |
|---------|-----------------|-----------------------|-----------------------------|
| 301     | val_wd_get_info | 4.2.4                 | Level 1+                    |

The Non-secure watchdog must have both its register frames mapped on to Non-secure address space

| Test ID | APIs consumed   | Specification section | Compliance level applicable |
|---------|-----------------|-----------------------|-----------------------------|
| 301     | val_wd_get_info | 4.4.7                 | Level 2+                    |
|         | val_mmio_read   |                       |                             |

### 5.5.2 Watchdog Signal 0 is routed as SPI (or LPI) and usable as an EL2 interrupt

WSO routed as SPI

| Test ID | APIs consumed                                 | Specification section | Compliance level applicable |
|---------|-----------------------------------------------|-----------------------|-----------------------------|
| 302     | val_wd_get_info                               | 4.2.4                 | Level 0, 1                  |
|         | <pre>val_gic_install_isr val_wd_set_ws0</pre> |                       |                             |

WSO routed as SPI or LPI

| Test ID | APIs consumed                         | Specification section | Compliance level applicable |
|---------|---------------------------------------|-----------------------|-----------------------------|
| 302     | val_wd_get_info                       | 4.3.8                 | Level 2, 3                  |
|         | val_gic_install_isr<br>val_wd_set_ws0 |                       |                             |

# 5.5.3 A system compatible with level 5 will implement a generic counter which counts in nanosecond units, Arm strongly recommends that such systems use revision 1 of the generic watchdog.

| Test ID | APIs consumed   | Specification section | Compliance level applicable |
|---------|-----------------|-----------------------|-----------------------------|
| 303     | val_wd_get_info | 4.4.4                 | Level 5+                    |

### 5.6 Peripherals and memory

Call the VAL APIs val\_peripheral\_create\_info\_table and val\_memory\_create\_info\_table for relevant test scenarios before their execution.

# 5.6.1 If the system has a USB2.0 (USB3.0) host controller peripheral, it must conform to EHCl v1.1 (XHCl v1.0) or later.

| Test ID | APIs consumed           | Specification section | Compliance level applicable |
|---------|-------------------------|-----------------------|-----------------------------|
| 601     | val_peripheral_get_info | 4.1.11                | Level 0+                    |
|         | val_pcie_read_cfg       |                       |                             |

### 5.6.2 If the system has a SATA host controller peripheral, it must conform to AHCI v1.3 or later.

| Test ID | APIs consumed           | Specification section | Compliance level applicable |
|---------|-------------------------|-----------------------|-----------------------------|
| 602     | val_peripheral_get_info | 4.1.11                | Level 0+                    |
|         | val_pcie_read_cfg       |                       |                             |

# 5.6.3 Base server system will include a Generic UART as specified in Appendix B. Check that that Generic UART is mapped to Non-secure address space

| Test ID | APIs consumed           | Specification section | Compliance level applicable |
|---------|-------------------------|-----------------------|-----------------------------|
| 603     | val_peripheral_get_info | 4.1.11                | Level 0+                    |

### 5.6.4 The UARTINTR interrupt output is connected to the GIC.

**UARTINTR** routed as SPI or LPI

| Test ID | APIs consumed           | Specification section | Compliance level applicable |
|---------|-------------------------|-----------------------|-----------------------------|
| 604     | val_peripheral_get_info | B.3                   | Level 1+                    |
|         | val_gic_install_isr     |                       |                             |

## 5.6.5 Memory access to an unpopulated part of the addressable memory space

In a memory access to an unpopulated part of the addressable memory space, the accesses must be terminated in a manner that is presented to the PE as either a precise Data Abort or that causes a system error interrupt or SPI, LPI interrupt to be delivered to the GIC.

| Test ID | APIs consumed                             | Specification section | Compliance level applicable |
|---------|-------------------------------------------|-----------------------|-----------------------------|
| 605     | val_pe_get_elr_stacked_addr               | 4.1.3                 | Level 0+                    |
|         | val_pe_install_esr<br>val_memory_get_info |                       |                             |

#### 5.6.6 Non-secure access to Secure address must cause exception.

Some memory is mapped in secure address space. The memory shall not be aliased in Non-secure address space.

| Test ID | APIs consumed      | Specification section | Compliance level applicable |
|---------|--------------------|-----------------------|-----------------------------|
| 606     | val_pe_install_esr | 4.1.3                 | Level 3+                    |
|         | val_pe_update_elr  |                       |                             |
|         | val pe reg read    |                       |                             |

### 5.7 Power states and wakeup

There are no prerequisite VAL APIs for the following tests.

# 5.7.1 In state B, a PE must be able to wake on receipt of an SGI, PPI or SPI that directly targets the PE.

Wake up due to ELO PTI

| Test ID | APIs consumed                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------|-----------------------|-----------------------------|
| 501     | val_timer_get_info val_timer_set_phy_el1 val_gic_install_isr | 4.1.8                 | Level 0+                    |
|         | val_power_enter_semantic                                     |                       |                             |

#### Wake up due to EL0 VTI

| Test ID | APIs consumed            | Specification section | Compliance level applicable |
|---------|--------------------------|-----------------------|-----------------------------|
| 502     | val_timer_get_info       | 4.1.8                 | Level 0+                    |
|         | val_timer_set_vir_el1    |                       |                             |
|         | val_timer_set_phy_el1    |                       |                             |
|         | val_gic_install_isr      |                       |                             |
|         | val_power_enter_semantic |                       |                             |

#### Wake up due to EL2 PTI

| Test ID | APIs consumed                                                                                 | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 503     | <pre>val_timer_get_info val_timer_set_phy_el2 val_timer_set_phy_el2 val_gic_install_isr</pre> | 4.1.8                 | Level 0+                    |
|         | val_power_enter_semantic                                                                      |                       |                             |

#### Wake up due to Watchdog WSO Interrupt

| Test ID | APIs consumed                                                                                                                   | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 504     | <pre>val_wd_get_info val_wd_set_ws0 val_timer_get_info val_timer_set_phy_el1 val_gic_install_isr val_power_enter_semantic</pre> | 4.1.8                 | Level 0+                    |

Wake up due to system time interrupt

| Test ID | APIs consumed                                                                | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 505     | <pre>val_timer_get_info val_timer_set_system_timer val_gic_install_isr</pre> | 4.1.8                 | Level 0+                    |
|         | val_power_enter_semantic                                                     |                       |                             |

### **5.8 IO Virtualization**

#### 5.8.1 SMMU if present is compatible with Arm SMMUv1

This test case can be skipped as it is very unlikely that the 2016/2017 platforms will have an SMMU compatible with version 1.

#### 5.8.2 SMMU if present, must support a 64KB translation granule

ID register gives the supported translation granule size.

| Test ID | APIs consumed                       | Specification section | Compliance level applicable |
|---------|-------------------------------------|-----------------------|-----------------------------|
| 701     | val_smmu_get_info val_smmu_read_cfg | -                     | Level 0+                    |

### 5.8.3 All the System MMUs in the system must be compliant with the same architecture version

| Test ID | APIs consumed     | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 702     | val_smmu_get_info | 4.1.6                 | Level 3+                    |

#### 5.8.4 If PCIe, check the stall model

| Test ID | APIs consumed     | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 704     | val_smmu_get_info | Appendix E            | Level 3+                    |
|         | val_pcie_get_info |                       |                             |

# 5.8.5 If SMMUv3 is in use, check the compliance with Appendix E: SMMUv3 integration

| Test ID | APIs consumed     | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 703     | val_smmu_get_info | 4.1.6                 | Level 3+                    |
|         | val_smmu_read_cfg | Appendix E            |                             |

### 5.8.6 If SMMUv2 is in use, Each context bank must present a unique physical interrupt to the GIC

| Test ID | APIs consumed                         | Specification section | Compliance level applicable |
|---------|---------------------------------------|-----------------------|-----------------------------|
| 705     | val_smmu_get_info                     | 4.1.6                 | Level 3+                    |
|         | val_iovirt_check_unique_ctx_i<br>ntid |                       |                             |

### 5.8.7 Each function, or virtual function, that requires hardware I/O Virtualization is associated with an SMMU context.

The programming of this association is IMPLEMENTATION DEFINED and is expected to be described by system firmware data.

| Test ID | APIs consumed                       | Specification section | Compliance level applicable |
|---------|-------------------------------------|-----------------------|-----------------------------|
| 706     | val_smmu_get_info                   | 4.1.6                 | Level 3+                    |
|         | val_iovirt_unique_rid_strid_m<br>ap |                       |                             |

#### 5.8.8 SMMU Version Check

| Test ID | APIs consumed       | Specification section | Compliance level applicable |
|---------|---------------------|-----------------------|-----------------------------|
| 707     | val_smmu_get_info() | 8.5.2                 | Level 1+                    |

#### 5.8.9 SMMU must implement support for 16-bit VMID.

Read SMMUv3\_IDR0 register to check support for 16-bit VMID.

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 708     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

#### 5.8.10 SMMU must implement support for 16-bit ASID.

Read SMMUv3\_IDR0[12] register to check support for 16-bit ASID

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 709     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

### 5.8.11 SMMU must support the translation granule sizes supported by the PEs.

Read SMMUv3\_IDR5 for granule support in SMMU, and ID\_AA64MMFR0\_EL1 for granule support in PEs.

| Test ID | APIs consumed                                                                            | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 710     | <pre>val_pcie_get_info() val_smmu_get_info() val_pe_reg_read() val_smmu_read_cfg()</pre> | 8.5.2                 | Level 6+                    |

### 5.8.12 If PEs implement Armv8.2-LVA, the SMMU must support extended virtual addresses

Read ID\_AA64MMFR2\_EL1 [19:16] for Armv8.2-LVA support, then check SMMU\_IDR5.VAX = 0b01.

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 711     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

### 5.8.13 If PEs implement Armv8.2-LPA, SMMU must support a 52 bit output size

Read ID AA64MMFR0 EL1 [3:0] for Armv8.2-LPA support, then check SMMU IDR5.OAS = 0b110.

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 712     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 3+                    |

### 5.8.14 The SMMU must implement coherent access to memory structures, queues, and page tables

Read SMMU Register SMMU\_IDR0.COHACC[4] == 1 for support.

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 713     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

## 5.8.15 The SMMU must support HTTU of the Access flag and the Dirty state of the page for AArch64 translation tables.

Read SMMU Register SMMU\_IDR0.HTTU[7:6] == 0b10

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 714     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

### 5.8.16 SMMU will support little endian for translation table walks, and at a minimum must match the endianness support of the PEs.

Check SCTLR\_ELx for endianness support in PEs and SMMUv3\_IDR0[22:21] for endianness support in SMMU.

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 715     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

# 5.8.17 The DVM capabilities of all DVM receivers (SMMUs and PEs) must be the same or a superset of the DVM capabilities of all DVM initiators (PEs). Check for TLB Range Invalidation

Check ID\_AA64ISARO\_EL1[59:56] == 0x2 for TLB Range invalidation support in PE's, then check for SMMU\_IDR3.RIL = 0b1.

| Test ID | APIs consumed                              | Specification section | Compliance level applicable |
|---------|--------------------------------------------|-----------------------|-----------------------------|
| 716     | val_pcie_get_info()<br>val_smmu_get_info() | 8.5.2                 | Level 6+                    |

#### **5.9 PCIE**

Call the VAL API val\_pcie\_create\_info\_table before any of the following test scenarios are executed.

## 5.9.1 Systems must map memory space to PCI Express configuration space, using the PCI Express Enhanced Configuration Access Mechanism (ECAM)

| Test ID | APIs consumed     | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 401     | val_pcie_get_info | D.1                   | Level 1                     |

#### 5.9.2 ECAM value present in MCFG

| Test ID | APIs consumed     | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 402     | val_pcie_get_info | D.1                   | Level 1+                    |

#### 5.9.3 PEs are able to access ECAM

| Test ID | APIs consumed     | Specification section | Compliance level applicable |
|---------|-------------------|-----------------------|-----------------------------|
| 403     | val_pcie_get_info | D.1                   | Level 1+                    |
|         | val_mmio_read     |                       |                             |

#### 5.9.4 PCIe space is device or non-cacheable

| Test ID | APIs consumed       | Specification section | Compliance level applicable |
|---------|---------------------|-----------------------|-----------------------------|
| 404     | val_pcie_get_info   | D.2                   | Level 1+                    |
|         | val_memory_get_info |                       |                             |

### 5.9.5 When PCI Express memory space is mapped as normal memory, the system must support unaligned accesses to that region.

| Test ID | APIs consumed       | Specification section | Compliance level applicable |
|---------|---------------------|-----------------------|-----------------------------|
| 404     | val_pcie_get_info   | D.2                   | Level 1+                    |
|         | val_memory_get_info |                       |                             |

# 5.9.6 In systems that are compatible with level 3 or above of the SBSA, the addresses sent by PCI Express devices must be presented to the memory system or SMMU unmodified

In a system where the PCI Express does not use an SMMU, the PCI Express devices have the same view of physical memory as the PEs.PCIe I/O Coherency Scenarios without System MMU are covered. PCIe I/O Coherency Scenarios with System MMU are covered.

| Test ID | APIs consumed | Specification | Compliance level applicable |
|---------|---------------|---------------|-----------------------------|
|         |               | section       |                             |

| 405 | <pre>val_pcie_get_info val_memory_get_info val_dma_get_info val_dma_start_from_device val_dma_start_to_device</pre> | D.3 | Level 1+ |  |
|-----|---------------------------------------------------------------------------------------------------------------------|-----|----------|--|
|     | val_smmu_ops                                                                                                        |     |          |  |

# 5.9.7 In a system with an SMMU for PCI Express there are no transformations to addresses being sent by PCI Express devices before they are presented as an input address to the SMMU.

The addresses sent by PCI Express devices must be presented to the memory system or SMMU unmodified.

| Test ID | APIs consumed                                                                                              | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 406     | <pre>val_pcie_get_info val_memory_get_info val_dma_get_info val_smmu_ops val_dma_device_get_dma_addr</pre> | D.3                   | Level 1+                    |
|         | val_dma_mem_alloc                                                                                          |                       |                             |

# 5.9.8 Support for Message Signaled Interrupts (MSI/MSI-X) is required for PCI Express devices.

MSI and MSI-X are edge-triggered interrupts that are delivered as a memory write transaction.

| Test ID | APIs consumed                                       | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------|-----------------------|-----------------------------|
| 407     | val_peripheral_get_info<br>val_pcie_get_device_type | D.4                   | Level 1+                    |

# 5.9.9 Each unique MSI(-X) shall trigger an interrupt with a unique ID and the MSI(-X) shall target GIC registers requiring no hardware-specific software to service the interrupt.

| Test ID | APIs consumed                                  | Specification section | Compliance level applicable |
|---------|------------------------------------------------|-----------------------|-----------------------------|
| 408     | val_peripheral_get_info<br>val_get_msi_vectors | D.4                   | Level 1+                    |

#### 5.9.10 All MSIs and MSI-x are mapped to LPI.

PJDOC-2042731200-3439 Issue 03 Test scenarios

| Test ID | APIs consumed                                  | Specification section | Compliance level applicable |
|---------|------------------------------------------------|-----------------------|-----------------------------|
| 409     | val_peripheral_get_info<br>val_get_msi_vectors | D.4                   | Level 1+                    |

### 5.9.11 If the system supports PCIe PASID, then at least 16 bits of PASID must be supported

| Test ID | APIs consumed                                                            | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------|-----------------------|-----------------------------|
| 410     | <pre>val_peripheral_get_info val_smmu_get_info val_smmu_max_pasids</pre> | D.14                  | Level 1+                    |

### 5.9.12 The PCI Express root complex is in the same Inner Shareable domain as the PEs

| Test ID | APIs consumed               | Specification section | Compliance level applicable |
|---------|-----------------------------|-----------------------|-----------------------------|
| 411     | val_iovirt_get_pcie_rc_info | D.8                   | Level 1+                    |

### 5.9.13 Each of the 4 legacy interrupt lines must be allocated a unique SPI ID and is programmed as level sensitive

| Test ID | APIs consumed                                         | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------|-----------------------|-----------------------------|
| 412     | val_peripheral_get_info<br>val_pci_get_legacy_irq_map | D.6                   | Level 1+                    |

## 5.9.14 All Non-secure on-chip masters in a base server system that are expected to be under the control of the OS or hypervisor must be capable of addressing all of the NS address space.

If the master goes through an SMMU then it must be capable of addressing all of the NS address space when the SMMU is off. Non-secure off-chip devices that cannot directly address all of the Non-secure address space must be placed behind a stage 1 System MMU compatible with the Arm SMMUv2 or SMMUv3 specification that has an output address size large enough to address all of the Non-secure address space.

| Test ID | APIs consumed                                                                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 413     | val_peripheral_get_info<br>val_pcie_is_devicedma_64bit<br>val_pcie_is_device_behind_sm<br>mu | 4.1.3                 | Level 1+                    |

#### 5.9.15 Memory Attributes of DMA traffic.

Memory Attributes of DMA traffic are one of (1) Inner WB, Outer WB, Inner Shareable (2) Inner/Outer Non- Cacheable (3) Device Type IO coherent DMA is as per (1) Inner/Outer WB, Inner Shareable.

| Test ID | APIs consumed                                                  | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------|-----------------------|-----------------------------|
| 414     | val_dma_get_info<br>val_dma_mem_alloc<br>val_dma_mem_get_attrs | 4.1.11                | Level 1+                    |

## 5.9.16 PCI Express transactions not marked as No\_snoop accessing memory that the PE translation tables attribute as cacheable and shared are I/O Coherent with the PEs.

| Test ID | APIs consumed                                                                        | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 415     | <pre>val_peripheral_get_info val_pcie_get_device_type val_pcie_get_dma_support</pre> | D.8                   | Level 1+                    |
|         | val_pcie_get_snoop_bit                                                               |                       |                             |

## 5.9.17 For Non-prefetchable (NP) memory, type-1 headers only support 32bit address, systems complaint with SBSA level 4 or above must support 32bit programming of NP BARs on such endpoints

| Test ID | APIs consumed                                                                    | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 416     | <pre>val_peripheral_get_info val_pcie_get_device_type val_pcie_io_read_cfg</pre> | D.2                   | Level 3+                    |
|         | val_pcie_scan_bridge_devices<br>_and_check_memtype                               |                       |                             |

#### 5.9.18 Root Port must implement minimal ACS features if P2P supported

| Test ID | APIs consumed                                                                                                     | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 417     | <pre>val_peripheral_get_info() val_pcie_get_pcie_type() val_pcie_p2p_support() val_pcie_read_ext_cap_word()</pre> | D.13                  | Level 3+                    |

#### 5.9.19 All switches must implement minimal ACS features if P2P supported

| Test ID | APIs consumed                                                                        | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 418     | <pre>val_peripheral_get_info() val_pcie_get_pcie_type() val_pcie_p2p_support()</pre> | D.13                  | Level 3+                    |
|         | val_pcie_read_ext_cap_word()                                                         |                       |                             |

## 5.9.20 Multifunction devices must implement minimal ACS features if P2P supported

| Test ID | APIs consumed                                                                                                             | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 419     | val_peripheral_get_info()                                                                                                 | D.13                  | Level 3+                    |
|         | <pre>val_pcie_get_pcie_type() val_pcie_multifunction_suppo rt() val_pcie_p2p_support() val_pcie_read_ext_cap_word()</pre> |                       |                             |

#### 5.9.21 Type 0/1 common config rules check

| Test ID | APIs consumed                                                                                                                                                   | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 420     | <pre>val_pcie_register_bitfields_ch eck(), val_pcie_disable_eru(bdf), val_pcie_device_port_type(bd f) val_pcie_bitfield_check(), val_pcie_find_capability</pre> | E.3/4                 | Level 3+                    |

#### **5.9.22 Type 0 config header rules check**

| Test ID | APIs consumed                                                                                                           | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 421     | <pre>val_pcie_register_bitfields_ch eck()</pre>                                                                         | E.3                   | Level 3+                    |
|         | <pre>val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> |                       |                             |

#### 5.9.23 Type 1 config header rules check

| Test ID | APIs consumed                                                                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 422     | <pre>val_pcie_register_bitfields_ch eck() val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> | E.3                   | Level 3+                    |

#### **5.9.24 PCIe capability rules check**

| Test ID | APIs consumed                                                                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 423     | <pre>val_pcie_register_bitfields_ch eck() val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> | E.15                  | Level 3+                    |

#### 5.9.25 Device capabilites register rules check

| Test ID | APIs consumed                                                                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 424     | <pre>val_pcie_register_bitfields_ch eck() val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> | E.14/15               | Level 3+                    |

#### **5.9.26 Device Control register rule check**

| Test ID | APIs consumed                                                                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 425     | <pre>val_pcie_register_bitfields_ch eck() val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> | E.14/15               | Level 3+                    |

#### 5.9.27 Device capabilities 2 register rules check

| Test ID | APIs consumed                                                                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 426     | <pre>val_pcie_register_bitfields_ch eck() val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> | E.14/15               | Level 3+                    |

#### 5.9.28 Device control 2 reg rules check

| Test ID | APIs consumed                                                                                                           | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 427     | <pre>val_pcie_register_bitfields_ch eck()</pre>                                                                         | E.14/15               | Level 3+                    |
|         | <pre>val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> |                       |                             |

#### 5.9.29 Power management capability rules check

| Test ID | APIs consumed                                                                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 428     | <pre>val_pcie_register_bitfields_ch eck() val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> | E.14/15               | Level 3+                    |

#### 5.9.30 Power management/status rule check

| Test ID | APIs consumed                                                                                                           | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 429     | <pre>val_pcie_register_bitfields_ch eck()</pre>                                                                         | E.14/15               | Level 3+                    |
|         | <pre>val_pcie_disable_eru(bdf) val_pcie_device_port_type(bd f) val_pcie_bitfield_check() val_pcie_find_capability</pre> |                       |                             |

#### 5.9.31 Check Command Register memory space enable functionality

| Test ID | APIs consumed                                                                                                                                                                                                                                                                                                                                            | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 430     | <pre>val_pe_update_elr() val_pcie_bdf_table_ptr() val_pcie_install_esr() val_pcie_function_header_typ e()  val_pcie_get_downstream_fu nction() val_pcie_get_mmio_bar() val_pcie_disable_eru() val_pcie_clear_urd() val_pcie_disable_msa() val_mmio_read() val_pcie_is_urd() val_pcie_enable_msa() val_pcie_enable_msa() val_pcie_find_capability()</pre> | E.3/4                 | Level 3+                    |

#### 5.9.32 Type0/1 BIST Reg verification rule

| Test ID | APIs consumed            | Specification section | Compliance level applicable |
|---------|--------------------------|-----------------------|-----------------------------|
| 431     | val_pcie_bdf_table_ptr() | E.3/4                 | Level 3+                    |

#### 5.9.33 Check HDR CapPtr Reg verification rule

| Test ID | APIs consumed            | Specification section | Compliance level applicable |
|---------|--------------------------|-----------------------|-----------------------------|
| 432     | val_pcie_bdf_table_ptr() | E.3/4                 | Level 3+                    |

#### 5.9.34 Max payload size supported check

| Test ID | APIs consumed                                                  | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------|-----------------------|-----------------------------|
| 433     | <pre>val_pcie_bdf_table_ptr() val_pcie_find_capability()</pre> | E.14/15               | Level 3+                    |

#### **5.9.35** BAR memory space and Type rule check

| Test ID | APIs consumed                                                                                                              | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 434     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type() val_pcie_is_onchip_peripheral() val_pcie_find_capability()</pre> | E.3                   | Level 3+                    |

#### 5.9.36 Function level reset rule check

| Test ID | APIs consumed                                                                                                                                                                                                                                              | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 435     | <pre>val_pe_get_index_mpid() val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_memory_alloc() val_pcie_get_bdf_config_addr() val_memcpy() val_time_delay_ms() val_memory_free() val_pcie_is_onchip_peripheral()</pre> | E.14/15               | Level 3+                    |

#### 5.9.37 Check ARI forwarding support rule

| Test ID | APIs consumed                                                                                                                 | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 436     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()</pre> | E.14/15               | Level 3+                    |

#### **5.9.38 Check OBFF supported rule**

| Test ID | APIs consumed                                                                                                                 | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 437     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()</pre> | E.14/15               | Level 3+                    |

#### 5.9.39 Check CTRS and CTDS rule

| Test ID | APIs consumed                                                                                                                                                                | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 438     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()val _pcie_get_rp_transaction_frwd_su pport(bdf)</pre> | E.15.11               | Level 3+                    |

#### 5.9.40 Check i-EP atomicop rule

| Test ID | APIs consumed                                                                                                                                                            | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 439     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_get_atomicop_requester _capable() val_pcie_is_onchip_peripheral()</pre> | E.15.11               | Level 3+                    |

#### 5.9.41 Check Root Port ATS and PRI rule

| Test ID | APIs consumed                                                                                                                 | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 440     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()</pre> | -                     | Level 3+                    |

#### 5.9.42 Check MSI and MSI-X support rule

| Test ID | APIs consumed                                                                                                                    | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 441     | <pre>val_pcie_bdf_table_ptr(), val_pcie_device_port_type(bdf), val_pcie_find_capability(), val_pcie_is_onchip_peripheral()</pre> | E.7                   | Level 3+                    |

#### **5.9.43 Check Power Management rules**

| Test ID | APIs consumed                                                                                                                 | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 442     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()</pre> | E.11                  | Level 3+                    |

#### 5.9.44 Check ARI forwarding enable rule

| Test ID | APIs consumed                                                                                                                 | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 443     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()</pre> | E.15.12               | Level 3+                    |

#### 5.9.45 Check device under RP in same ECAM

| Test ID | APIs consumed                                                                                                                                             | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 444     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_get_ecam_base(bdf) val_mmio_read() val_pcie_io_read_cfg() val_pcie_get_info()</pre> | D.1                   | Level 3+                    |

#### 5.9.46 Check all RP under a HB is in same ECAM

| Test ID | APIs consumed                                                                                                                                                                 | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 445     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_get_info() val_pcie_get_ecam_base(bdf) val_pcie_find_capability() val_pcie_is_onchip_peripheral()</pre> | D.1                   | Level 3+                    |

### 5.9.47 The Root port must comply with the byte enable rules and must support 1 byte, 2 byte and 4-byte Configuration read and write

| Test ID | APIs consumed                                                                                                                                                                                                              | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 446     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_get_info() val_pcie_get_ecam_base(bdf) val_mmio_read() val_mmio_read8() val_mmio_read16() val_mmio_write() val_mmio_write8() val_mmio_write8()</pre> | D.1                   | Level 3+                    |

## 5.9.48 Recognition and consumption configuration transactions intended for the Root Port Configuration space and read/write the appropriate Root Port Configuration register

| Test ID | APIs consumed                                                                                                                         | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 447     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_get_ecam_base(bdf) val_mmio_read() val_pcie_io_read_cfg()</pre> | D.1                   | L3+                         |

# 5.9.49 Recognition of transactions received on the primary side of the RP PCI-PCI bridge, targeting non-prefetchable memory spaces of devices and switches that are on the secondary side of the bridge: Where the address falls within the non-prefetchable memory window in the type 1 header registers, the transactions must be forwarded to the secondary side

|         |                                                                                                                                                                                       | •                     |                             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| Test ID | APIs consumed                                                                                                                                                                         | Specification section | Compliance level applicable |
| 448     | <pre>val_pcie_bdf_table_ptr() val_pe_install_esr() val_pcie_enable_bme(bdf) val_pcie_enable_msa(bdf) val_pcie_device_port_type(bdf) val_pcie_clear_urd(bdf) val_pcie_read_cfg()</pre> | D.1                   | L3+                         |

5.9.50 Recognition of transactions received on the primary side of the RP PCI-PCI bridge, targeting prefetchable memory spaces of devices and switches that are on the secondary side of the bridge: Where the address falls within the prefetchable memory window in the type 1 header registers, the transactions must be forwarded to the secondary side

| Test ID | APIs consumed                                                                                                                                                                         | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 449     | <pre>val_pcie_bdf_table_ptr() val_pe_install_esr() val_pcie_enable_bme(bdf) val_pcie_enable_msa(bdf) val_pcie_device_port_type(bdf) val_pcie_clear_urd(bdf) val_pcie_read_cfg()</pre> | D.1                   | L3+                         |

### 5.9.51 Each legacy interrupt SPI must be programmed as level-sensitive in the appropriate GIC\_ICFGR

| Test ID | APIs consumed                                                                                                                           | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 450     | <pre>val_memory_alloc() val_pcie_bdf_table_ptr() val_pcie_read_cfg() val_pci_get_legacy_irq_map() val_gic_get_intr_trigger_type()</pre> | D.6                   | L3+                         |

### 5.9.52 For i-EP, the Root port must provide the ability to do a hot reset of the Endpoint using the Secondary Bus Reset bit in bridge Control Register

| Test ID | APIs consumed                                                                                                                                                                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 451     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_memory_alloc() val_pcie_get_bdf_config_addr() val_memcpy() val_pcie_read_cfg() val_pcie_write_cfg() val_memory_free()</pre> | E.10                  | L3+                         |

### 5.9.53 PCIe ATS capability must be supported if the RCiEP or i-EP has a software visible cache for address translations

| Test ID | APIs consumed                                                                                                                                             | Specification section | Compliance level applicable |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 452     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_is_host_bridge(bdf) val_pcie_is_cache_present(bdf) val_pcie_find_capability()</pre> | E.9                   | L3+                         |

### 5.9.54 If the PCIe hierarchy allows peer-to-peer transactions, Root Port must support ACS capability

| Test ID | APIs consumed                                                                                                                            | Specification section | Compliance level applicable |
|---------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 453     | <pre>val_pcie_p2p_support() val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability() val_pcie_read_cfg()</pre> | D.11                  | L3+                         |

## 5.9.55 If the PCIe hierarchy allows peer-to-peer transactions, the root port must support ACS violation error detection, Logging and reporting must be through the usage of AER mechanism

| Test ID | APIs consumed                                                                                                        | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 454     | <pre>val_pcie_p2p_support() val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_find_capability()</pre> | D.11                  | L3+                         |

## 5.9.56 If the Root port supports peer-to-peer traffic with other root ports then - If the root port supports Address Translation services and peer-to-peer traffic with other root ports, then it must support ACS direct translated P2P

| Test ID | APIs consumed | Specification | Compliance level applicable |
|---------|---------------|---------------|-----------------------------|
|         |               | section       |                             |



## 5.9.57 If the i-EP endpoint is capable of sending transactions to a peer endpoint (RCiEP or i-EP endpoint or discrete), then the i-EP root port must have ACS capability

| Test ID | APIs consumed                                                                                                                                                                               | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 456     | <pre>val_pcie_p2p_support() val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_dev_p2p_support() val_pcie_get_rootport() val_pcie_find_capability() val_pcie_read_cfg()</pre> | E.12                  | L3+                         |

## 5.9.58 ACS capability must be present in the RCiEP or i-EP endpoint functions if the RCiEP or i-EP Endpoint ISA multi-function device and supports peer to peer traffic between its functions.

| Test ID | APIs consumed                                                                                                                                      | Specification section | Compliance level applicable |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 457     | <pre>val_pcie_bdf_table_ptr() val_pcie_device_port_type(bdf) val_pcie_multifunction_support() val_pcie_find_capability() val_pcie_read_cfg()</pre> | E.12                  | L3+                         |

#### 5.10 EL3 - Trusted firmware



Running the EL3-Firmware tests is not required for ServerReady certification.

## **5.10.1** Watchdog Signal 1 is available. This may be confirmed in the data base. This may not be possible to exercise as its handling is platform-specific

| Test ID | APIs consumed                                                                       | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 901     | <pre>val_wd_get_info val_wd_set_ws0 val_gic_install_isr val_secure_get_result</pre> | 4.2.4                 | Level 1+                    |
|         | val_gic_end_of_interrupt                                                            |                       |                             |

The Watchdog Signal 1 is routed as a SPI to GIC and usable as an EL3 interrupt, directly targeting a single PE

| Test ID | APIs consumed                                                                       | Specification section | Compliance level applicable |
|---------|-------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 901     | <pre>val_wd_get_info val_wd_set_ws0 val_gic_install_isr val_secure_get_result</pre> | 4.5.3                 | Level 3+                    |
|         | val_gic_end_of_interrupt                                                            |                       |                             |

#### 5.10.2 Must implement at least 56 bits

| Test ID | APIs consumed                                                                                     | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 902     | val_is_el3_enabled val_secure_call_smc val_secure_get_result val_pe_install_esr val_pe_update_elr | 4.1.5                 | Level 0+                    |

In systems that implement EL3, CNTControlBase should be mapped to Secure address space only.

| Test ID | APIs consumed                                                                                     | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 902     | val_is_el3_enabled val_secure_call_smc val_secure_get_result val_pe_install_esr val_pe_update_elr | 4.1.5                 | Level 0+                    |

The counter shall be sized and programmed to ensure that rollover never occurs in practice

| Test ID | APIs consumed                                                                                                | Specification section | Compliance level applicable |
|---------|--------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 902     | <pre>val_is_el3_enabled val_secure_call_smc val_secure_get_result val_pe_install_esr val_pe_update_elr</pre> | 4.2.3                 | Level 1+                    |

Generic Timer required registers are implemented as specified in section 4.2.3.1 "Summary of required registers of the CNTControlBase frame"

| Test ID | APIs consumed                                                                                     | Specification section | Compliance level applicable |
|---------|---------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|
| 902     | val_is_el3_enabled val_secure_call_smc val_secure_get_result val_pe_install_esr val_pe_update_elr | 4.2.3.1               | Level 1+                    |

## **5.10.3** The local PE timer when expiring must generate a PPI when EL3 physical timer expires

| Test ID | APIs consumed                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 903     | val_secure_call_smc<br>val_secure_get_result | 4.1.5                 | Level 0+                    |
|         | val_check_for_error                          |                       |                             |

The local PE timer when expiring must generate a PPI when EL3 physical timer expires, and PPI must be 29.

| Test ID | APIs consumed | Specification section | Compliance level applicable |
|---------|---------------|-----------------------|-----------------------------|

903 val\_secure\_call\_smc 4.3.2.1 Level 2+ val\_secure\_get\_result val\_check\_for\_error

## 5.10.4 Any local timers that are marked by PE as always ON must be able to wake up the system. This applies to expiry of all Secure views of the local timer (CNTPS)

| Test ID | APIs consumed                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 904     | val_secure_call_smc<br>val_secure_get_result | 4.1.7                 | Level 0+                    |
|         | val_check_for_error                          |                       |                             |

Secure Watchdog is implemented. Secure watchdog is not aliased in Non-secure address space. Signal 0 if Secure watchdog is routed as an SPI and usable as an interrupt to EL3, directly targeting a single PE

| Test ID | APIs consumed                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 904     | val_secure_call_smc<br>val_secure_get_result | 4.5.3                 | Level 3+                    |
|         | val_check_for_error                          |                       |                             |

## 5.10.5 Secure Generic UART is present. It is not aliased in Non-secure address space. The UARTINTR output of the Secure generic UART is connected to the GIC as an SPI

| Test ID | APIs consumed                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 905     | val_secure_call_smc<br>val_secure_get_result | 4.5.4                 | Level 3+                    |
|         | val_check_for_error                          |                       |                             |

### 5.10.6 A Secure system wakeup timer is present and the interrupt is presented to GIC as a SPI

| Test ID | APIs consumed                                | Specification section | Compliance level applicable |
|---------|----------------------------------------------|-----------------------|-----------------------------|
| 906     | val_secure_call_smc<br>val_secure_get_result | 4.5.2                 | Level 3+                    |
|         | val_check_for_error                          |                       |                             |

### **Appendix A Revisions**

This appendix describes the technical changes between released issues of this book.

#### Table-1 Issue 02

| Change      | Location | Affects |
|-------------|----------|---------|
| First issue | -        | -       |

#### Table-2 Differences between issue 02 and issue 03

| Change                    | Location  | Affects        | 1 |
|---------------------------|-----------|----------------|---|
| New PCIe tests are added. | See PCIE. | All revisions. | Ì |

#### Table-3 Differences between issue 03 and issue 04

| Change                                                                                                                                                       | Location                                                                   | Affects        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------|
| Added SBSA Level 6 PE and SMMU tests. Added new PCIe tests and Exerciser tests that are related to Address Translation Service, Peer-to-Peer, and ACS rules. | See Cross reference to architecture and tests and Test scenarios chapters. | All revisions. |