



# Arm® SBSA Architecture Compliance

Version 8.0.0

## Validation Methodology

### Non-Confidential

Copyright © 2016–2025 Arm Limited (or its affiliates).  
All rights reserved.

### Issue 01

101544\_0800\_01\_en

# Arm® SBSA Architecture Compliance Validation Methodology

This document is Non-Confidential.

Copyright © 2016–2025 Arm Limited (or its affiliates). All rights reserved.

This document is protected by copyright and other intellectual property rights.

Arm only permits use of this document if you have reviewed and accepted [Arm's Proprietary Notice](#) found at the end of this document.

This document (101544\_0800\_01\_en) was issued on 2025-12-10. There might be a later issue at <https://developer.arm.com/documentation/101544>

The product version is 8.0.0.

See also: [Proprietary Notice](#) | [Product and document information](#) | [Useful resources](#)

## Start reading

If you prefer, you can skip to [the start of the content](#).

## Intended audience

This book is written for engineers who are designing or verifying an implementation of the Arm® Server Base System Architecture.

## Inclusive language commitment

Arm values inclusive communities. Arm recognizes that we and our industry have used language that can be offensive. Arm strives to lead the industry and create change.

This document includes language that can be offensive. We will replace this language in a future issue of this document.

To report offensive language in this document, email [terms@arm.com](mailto:terms@arm.com).

## Feedback

Arm welcomes feedback on this product and its documentation. To provide feedback on the product, create a ticket on <https://support.developer.arm.com>.

To provide feedback on the document, fill the following survey: <https://developer.arm.com/documentation-feedback-survey>.

# Contents

|                                                                         |           |
|-------------------------------------------------------------------------|-----------|
| <b>1. About the Arm® SBSA ACS.....</b>                                  | <b>5</b>  |
| 1.1 Abbreviations.....                                                  | 5         |
| 1.2 Introduction to SBSA ACS.....                                       | 6         |
| 1.3 Compliance test suites.....                                         | 6         |
| 1.4 Layered software stack.....                                         | 7         |
| 1.4.1 ACS software stack with UEFI application.....                     | 8         |
| 1.4.2 ACS software stack with Linux application.....                    | 8         |
| 1.4.3 PMU event test suite.....                                         | 10        |
| 1.4.4 Coding guidelines.....                                            | 11        |
| 1.5 Exerciser.....                                                      | 11        |
| 1.5.1 ACS software stack for exerciser with UEFI shell application..... | 13        |
| 1.6 GIC ITS.....                                                        | 14        |
| 1.7 Test platform abstraction.....                                      | 16        |
| <b>2. Execution flow control.....</b>                                   | <b>18</b> |
| 2.1 Execution flow control.....                                         | 18        |
| 2.2 Test build and execution flow.....                                  | 18        |
| 2.2.1 Source code directory.....                                        | 19        |
| 2.2.2 Building the tests.....                                           | 20        |
| <b>3. Platform Abstraction Layer.....</b>                               | <b>21</b> |
| 3.1 Overview of PAL API.....                                            | 21        |
| 3.2 PAL API definitions.....                                            | 21        |
| 3.2.1 API naming convention.....                                        | 22        |
| 3.2.2 PE APIs.....                                                      | 22        |
| 3.2.3 GIC APIs.....                                                     | 24        |
| 3.2.4 PCIe APIs.....                                                    | 25        |
| 3.2.5 IO-Virt APIs.....                                                 | 30        |
| 3.2.6 SMMU APIs.....                                                    | 32        |
| 3.2.7 DMA APIs.....                                                     | 33        |
| 3.2.8 Exerciser APIs.....                                               | 36        |
| 3.2.9 Miscellaneous APIs.....                                           | 38        |
| 3.2.10 NIST API.....                                                    | 42        |

|                                              |           |
|----------------------------------------------|-----------|
| 3.2.11 PMU APIs.....                         | 42        |
| 3.2.12 RAS APIs.....                         | 43        |
| 3.2.13 MPAM APIs.....                        | 45        |
| <b>A. NIST Statistical Test Suite.....</b>   | <b>48</b> |
| A.1 NIST Statistical Test Suite.....         | 48        |
| <b>Proprietary Notice.....</b>               | <b>50</b> |
| <b>Product and document information.....</b> | <b>52</b> |
| Product status.....                          | 52        |
| Revision history.....                        | 52        |
| Conventions.....                             | 57        |
| <b>Useful resources.....</b>                 | <b>59</b> |

# 1. About the Arm® SBSA ACS

This chapter provides an introduction to the Arm® SBSA Architecture Compliance Suite.

## 1.1 Abbreviations

The following table lists the abbreviations used in this document.

**Table 1-1: Abbreviations and expansions**

| Abbreviation | Expansion                                          |
|--------------|----------------------------------------------------|
| ACPI         | Advanced Configuration and Power Interface         |
| ACS          | Architecture Compliance Suite                      |
| AEST         | Arm Error Source Table                             |
| BDF          | Bus, Device, and Function                          |
| ELx          | Exception Level x (where x can be 0 to 3)          |
| ETE          | Embedded Trace Extension                           |
| GCD          | Grand Central Dispatch                             |
| GIC          | Generic Interrupt Controller                       |
| HMAT         | Heterogenous Memory Attribute Table                |
| HVC          | HyperVisor Call                                    |
| ITS          | Interrupt Translation Service                      |
| IOMMU        | Input-Output Memory Management Unit                |
| LPI          | Locality-specific Peripheral Interrupt             |
| MPAM         | Memory System Resource Partitioning and Monitoring |
| MSI          | Message-Signaled Interrupt                         |
| PAL          | Platform Abstraction Layer                         |
| PMU          | Performance Monitoring Unit                        |
| PCIe         | Peripheral Component Interconnect Express          |
| PE           | Processing Element                                 |
| PPTT         | Processor Properties Topology Table                |
| PSCI         | Power State Coordination Interface                 |
| RAS          | Reliability, Availability, and Serviceability      |
| RCiEP        | Root Complex integrated End Point                  |
| SATA         | Serial Advanced Technology Attachment              |
| SBSA         | Server Base System Architecture                    |
| SMC          | Secure Monitor Call                                |
| SMMU         | System Memory Management Unit                      |
| SoC          | System on Chip                                     |
| SRAT         | System Resource Affinity Table                     |

| Abbreviation | Expansion                                       |
|--------------|-------------------------------------------------|
| STS          | Statistical Test Suite                          |
| UART         | Universal Asynchronous Receiver and Transmitter |
| UEFI         | Unified Extensible Firmware Interface           |
| VAL          | Validation Abstraction Layer                    |

## 1.2 Introduction to SBSA ACS

Server Base System Architecture (SBSA) specification specifies hardware system architecture which is based on Arm® 64-bit architecture that server system software such as operating systems, hypervisors, and firmware can rely on. It addresses PE features and key aspects of system architecture.

It ensures a standard system architecture to enable a suitably built single OS image to run on all hardware compliant with this specification. It also specifies features that firmware can rely on, allowing for some commonality in firmware implementation across platforms.

The SBSA architecture that is described in the *Arm® Server Base System Architecture Specification* defines the behavior of an abstract machine, referred to as an SBSA system. Implementations compliant with the SBSA architecture must conform to the behavior described in the specification.

The Architecture Compliance Suite (ACS) is a set of examples of the specified invariant behaviors. Use this suite to verify that these behaviors are implemented correctly in your system.

## 1.3 Compliance test suites

SYSARCH compliance test suites are self-checking, portable C-based tests with directed stimulus.

The following table describes the compliance test suites.

**Table 1-2: Test suites**

| Test suites | Description                                                                           |
|-------------|---------------------------------------------------------------------------------------|
| ETE         | Verifies PE Trace Compliance                                                          |
| Exerciser   | Verifies PCIe subsystem with a custom stimulus generator.                             |
| GIC         | Verifies GIC compliance.                                                              |
| Memory      | Verifies memory map compliance.                                                       |
| MPAM        | Verifies MPAM compliance.                                                             |
| NIST        | Verifies to determine the suitability of a generator for a cryptographic application. |
| PCIe        | Verifies PCIe subsystem compliance.                                                   |
| PE          | Verifies PE compliance.                                                               |
| Peripherals | Verifies USB, SATA, and UART compliance.                                              |
| PMU         | Verifies PMU compliance.                                                              |

| Test suites      | Description                                      |
|------------------|--------------------------------------------------|
| Power and Wakeup | Verifies system power states compliance.         |
| RAS              | Verifies RAS compliance.                         |
| SMMU             | Verifies SMMU subsystem compliance.              |
| Timer            | Verifies PE timers and system timers compliance. |
| Watchdog         | Verifies watchdog timer compliance.              |

## 1.4 Layered software stack

ACS uses the layered software stack approach to enable porting across different test platforms.

The layered stack contains:

- Test suites
- Validation Abstraction Layer (VAL)
- Platform Abstraction Layer (PAL)

**Figure 1-1: Layered software stack**



The following table describes the different layers of the ACS.

**Table 1-3: Compliance test layers**

| Layer            | Description                                                                                                                                                                                                                                                                                                                                                           |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SBSA test suites | Collection of targeted tests that validate the compliance of the target system. These tests use interfaces that are provided by the VAL.                                                                                                                                                                                                                              |
| VAL              | Provides a uniform view of all the underlying hardware and test infrastructure to the test suite.                                                                                                                                                                                                                                                                     |
| PAL              | Has C-based Arm-defined APIs that you can implement. It abstracts features whose implementation varies from one target system to another. Each test platform requires a PAL implementation of its own. PAL APIs are meant for the compliance test to reach or use other abstractions in the test platform such as the UEFI infrastructure and bare-metal abstraction. |

### 1.4.1 ACS software stack with UEFI application

The following figure is an example of the ACS software stack interplay with UEFI shell application.

**Figure 1-2: Software stack UEFI shell application**



### 1.4.2 ACS software stack with Linux application

The stack is spread across user mode and kernel mode space. The Linux command-line application running in the user mode space and the kernel module communicate using a `procfs` interface. The test pool, VAL, and PAL layers are built as a kernel module.

The following figure is an example of the ACS software stack with Linux application.

**Figure 1-3: Software stack with Linux application**



The SBSA command-line application initiates the tests and queries for status of the test using the standard `procfs` interface of the Linux OS. To avoid multiple data transfers between the kernel and user modes, the test suite, VAL, and PAL are built together as a kernel module.

Further, the PAL layer might need information from modules such as AHCI driver and the IOMMU driver which are outside the SBSA ACS kernel module. A separate patch file is provided to patch the drivers appropriately to export the required information. For details, see the *Arm® SBSA ACS User Guide*.

### 1.4.3 PMU event test suite

The PMU event test suite contains a Python script, Linux perf driver interface, and PySweep for workload generation. The following figure shows how the PMU event test suite Linux application is set up.

**Figure 1-4: PMU event test suite Linux application**



### Python script

Reads the event number and event details from input text file. Calls event generation functions and monitor events.

### PyPerf

Programs the PMU and monitor event count based on the event ID.

### PySweep

Generates workload.

1. Instruction-related event generation: `src/loadcode.c` (I-Cache, I-TLB, INST\_\*\*, OP\_\*\*)
2. Data-related event generation: `src/loaddata.c` (D-Cache, D-TLB)
3. Branching event generation: `src/branch_prediction.c`

## 1.4.4 Coding guidelines

The coding guidelines followed for the implementation of the test suite are described in this section.

- All the tests call VAL APIs.
- VAL APIs might call PAL APIs depending on the requested functionality.
- A test does not directly interface with PAL functions.
- The test layer does not need any code modifications when porting from one platform to another.
- All the platform porting changes are limited to PAL.
- The VAL may require changes if there are architectural changes impacting multiple platforms.

## 1.5 Exerciser

Exerciser is a PCIe endpoint device that can be programmed to generate custom stimuli for verifying the SBSA compliance of PCIe IP integration into an Arm SoC. The stimulus is used in verifying the compliance of PCIe functionality like IO coherency, snoop behavior, address translation, PASID transactions, DMA transactions, MSI, and legacy interrupt behavior.

The following figure shows a PCIe hierarchy consisting of various endpoints, switches, and bridges.

**Figure 1-5: Exerciser in an SoC**



Root Complex integrated EndPoint (RCiEP) and Root Complex Event Collector (RCEC) are endpoints connected directly to Root Complex. PCIe endpoints are connected either to the Root Port or downstream ports. Bridges are used to connect PCI devices into PCIe hierarchy while switches are used to connect multiple PCIe devices to a single downstream port. PCIe devices access GIC, memory, and PE through the Root Complex, also called the host bridge.

The figure shows two instances of the exerciser that are present in the system. Instance 1 is connected directly to the Root Complex as a RCiEP and instance 2 is connected to the downstream port of a switch as a PCIe endpoint device.



**Note** The number of exercisers instantiated is platform-specific. To achieve higher coverage, Arm recommends that you present multiple exercisers to the ACS.

To generate custom stimuli, the exerciser must provide functionality to configure interrupt and DMA attributes, trigger them, and know the status of these operations, the details of which are **IMPLEMENTATION DEFINED**. This can be done by providing a set of BAR-mapped registers and writing specific values to trigger the necessary operations.

The following figure shows the reference implementation of exerciser hardware.

**Figure 1-6: Reference implementation of exerciser hardware**



### 1.5.1 ACS software stack for exerciser with UEFI shell application

The exerciser tests validate device interrupts (legacy interrupt and MSI-X interrupt), DMA (address translation and memory access), and coherency behavior. The exerciser PCIe configuration space is accessed using UEFI or MMIO APIs and exerciser functionality like interrupt generation and DMA transactions can be accessed using exerciser APIs.

The following figure shows the compliance test software stack for exerciser with UEFI shell application.

**Figure 1-7: Exerciser with UEFI shell application**



## 1.6 GIC ITS

The Interrupt Translation Service (ITS) translates an input EventID from a device, identified by its DeviceID and determines:

- The corresponding INTID for the input.
- The target Redistributor and, through this, the target PE for the INTID.

Endpoint device 1 triggers a write on MSI address from the MSI table, which gets converted to a Locality-specific Peripheral Interrupt (LPI) using the ITS tables. To generate an MSI, ITS must be configured before running the ACS. The software must allocate memory for different ITS tables. ITS table mappings must be updated using the ITS commands, Device ID, LPI Interrupt ID, and Redistributor Base.

For more information on GIC ITS, see *Arm® GIC Architecture Specification* and *Arm® GICv3 Software Overview*.

The following figure shows how an MSI is converted to an LPI using ITS.

**Figure 1-8: Routing MSI-X from Endpoint to PE through GIC ITS**



## 1.7 Test platform abstraction

The ACS defines and uses the test platform abstraction that is illustrated in the figure below.

**Figure 1-9: Test platform abstraction**



The following table describes the SBSA abstraction terms.

**Table 1-4: Abstraction terms and descriptions**

| Abstraction      | Description                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| UEFI or OS       | UEFI Shell application or operating system provides infrastructure for console and memory management. This module runs at EL2.      |
| Trusted firmware | Firmware which runs at EL3.                                                                                                         |
| ACPI             | Interface layer which provides platform-specific information, removing the need for the test suite to be ported for every platform. |

| Abstraction | Description                                                              |
|-------------|--------------------------------------------------------------------------|
| Hardware    | PE and controllers that are specified as part of the SBSA specification. |

## 2. Execution flow control

This chapter describes the execution flow control used for SBSA ACS.

### 2.1 Execution flow control

The following figure describes the execution flow control of the ACS.

**Figure 2-1: Execution flow control**



The process that is followed for the flow control is:

1. The execution environment such as the UEFI shell, invokes the test entry point.
2. Start the test iteration loop.
3. Print status during the test execution as required.
4. Reboot or put the system to sleep as required.
5. Loop until all the tests are completed.

### 2.2 Test build and execution flow

This section describes the source code directory structure and provides references for building the tests.

## 2.2.1 Source code directory

The following figure shows the source code directory for the SYSARCH ACS.

**Figure 2-2: SYSARCH ACS directory structure**



The following describes all the directories in SBSA ACS.

### docs

Documentation.

Copyright © 2016–2025 Arm Limited (or its affiliates). All rights reserved.  
Non-Confidential

|                        |                                                                            |
|------------------------|----------------------------------------------------------------------------|
| <b>linux_app</b>       | Linux command-line executable source code.                                 |
| <b>baremetal_app</b>   | Reference bare-metal application source to call into the test entry point. |
| <b>prebuilt_images</b> | Contains prebuilt images for the releases.                                 |
| <b>patches</b>         | Contains the SBSA NIST Statistical Test Suite (STS) patch.                 |
| <b>test_pool</b>       | Test case source files for the test suite.                                 |
| <b>tools</b>           | Consists of scripts written for this suite.                                |
| <b>uefi_app</b>        | UEFI application source to call into the tests entry point.                |

## 2.2.2 Building the tests

This section provides reference information for building SYSARCH ACS as a UEFI Shell application and SBSA ACS kernel module.

### Test build for UEFI

The build steps for the compliance suite to be compiled as a UEFI shell application are available in the [README](#).

### Test build for OS-based tests

The build steps for the Linux application-driven compliance suite, and SBSA ACS kernel module, which has a dependency for the SBSA ACS Linux application, are available in the [README](#).

The build steps for the PMU events test, Linux application-driven compliance suite, and SBSA ACS kernel module, which has a dependency for the SBSA ACS Linux application, are available in the [README](#).

# 3. Platform Abstraction Layer

This chapter provides an overview of PAL API and its categories.

## 3.1 Overview of PAL API

The PAL is a C-based, Arm-defined API that you can implement.

Each test platform requires a PAL implementation of its own. The PAL APIs are meant for the compliance test to reach or use other abstractions in the test platform such as the UEFI infrastructure and Linux OS modules. PAL implementation can also be bare-metal code.

The reference PAL implementations are available in the following locations:

- [UEFI](#)
- [Linux](#)
- [Bare-metal](#)



The PAL bare-metal reference code provides a reference implementation for a subset of APIs. The current version of the repository contains the reference code for creation of information tables like PE, GIC, timer, and watchdog. Additional code must be implemented to match the target SoC implementation under test.

## 3.2 PAL API definitions

The PAL API contains APIs that:

- Are called by the VAL and implemented by the platform.
- Begin with the prefix `pal`.
- Have a second word on the API name that indicates the module which implements this API.
- Have the mapping of the module as per the table below.
- Create and fill structures needed as prerequisites for the test suite, named as `pal_<module>_create_info_table`.

### 3.2.1 API naming convention

The PAL API interface <module> names are mapped as shown in the following table.

**Table 3-1: Modules and corresponding API names**

| Module        | API name         |
|---------------|------------------|
| PE            | pe               |
| GIC           | gic              |
| Timer         | timer            |
| Watchdog      | wd               |
| PCIE          | pcie             |
| IOVirt        | iovirt           |
| SMMU          | smmu             |
| Peripheral    | per              |
| DMA           | dma              |
| Memory        | memory           |
| Exerciser     | exerciser        |
| ETE           | ete              |
| Miscellaneous | print, mem, mmio |
| NIST          | nist             |
| MPAM          | mpam             |
| RAS           | ras              |
| PMU           | pmu              |

### 3.2.2 PE APIs

These APIs provide the information and functionality required by the test suite that accesses features of a PE.

**Table 3-2: PE APIs and their descriptions**

| API name          | Function prototype                                                           | Description                                                                                                                           |
|-------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| get_num           | <code>uint32_t pal_pe_get_num();</code>                                      | Returns the number of PEs in the system.                                                                                              |
| create_info_table | <code>void pal_pe_create_info_table(PE_INFO_TABLE *PeTable);</code>          | Gathers information about the PEs in the system and fills the info_table with the relevant data.                                      |
| call_smc          | <code>void pal_pe_call_smc(ARM_SMC_ARGS *args);</code>                       | Abstracts the smc instruction. The input arguments to this function are x0 to x7 registers filled in with the appropriate parameters. |
| execute_payload   | <code>void pal_pe_call_smc(ARM_SMC_ARGS *ArmSmcArgs, int32_t Conduit)</code> | Abstracts the PE wakeup and execute functionality. Ideally, this function calls the PSCI_ON SMC command.                              |

| API name             | Function prototype                                                                   | Description                                                                                                                                                                                                                                                                                                                             |
|----------------------|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| update_elr           | void pal_pe_update_elr(void *context, uint64_t offset);                              | Updates the ELR to return from exception handler to a required address.                                                                                                                                                                                                                                                                 |
| get_esr              | uint64_t pal_pe_get_esr(void *context);                                              | Returns the exception syndrome from exception handler.                                                                                                                                                                                                                                                                                  |
| data_cache_ops_by_va | void pal_pe_data_cache_ops_by_va(uint64_t addr, uint32_t type);                      | Performs cache maintenance operation on an address.                                                                                                                                                                                                                                                                                     |
| get_far              | uint64_t pal_pe_get_far(void *context);                                              | Returns the FAR from exception handler.                                                                                                                                                                                                                                                                                                 |
| install_esr          | uint32_t pal_pe_install_esr(uint32_t exception_type, void (*esr)(uint64_t, void *)); | Abtracts the exception handler installation steps. The input arguments are exception type and function pointer of the handler that has to be called when the exception of the given type occurs. It returns zero on success and non-zero on failure.                                                                                    |
| psci_get_conduit     | uint32_t pal_psci_get_conduit(void)                                                  | Checks whether PSCI is implemented. If yes, which conduit does it use (HVC or SMC).<br>Returns: <ul style="list-style-type: none"><li>• CONDUIT_NONE: PSCI is not implemented</li><li>• CONDUIT_SMC: PSCI is implemented and uses SMC as the conduit.</li><li>• CONDUIT_HVC: PSCI is implemented and uses HVC as the conduit.</li></ul> |

Each PE information entry structure can hold information for a PE in the system.  
The types of information are:



```
typedef struct {
    uint32_t    pe_num;                                /* PE Index */
    uint32_t    attr;                                 /* PE attributes */
    uint64_t    mpidr;                               /* PE MPIDR */
    uint32_t    pmu_gsiv;                            /* PMU Interrupt */
    uint32_t    gmain_gsiv;                           /* GIC Maintenance
    Interrupt */
    uint32_t    acpi_proc_uid;                         /* ACPI Processor UID */
    uint32_t    level_1_res[MAX_L1_CACHE_RES];        /* index of level 1
    cache(s) in cache_info_table */7
    uint32_t    trbe_interrupt;                        /* TRBE Interrupt */
}PE_INFO_ENTRY;
```

### 3.2.3 GIC APIs

These APIs provide the information and functionality required by the test suite that accesses features of a GIC.

**Table 3-3: GIC APIs and their descriptions**

| API name            | Function prototype                                                                          | Description                                                                                                                                                                                        |
|---------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_info_table   | void pal_gic_create_info_table(GIC_INFO_TABLE *gic_info_table);                             | Gathers information about the GIC sub-system and fills the gic_info_table with the relevant data.                                                                                                  |
| install_isr         | uint32_t pal_gic_install_isr(uint32_t int_id, void (*isr)(void));                           | Abstracts the steps required to register an interrupt handler to an IRQ number. It also enables the interrupt in the GIC CPU interface and Distributor. It returns 0 on success and -1 on failure. |
| end_of_interrupt    | uint32_t pal_gic_end_of_interrupt(uint32_t int_id);                                         | Indicates completion of interrupt processing by writing to the end of interrupt register in the GIC CPU interface. It returns 0 on success and -1 on failure.                                      |
| request_irq         | uint32_t pal_gic_request_irq(unsigned int irq_num, unsigned int mapped_irq_num, void *isr); | Registers the interrupt handler for a given IRQ.<br><br>irq_num: hardware IRQ number<br><br>mapped_irq_num: mapped IRQ number<br><br>isr: Interrupt Service Routine that returns the status        |
| free_irq            | void pal_gic_free_irq(unsigned int irq_num, unsigned int mapped_irq_num);                   | Frees the registered interrupt handler for a given IRQ.<br><br>irq_num: hardware IRQ number<br><br>mapped_irq_num: mapped IRQ number                                                               |
| set_intr_trigger    | uint32_t pal_gic_set_intr_trigger(uint32_t int_id, INTR_TRIGGER_INFO_TYPE_e trigger_type);  | Sets the trigger type to edge or level.<br><br>int_id: interrupt ID which must be enabled and the service routine installed for<br><br>trigger_type: interrupt trigger type edge or level          |
| get_num_nongic_ctrl | uint32_t pal_get_num_nongic_ctrl(void);                                                     | Returns the count of Non GIC Interrupt Controller.                                                                                                                                                 |

- Each GIC information entry structure can hold information for any of the seven types of GIC components. The seven types of entries are:

```
typedef enum {
    ENTRY_TYPE_CPUIF = 0x1000,
    ENTRY_TYPE_GICD,
    ENTRY_TYPE_GICC_GICRD,
    ENTRY_TYPE_GICR_GICRD,
    ENTRY_TYPE_GICITS,
    ENTRY_TYPE_GIC_MSI_FRAME,
    ENTRY_TYPE_GICH
} GIC_INFO_TYPE_e;
```



- In addition to the type, each entry contains the base address of each type, entry\_id for entry type ITS, and length in case of Redistributor range address length.

```
typedef struct {
```

```

    uint32_t type;
    uint64_t base;
    uint32_t entry_id;
    uint64_t length;
    uint32_t flags;
    uint32_t spi_count;
    uint32_t spi_base;
}GIC_INFO_ENTRY;

```

### 3.2.4 PCIe APIs

These APIs provide the information and functionality required by the test suite that accesses features of PCIe subsystem.

**Table 3-4: PCIe APIs and their descriptions**

| API name          | Function prototype                                                            | Description                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_info_table | void pal_pcie_create_info_table(PCIE_INFO_TABLE *PcieTable);                  | Abstracts the steps to gather PCIe information in the system and fills the PCIe info_table. Ideally, this function reads the ACPI MCFG table to retrieve the ECAM base address.                                                                                                                                                                                                                       |
| enumerate         | void pal_pcie_enumerate(void);                                                | Performs the PCIe enumeration.                                                                                                                                                                                                                                                                                                                                                                        |
| io_read_cfg       | uint32_t pal_pcie_io_read_cfg(uint32_t bdf, uint32_t offset, uint32_t *data); | Abstracts the configuration space read of a device identified by Bus, Device, and Function (BDF). This is used only in peripheral tests and need not be implemented in Linux. It returns either success or failure.<br><br>bdf: PCI Bus, Dev, and Func<br><br>offset: Offset in the configuration space from where data is to be read<br><br>data: Stores the value read from the configuration space |
| io_write_cfg      | void pal_pcie_io_write_cfg(uint32_t bdf, uint32_t offset, uint32_t data);     | Abstracts the configuration space write of a device identified by BDF (Bus, Device, and Function). Writes 32-bit data to the configuration space of the device at an offset.<br><br>bdf: PCI Bus, Dev, and Func<br><br>offset: Offset in the configuration space from where data is to be read<br><br>data: Stores the value read from the configuration space                                        |

| API name        | Function prototype                                                                                                                  | Description                                                                                                                                                                                                                                                                                                    |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| get_mcfg_ecam   | <code>uint64_t pal_pcie_get_mcfg_ecam(uint32_t bdf);</code>                                                                         | Returns the PCI ECAM address from the ACPI MCFG table address.<br><br><code>bdf</code> : PCI Bus, Dev, and Func                                                                                                                                                                                                |
| get_msi_vectors | <code>uint32_t pal_get_msi_vectors(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn, PERIPHERAL_VECTOR_LIST **mvector);</code> | Creates a list of MSI(X) vectors for a device. It returns the number of MSI(X) vectors.<br><br><code>seg</code> : PCI segment number<br><code>bus</code> : PCI bus number<br><code>dev</code> : PCI device number<br><code>fn</code> : PCI function number<br><code>mvector</code> : Pointer to MSI(X) address |
| get_PCIE_type   | <code>uint32_t pal_pcie_get_PCIE_type(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</code>                                | Gets the PCIe device or port type.<br><br><code>seg</code> : PCI segment number<br><code>bus</code> : PCI bus number<br><code>dev</code> : PCI device number<br><code>fn</code> : PCI function number                                                                                                          |
| p2p_support     | <code>uint32_t pal_pcie_p2p_support();</code>                                                                                       | Checks P2P support in the PCIe hierarchy.<br><br>Returns 1 if P2P feature is not supported and 0 if it is supported.                                                                                                                                                                                           |
| dev_p2p_support | <code>uint32_t pal_pcie_dev_p2p_support(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</code>                              | Checks the PCIe device P2P support.<br><br><code>seg</code> : PCI segment number<br><code>bus</code> : PCI bus number<br><code>dev</code> : PCI device number<br><code>fn</code> : PCI function number<br><br>Returns 1 if P2P feature is not supported, else 0.                                               |

| API name                        | Function prototype                                                                                                    | Description                                                                                                                                                                                                                                                                                                        |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| is_cache_present                | <code>uint32_t pal_pcie_is_cache_present(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</code>               | <p>Checks whether the PCIe device has an Address Translation Cache (ATC).</p> <p><code>seg</code>: PCI segment number</p> <p><code>bus</code>: PCI bus number</p> <p><code>dev</code>: PCI device number</p> <p><code>fn</code>: PCI function number</p> <p>Returns 0 if the device does not have ATC, else 1.</p> |
| is_onchip_peripheral            | <code>uint32_t pal_pcie_is_onchip_peripheral(uint32_t bdf);</code>                                                    | <p>Checks if a PCIe function is an on-chip peripheral.</p> <p><code>bdf</code>: Segment, PCI Bus, Device, and Function.</p> <p>Returns 1 if the PCIe function is an on-chip peripheral, else 0.</p>                                                                                                                |
| check_device_list               | <code>uint32_t pal_pcie_check_device_list(void);</code>                                                               | <p>Checks if the PCIe hierarchy matches with the topology described in the information table.</p> <p>Returns 0 if device entries match, else 1.</p>                                                                                                                                                                |
| check_device_valid              | <code>uint32_t pal_pcie_check_device_valid(uint32_t bdf);</code>                                                      | <p>This API is used as a placeholder to check if the bdf obtained is valid or not.</p> <p><code>bdf</code>: PCI Seg, bus, device, and function</p>                                                                                                                                                                 |
| get_rp_transaction_frwd_support | <code>uint32_t pal_pcie_get_rp_transaction_frwd_support(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn)</code> | <p>Gets Root Port (RP) transaction forwarding support.</p> <p><code>seg</code>: PCI segment number</p> <p><code>bus</code>: PCI bus number</p> <p><code>dev</code>: PCI device number</p> <p><code>fn</code>: PCI function number</p> <p>Returns 0 if RP is not involved in transaction forwarding, else 1.</p>    |

| API name          | Function prototype                                                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| read_ext_cap_word | <pre>void pal_pcie_read_ext_cap_word(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn, uint32_t ext_cap_id, uint8_t offset, uint16_t *val);</pre> | <p>Reads the extended PCIe configuration space at an offset for a capability.</p> <p><b>seg:</b> PCI segment number</p> <p><b>bus:</b> PCI bus number</p> <p><b>dev:</b> PCI device number</p> <p><b>fn:</b> PCI function number</p> <p><b>ext_cap_id:</b> PCI capability ID</p> <p><b>offset:</b> offset of the word in the capability configuration space</p> <p><b>val:</b> return value</p>                                                                                |
| get_bdf_wrapper   | <pre>uint32_t pal_pcie_get_bdf_wrapper (uint32_t ClassCode, uint32_t StartBdf);</pre>                                                                  | <p>Returns the Bus, Device, and Function for a matching class code.</p> <p><b>ClassCode:</b> 32-bit value of format <code>ClassCode &lt;&lt; 16   sub_class_code</code></p> <p><b>StartBdf:</b></p> <ul style="list-style-type: none"> <li>0: start enumeration from host bridge.</li> <li>1: start enumeration from the input segment, Bus, Device.</li> </ul> <p>This is needed since multiple controllers with the same class code are potentially present in a system.</p> |
| bdf_to_dev        | <pre>void *pal_pci_bdf_to_dev(uint32_t bdf);</pre>                                                                                                     | <p>Returns the PCI device structure for the given bdf.</p> <p><b>bdf:</b> PCI Bus, Device, and Function.</p>                                                                                                                                                                                                                                                                                                                                                                   |
| read_config_byte  | <pre>void pal_pci_read_config_byte(uint32_t bdf, uint8_t offset, uint8_t *val);</pre>                                                                  | <p>Reads one byte from the PCI configuration space for the current BDF at given offset.</p> <p><b>bdf:</b> PCI Bus, Device, and Function</p> <p><b>offset:</b> offset in the PCI configuration space for that BDF</p> <p><b>val:</b> return value</p>                                                                                                                                                                                                                          |

| API name              | Function prototype                                                                             | Description                                                                                                                                                                                                                                                                                 |
|-----------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| write_config_byte     | void pal_pci_write_config_byte(uint32_t bdf, uint8_t offset, uint8_t val);                     | <p>Writes one byte from the PCI configuration space for the current BDF at a given offset.</p> <p>bdf: PCI Bus, Device, and Function</p> <p>offset: offset in the PCI configuration space for that BDF</p> <p>val: return value</p>                                                         |
| mem_get_offset        | uint32_t pal_pcie_mem_get_offset(uint32_t bdf, PCIE_MEM_TYPE_INFO_e mem_type);                 | <p>Returns the memory offset that can be accessed safely. This offset is platform-specific. It needs to be modified according to the requirement.</p> <p>bdf: BUS/Device/Function</p> <p>mem_type : If the memory is Prefetchable or Non-prefetchable memory.<br/>Return memory offset.</p> |
| device_driver_present | uint32_t pal_pcie_device_driver_present(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn) | <p>Returns if driver present for PCIe device.</p> <p>seg: PCI segment number</p> <p>bus: PCI bus number</p> <p>dev: PCI device number</p> <p>fn: PCI function number</p> <p>Returns 0 if Driver present else 1</p>                                                                          |
| ecam_base             | uint64_t pal_pcie_ecam_base(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t func)           | <p>Returns the ECAM address of the input PCIe device.</p> <p>seg: PCI segment number</p> <p>bus: PCI bus number</p> <p>dev: PCI device number</p> <p>fn: PCI function number</p> <p>Returns ECAM address if success, else NULL address</p>                                                  |

| API name      | Function prototype                                                             | Description                                                                                                                                                                                                        |
|---------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bar_mem_read  | uint32_t pal_pcie_bar_mem_read(uint32_t Bdf, uint64_t address, uint32_t *data) | Reads 32-bit data from BAR space pointed by Bus, Device, Function and register offset.<br><br>Bdf: BDF value for the device.<br><br>address: BAR memory address.<br><br>data: 32 bit value at BAR address.         |
| bar_mem_write | uint32_t pal_pcie_bar_mem_write(uint32_t Bdf, uint64_t address, uint32_t data) | Writes 32-bit data to BAR space pointed by Bus, Device, Function and register offset.<br><br>Bdf: BDF value for the device.<br><br>address: BAR memory address.<br><br>data: 32 bit value to write to BAR address. |

This data structure holds the PCIe subsystem information.



```
/**
@brief PCI Express Info Table
*/
typedef struct {
    addr_t ecam_base;      ///< ECAM Base address
    uint32_t segment_num;  ///< Segment number of this ECAM
    uint32_t start_bus_num; //< Start Bus number for this ecam space
    uint32_t end_bus_num;  //< Last Bus number
} PCIE_INFO_BLOCK;
```

The data structure is repeated for the number of ECAM ranges in the system.

```
typedef struct {
    uint32_t num_entries;
    PCIE_INFO_BLOCK block[];
} PCIE_INFO_TABLE;
```

### 3.2.5 IO-Virt APIs

These APIs provide the information and functionality required by the test suite that accesses features of IO virtualization system.

**Table 3-5: IO-Virt APIs and their descriptions**

| API name          | Function prototype                                             | Description                                                                                                      |
|-------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| create_info_table | void pal_iovirt_create_info_table( IOVIRT_INFO_TABLE *iovirt); | Abstracts the steps to fill in the iovirt table with the details of the Virtualization sub-system in the system. |

| API name               | Function prototype                                                                                   | Description                                                                                                                                                                                                             |
|------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| unique_rid_strid_map   | uint32_t pal_iovирт_unique_rid_strid_map(uint64_t rc_block);                                         | Abstracts the mechanism to check if a Root Complex node has unique requestor ID to Stream ID mapping.<br><br>0 indicates a fail since the mapping is not unique.<br><br>1 indicates a pass since the mapping is unique. |
| check_unique_ctx_initd | uint32_t pal_iovирт_check_unique_ctx_initd(uint64_t smmu_block);                                     | Abstracts the mechanism to check if a given SMMU node has unique context bank interrupt IDs.<br><br>0 indicates fail and 1 indicates pass.                                                                              |
| get_rc_smmu_base       | uint64_t pal_iovирт_get_rc_smmu_base( IOVIRT_INFO_TABLE *iovирт, uint32_t rc_seg_num, uint32_t rid); | Returns the base address of SMMU if a Root Complex is behind an SMMU, otherwise returns NULL.                                                                                                                           |

The following data structure is filled in by the above function. This data structure captures all the information related to SMMUs, PCIe root complex, GIC-ITS and any other named components involved in the Virtualization sub-system of the SoC.

The information captured includes interrupt routing tables, memory maps, and the base addresses of the various components.



Note

```

typedef struct {
    uint32_t arch_major_rev; /* Version 1 or 2 or 3 */
    uint64_t base;           /* SMMU Controller base address */
} SMMU_INFO_BLOCK;

typedef struct {
    uint32_t segment;
    uint32_t ats_attr;
    uint32_t cca;           /* Cache Coherency Attribute */
    uint64_t smmu_base;
} IOVIRT_RC_INFO_BLOCK;

typedef struct {
    uint64_t base;
    uint32_t overflow_gsiv;
    uint32_t node_ref; /* offset to the IORT node in IORT ACPI table*/
    uint64_t smmu_base; /* SMMU base to which component is attached, else
                         NULL */
} IOVIRT_PMCG_INFO_BLOCK;

typedef struct {
    uint64_t smmu_base;      /* SMMU base to which
                           component is attached, else NULL */
    uint32_t cca;            /* Cache Coherency Attribute */
    char name[MAX_NAMED_COMP_LENGTH]; /* Device object name */
} IOVIRT_NAMED_COMP_INFO_BLOCK;

typedef struct {
    uint32_t input_base;
    uint32_t id_count;
    uint32_t output_base;
    uint32_t output_ref; /* output ref captured here is offset to
                          iovирт block in
                          IOVIRT_NAMED_COMP_INFO_BLOCK */
} IOVIRT_NAMED_COMP_OUTPUT_BLOCK;

```

```
IOVIRT info table not IORT ACPI table in
memory */
} ID_MAP;

typedef union {
    uint32_t id[4];
    ID_MAP map;
} NODE_DATA_MAP;

typedef union {
    IOVIRT_NAMED_COMP_INFO_BLOCK named_comp;
    IOVIRT_RC_INFO_BLOCK rc;
    IOVIRT_PMC_G_INFO_BLOCK pmcg;
    uint32_t its_count;
    SMMU_INFO_BLOCK smmu;
} NODE_DATA;

typedef struct {
    uint32_t type;
    uint32_t num_data_map;
    NODE_DATA data;
    uint32_t flags;
    NODE_DATA_MAP data_map[];
} IOVIRT_BLOCK;

typedef struct {
    uint32_t num_blocks;
    uint32_t num_smmus;
    uint32_t num_pci_rcs;
    uint32_t num_named_components;
    uint32_t num_its_groups;
    uint32_t num_pmcgs;
    IOVIRT_BLOCK blocks[];
} IOVIRT_INFO_TABLE;
```

### 3.2.6 SMMU APIs

These functions abstract information that is specific to the operations of the SMMUs in the system.

**Table 3-6: SMMU APIs and their descriptions**

| API name                  | Function prototype                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_info_table         | void pal_smmu_create_info_table(SMMU_INFO_TABLE *smmu_info_table);  | Abstracts the steps to gather information about SMMUs in the system and fills the info_table.                                                                                                                                                                                                                                                                                                                     |
| check_device_iova         | uint32_t pal_smmu_check_device_iova(void *port, uint64_t dma_addr); | Checks if the input DMA address belongs to the input device. This can be done by keeping track of the DMA addresses generated by the device using the start and stop monitor calls defined below or by reading the IOVA table of the device and looking for the input address.<br><br>0 is returned if address belongs to the device. Non-zero is returned if there are <b>ARCHITECTURE DEFINED</b> error values. |
| device_start_monitor_iova | void pal_smmu_device_start_monitor_iova(void *port);                | A hook to start the process of saving DMA addresses being used by the input device. It is used by the test to indicate the upcoming DMA transfers to be recorded and the test queries for the address through the check_device_iova call.                                                                                                                                                                         |

| API name                 | Function prototype                                                        | Description                                                                                                                                                                                                                             |
|--------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| device_stop_monitor_iova | void pal_smmu_device_stop_monitor_iova(void *port);                       | Stops the recording of the DMA addresses being used by the input port.                                                                                                                                                                  |
| pa2iova                  | uint64_t pal_smmu_pa2iova(uint64_t SmmuBase, uint64_t Pa);                | Converts physical address to I/O virtual address.<br><br>SmmuBase: physical address of the SMMU for conversion to virtual address.<br><br>Pa: physical address to use in conversion.<br><br>Returns 0 on success and 1 on failure.      |
| smmu_disable             | uint32_t pal_smmu_disable(uint64_t SmmuBase);                             | Globally disables the SMMU based on input base address.<br><br>SmmuBase: physical address of the SMMU that needs to be globally disabled.<br><br>Returns 0 for success and 1 for failure.                                               |
| create_pasid_entry       | uint32_t pal_smmu_create_pasid_entry(uint64_t smmu_base, uint32_t pasid); | Prepares the SMMU page tables to support input PASID.<br><br>smmu_base: physical address of the SMMU for which PASID support is needed.<br><br>pasid: Process Address Space IDentifier.<br><br>Returns 0 for success and 1 for failure. |

### 3.2.7 DMA APIs

These functions abstract information that is specific to DMA operations in the system.

**Table 3-7: DMA APIs and their descriptions**

| API name          | Function prototype                                                                                | Description                                                                                                                                                                                                                                                                                                                                 |
|-------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_info_table | void pal_dma_create_info_table(DMA_INFO_TABLE *dma_info_table);                                   | Abstracts the steps to gather information on all the DMA-enabled controllers present in the system and fill the information in the dma_info_table.                                                                                                                                                                                          |
| start_from_device | uint32_t pal_dma_start_from_device(void *dma_target_buf, uint32_t length, void *host, void *dev); | Abstracts the functionality of performing a DMA operation from the device to DDR memory.<br><br>dma_target_buf is the target physical address in the memory where the DMA data is to be written.<br><br>0: success.<br><br><b>IMPLEMENTATION DEFINED:</b> on error, the status is a non-zero value which is <b>IMPLEMENTATION DEFINED</b> . |

| API name          | Function prototype                                                                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| start_to_device   | uint32_t pal_dma_start_to_device(void *dma_source_buf, uint32_t length, void *host, void *target, uint32_t timeout); | Abstracts the functionality of performing a DMA operation to the device from DDR memory.<br><br>dma_source_buf: physical address in the memory where the DMA data is read from and has to be written to the device.<br><br>0: success<br><br><b>IMPLEMENTATION DEFINED:</b> on error, the status is a non-zero value which is <b>IMPLEMENTATION DEFINED</b> .                                                                                                 |
| mem_alloc         | uint64_t pal_dma_mem_alloc(void **buffer, uint32_t length, void *dev, uint32_t flags);                               | Allocates contiguous memory for DMA operations.<br><br>Supported values for flags are:<br><br>1: DMA_COHERENT<br><br>2: DMA_NOT_COHERENT<br><br>dev is a void pointer which can be used by the PAL layer to get the context of the request. This is same value that is returned by PAL during info table creation.<br><br>0: success.<br><br><b>IMPLEMENTATION DEFINED:</b> on error, the status is a non-zero value which is <b>IMPLEMENTATION DEFINED</b> . |
| scsi_get_dma_addr | void pal_dma_scsi_get_dma_addr(void *port, void *dma_addr, uint32_t *dma_len);                                       | This is a hook provided to extract the physical DMA address used by the DMA Requester for the last transaction. It is used by the test to verify if the address used by the DMA Requester was the same as the one allocated by the test.                                                                                                                                                                                                                      |
| mem_get attrs     | int pal_dma_mem_get attrs(void *buf, uint32_t *attr, uint32_t *sh)                                                   | Returns the memory and Shareability attributes of the input address. The attributes are returned as per the MAIR definition in the Arm® ARM VMSA section.<br><br>0: success.<br><br>Non-zero: error, ignore the attribute and Shareability parameters.                                                                                                                                                                                                        |
| dma_mem_free      | void pal_dma_mem_free(void *buffer, addr_t mem_dma, unsigned int length, void *port, unsigned int flags);            | Free the memory allocated by pal_dma_mem_alloc.<br>buffer: memory mapped to the DMA that is to be freed<br><br>mem_dma: DMA address with respect to device<br><br>length: size of the memory<br><br>port: ATA port structure<br><br>flags: Value can be DMA_COHERENT or DMA_NOT_COHERENT                                                                                                                                                                      |



This data structure captures the information about SATA or USB controllers which are DMA-enabled.

```
typedef struct {
```

```
uint32_t num_dma_ctrls;
DMA_INFO_BLOCK info[]; ///< Array of information blocks - per DMA
controller
}DMA_INFO_TABLE;
```

This includes pointers to information such as port information and targets connected to the port. The present structures are defined only for SATA and USB. If other peripherals are to be supported, these structures must be enhanced.

```
/***
@bref DMA controllers info structure
*/
typedef enum {
DMA_TYPE_USB = 0x2000,
DMA_TYPE_SATA,
DMA_TYPE_OTHER,
}DMA_INFO_TYPE_e;

typedef struct {
DMA_INFO_TYPE_e type;
void *target; ///< The actual info stored in these pointers is
implementation specific.
void *port;
void *host; ///< It will be used only by PAL. hence void.
uint32_t flags;
}DMA_INFO_BLOCK;
```

### 3.2.8 Exerciser APIs

These APIs abstract information specific to the operations of PCIe stimulus generation hardware.

**Table 3-8: Exerciser APIs and descriptions**

| API Name  | Function prototype                                                                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| set_param | <pre>uint32_t pal_exerciser_set_ param(EXERCISER_PARAM_TYPE type, uint64_t value1, uint64_ t value2, uint32_t instance)</pre>   | <p>Writes the configuration parameters to the PCIe stimulus generation hardware indicated by the instance number. The supported configuration parameters include:</p> <ul style="list-style-type: none"> <li>1 – SNOOP_ATTRIBUTES</li> <li>2 – LEGACY_IRQ</li> <li>3 – DMA_ATTRIBUTES</li> <li>4 – P2P_ATTRIBUTES</li> <li>5 – PASID_ATTRIBUTES</li> <li>6 – MSIX_ATTRIBUTES</li> <li>7 – CFG_TXN_ATTRIBUTES</li> <li>8 – ERROR_INJECT_TYPE</li> <li>9 – ENABLE_POISON_MODE</li> <li>10 – ENABLE_RAS_CTRL</li> <li>11 – DISABLE_POISON_MODE</li> </ul> <p>value2 is an optional argument and must be ignored for some configuration parameters.</p> |
| get_param | <pre>uint32_t pal_exerciser_ get_param(EXERCISER_PARAM_ TYPE type, uint64_t *value1, uint64_t *value2, uint32_t instance)</pre> | Returns the requested configuration parameter values through 64-bit input arguments value1 and value2. The function returns a value of 1 to indicate read success and 0 to indicate read failure.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| set_state | <pre>uint32_t pal_exerciser_set_ state(EXERCISER_STATE state, uint64_t *value, uint32_t instance)</pre>                         | <p>Sets the state of the PCIe stimulus generation hardware. The supported states include:</p> <ul style="list-style-type: none"> <li>1 – RESET, hardware in reset state.</li> <li>2 – ON, this state is set after hardware is initialized and is ready to generate stimulus.</li> <li>3 – OFF, this state is set to indicate that hardware can no longer generate stimulus.</li> <li>4 – ERROR, this state is set to signal an error with hardware.</li> </ul>                                                                                                                                                                                      |

| API Name               | Function prototype                                                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------|------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| get_state              | uint32_t pal_exerciser_get_state(EXERCISER_STATE state, uint64_t *value, uint32_t instance)          | Returns the state of the PCIe stimulus generation hardware of the requested instance.                                                                                                                                                                                                                                                                                                                                                                      |
| ops                    | uint32_t pal_exerciser_ops(EXERCISER_OPS ops, uint64_t param, uint32_t instance)                     | Abstracts the steps to implement the requested operation on the PCIe stimulus generation hardware. Following are the supported operations:<br>1 – START_DMA<br>2 – GENERATE_MSI<br>3 – GENERATE_L_INTR<br>4 – MEM_READ<br>5 – MEM_WRITE<br>6 – CLEAR_INTR<br>7 – PASID_TLP_START<br>8 – PASID_TLP_STOP<br>9 – TXN_NO_SNOOP_ENABLE<br>10 – TXN_NO_SNOOP_DISABLE<br>11 – START_TXN_MONITOR<br>12 – STOP_TXN_MONITOR<br>13 – ATS_TXN_REQ<br>14 – INJECT_ERROR |
| get_data               | uint32_t pal_exerciser_get_data(EXERCISER_DATA_TYPE type, exerciser_data_t *data, uint32_t instance) | Returns either the configuration space or the BAR space information depending on the input argument type. The argument type can take one of the following two values:<br>1 – EXERCISER_DATA_CFG_SPACE<br>2 – EXERCISER_DATA_BAR0_SPACE                                                                                                                                                                                                                     |
| is_bdf_exerciser       | uint32_t pal_is_bdf_exerciser(uint32_t bdf)                                                          | Checks if the device is an exerciser.<br>Returns 1 if device is an exerciser, else 0.                                                                                                                                                                                                                                                                                                                                                                      |
| get_ecsr_base          | uint64_t pal_exerciser_get_ecsr_base(uint32_t Bdf, uint32_t BarIndex)                                | Returns the ECSR base address of a particular BAR Index.                                                                                                                                                                                                                                                                                                                                                                                                   |
| get_PCIE_config_offset | uint64_t pal_exerciser_get_PCIE_config_offset(uint32_t Bdf)                                          | Returns the configuration address of the given bdf.                                                                                                                                                                                                                                                                                                                                                                                                        |

| API Name                             | Function prototype                                                                                       | Description                                                                                                                     |
|--------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| start_dma_direction                  | uint32_t pal_exerciser_start_dma_direction(uint64_t Base, EXERCISER_DMA_ATTRDirection)                   | Triggers the DMA operation.                                                                                                     |
| find_PCIE_capability                 | uint32_t pal_exerciser_find_PCIE_capability(uint32_t ID, uint32_t Bdf, uint32_t Value, uint32_t *Offset) | Returns 0 if the PCIe capability is found.                                                                                      |
| disable_rp_pio_register              | void pal_exerciser_disable_rp_pio_register(uint32_t bdf)                                                 | Disables the RP-PIO register for RP BDF of an exerciser.                                                                        |
| check_poison_data_forwarding_support | uint32_t pal_exerciser_check_poison_data_forwarding_support()                                            | Checks if forwarding poison data forwarding is supported or not.<br><br>Return 1 if poison data forwarding is supported else 0. |
| get_PCIE_RAS_compliant_err_node      | uint32_t pal_exerciser_get_PCIE_RAS_compliant_err_node(uint32_t bdf, uint32_t rp_bdf)                    | Return the RAS node that records the PCIe errors.                                                                               |
| get_ras_status                       | uint64_t pal_exerciser_get_ras_status(uint32_t ras_node, uint32_t bdf, uint32_t rp_bdf)                  | Return the status register of the RAS node that recorded the PCIe errors.                                                       |
| set_bar_response                     | uint32_t pal_exerciser_set_bar_response(uint32_t bdf)                                                    | Ensures that an external abort is obtained when MMIO space is targeted with reads.                                              |

### 3.2.9 Miscellaneous APIs

Miscellaneous APIs are described in the following table.

**Table 3-9: Miscellaneous APIs and their descriptions**

| API name  | Function prototype                                              | Description                                                                                                                                                                                                                                                                                     |
|-----------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| print     | void pal_print(char *string, uint64_t data);                    | Sends a formatted string to the output console.<br><br>string: An ASCII string.<br><br>data: Data for the formatted output.                                                                                                                                                                     |
| print_raw | void pal_print_raw(uint64_t addr, char *string, uint64_t data); | Sends a string to the output console without using the platform print function. This function gets COMM port address and directly writes to the address character by character.<br><br>addr: Address to be written.<br><br>string: An ASCII string.<br><br>data: Data for the formatted output. |

| API name     | Function prototype                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| strcmp       | <code>uint32_t pal_strcmp<br/>(char *FirstString, char<br/>*SecondString, uint32_t<br/>Length);</code> | <p>Compares two strings. Returns zero if strings are identical, else a nonzero value.</p> <p><code>FirstString</code>: The pointer to the first null-terminated ASCII string.</p> <p><code>SecondString</code>: The pointer to the second null-terminated ASCII string.</p> <p><code>Length</code>: The maximum number of ASCII characters for comparison.</p> |
| mmio_read    | <code>uint32_t pal_mmio_read(uint64_t<br/>addr);</code>                                                | <p>Provides a single point of abstraction to read from all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>return</code>: 32-bit data read from the input address</p>                                                                                                                                                 |
| mmio_read8   | <code>uint8_t pal_mmio_read8(uint64_t<br/>addr);</code>                                                | <p>Provides a single point of abstraction to read 8-bit data from all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>return</code>: 8-bit data read from the input address</p>                                                                                                                                       |
| mmio_read16  | <code>uint16_t pal_mmio_<br/>read16(uint64_t addr);</code>                                             | <p>Provides a single point of abstraction to read 16-bit data from all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>return</code>: 16-bit data read from the input address</p>                                                                                                                                     |
| mmio_read64  | <code>uint64_t pal_mmio_<br/>read64(uint64_t addr);</code>                                             | <p>Provides a single point of abstraction to read 64-bit data from all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>return</code>: 64-bit data read from the input address</p>                                                                                                                                     |
| mmio_write   | <code>void pal_mmio_write(uint64_t<br/>addr, uint32_t data);</code>                                    | <p>Provides a single point of abstraction to write to all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>data</code>: 32-bit data to write to address</p>                                                                                                                                                            |
| mmio_write8  | <code>void pal_mmio_write8(uint64_t<br/>addr, uint8_t data);</code>                                    | <p>Provides a single point of abstraction to write 8-bit data to all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>data</code>: 8-bit data to write to address</p>                                                                                                                                                  |
| mmio_write16 | <code>void pal_mmio_write16(uint64_t<br/>addr, uint16_t data);</code>                                  | <p>Provides a single point of abstraction to write 16-bit data to all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>data</code>: 16-bit data to write to address</p>                                                                                                                                                |

| API name            | Function prototype                                                                | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mmio_write64        | <code>void pal_mmio_write8(unit64_t addr, uint64_t data);</code>                  | <p>Provides a single point of abstraction to write 64-bit data to all memory-mapped I/O addresses.</p> <p><code>addr</code>: 64-bit input address</p> <p><code>data</code>: 64-bit data to write to address</p>                                                                                                                                                                                  |
| mem_free_shared     | <code>void pal_mem_free_shared(void);</code>                                      | Frees the allocated shared memory region.                                                                                                                                                                                                                                                                                                                                                        |
| mem_get_shared_addr | <code>uint64_t pal_mem_get_shared_addr(void);</code>                              | Returns the base address of the shared memory region to the VAL layer.                                                                                                                                                                                                                                                                                                                           |
| mem_alloc           | <code>void pal_mem_alloc(unsigned int size);</code>                               | <p>Allocates memory of the requested size.</p> <p><code>size</code>: size of the memory region to be allocated</p> <p>Returns virtual address on success and null on failure.</p>                                                                                                                                                                                                                |
| mem_calloc          | <code>void * pal_mem_calloc(uint32_t num, uint32_t size);</code>                  | Allocates requested buffer size in bytes with zeros in a contiguous memory and returns the base address of the range.                                                                                                                                                                                                                                                                            |
| mem_allocate_shared | <code>void pal_mem_allocate_shared(uint32_t num_pe, uint32_t sizeofentry);</code> | <p>Allocates memory which is to be used to share data across PEs.</p> <p><code>num_pe</code>: number of PEs in the system</p> <p><code>sizeofentry</code>: size of memory region allocated to each PE</p> <p>Returns none.</p>                                                                                                                                                                   |
| mem_free            | <code>void pal_mem_free(void *buffer);</code>                                     | <p>Frees the memory allocated by UEFI framework APIs.</p> <p><code>buffer</code>: the base address of the memory range to be free</p>                                                                                                                                                                                                                                                            |
| mem_cpy             | <code>void *pal_memcpy(void *dest_buffer, void *src_buffer, uint32_t len);</code> | <p>Copies a source buffer to a destination buffer and returns the destination buffer.</p> <p><code>dest_buffer</code>: pointer to the destination buffer of the memory copy</p> <p><code>src_buffer</code>: pointer to the source buffer of the memory copy</p> <p><code>len</code>: number of bytes to copy from source buffer to destination buffer</p> <p>Returns the destination buffer.</p> |
| mem_compare         | <code>uint32_t pal_mem_compare(void *src, void *dest, uint32_t len);</code>       | <p>Compares the contents of the source and destination buffers.</p> <p><code>src</code>: base address of the memory, source buffer to be compared</p> <p><code>dest</code>: destination buffer to be compared with</p> <p><code>len</code>: length of the comparison to be performed</p>                                                                                                         |
| mem_alloc_cacheable | <code>void pal_mem_alloc_cacheable(uint32_t bdf, uint32_t size, void *pa);</code> | <p>Allocates cacheable memory of the requested size.</p> <p><code>bdf</code>: BDF of the requesting PCIe device</p> <p><code>size</code>: size of the memory region to be allocated</p> <p><code>pa</code>: physical address of the allocated memory</p>                                                                                                                                         |

| API name             | Function prototype                                                                                 | Description                                                                                                                                                                                                                                                                                     |
|----------------------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mem_free_cacheable   | <code>void pal_mem_free_cacheable(uint32_t bdf,<br/>uint32_t size, void *va, void<br/>*pa);</code> | Frees the cacheable memory allocated by Linux DMA Framework APIs.<br><br>bdf: Bus, Device, and Function of the requesting PCIe device<br><br>size: size of memory region to be freed<br><br>va: virtual address of the memory to be freed<br><br>pa: physical address of the memory to be freed |
| mem_virt_to_phys     | <code>void pal_mem_virt_to_phys(void<br/>*va);</code>                                              | Returns the physical address of the input virtual address.<br><br>va: virtual address of the memory to be converted<br><br>Returns the physical address.                                                                                                                                        |
| time_delay_ms        | <code>uint64_t pal_time_delay_ms<br/>(uint64_t MicroSeconds);</code>                               | Stalls the CPU for the specified number of microseconds.<br><br>MicroSeconds: the minimum number of microseconds to be delayed<br><br>Returns the value of the microseconds given as input.                                                                                                     |
| mem_set              | <code>void pal_mem_set (void *buf,<br/>uint32_t size, uint8_t value);</code>                       | A buffer with a known specified input value.<br><br>buf: pointer to the buffer to fill<br><br>size: number of bytes in the buffer to fill<br><br>value: value to fill the buffer with                                                                                                           |
| page_size            | <code>uint32_t pal_mem_page_size();</code>                                                         | Returns the memory page size (in bytes) used by the platform.                                                                                                                                                                                                                                   |
| alloc_pages          | <code>void* pal_mem_alloc_pages<br/>(uint32_t NumPages);</code>                                    | Allocates the requested number of memory pages.                                                                                                                                                                                                                                                 |
| free_pages           | <code>void pal_mem_free_pages (void<br/>*PageBase, uint32_t NumPages);</code>                      | Frees pages as requested.                                                                                                                                                                                                                                                                       |
| phys_to_virt         | <code>void* pal_mem_phys_to_virt<br/>(uint64_t Pa);</code>                                         | Returns the VA of the input PA.<br>Pa: Physical Address of the memory to be converted.<br><br>Returns the VA.                                                                                                                                                                                   |
| target_is_bm         | <code>uint32_t pal_target_is_bm();</code>                                                          | Checks if the system information is passed using bare-metal.                                                                                                                                                                                                                                    |
| aligned_alloc        | <code>void *pal_aligned_<br/>alloc( uint32_t alignment,<br/>uint32_t size);</code>                 | Allocates memory with the given alignment.<br><br>alignment: Specifies the alignment.<br><br>size: Requested memory allocation size.<br><br>Returns pointer to the allocated memory with requested alignment.                                                                                   |
| mem_free_aligned     | <code>void pal_mem_free_aligned(void<br/>*buffer);</code>                                          | Frees the aligned memory allocated by aligned_alloc. Buffer: The base address of the aligned memory range.                                                                                                                                                                                      |
| mem_alloc_at_address | <code>void *pal_mem_alloc_at_<br/>address(uint64_t mem_base,<br/>uint64_t size);</code>            | Allocate memory in the given memory base.                                                                                                                                                                                                                                                       |

| API name            | Function prototype                                              | Description                                         |
|---------------------|-----------------------------------------------------------------|-----------------------------------------------------|
| mem_free_at_address | void pal_mem_free_at_address(uint64_t mem_base, uint64_t size); | Free the allocated memory in the given memory base. |

### 3.2.10 NIST API

This API is used for randomness testing.

**Table 3-10: NIST API and its description**

| API name     | Function prototype                                    | Description                                                                                                          |
|--------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| generate_rng | uint32_t pal_nist_generate_rng(uint32_t *rng_buffer); | Generates a 32-bit random number.<br>rng_buffer: pointer to store the random data<br><br>Returns success or failure. |

### 3.2.11 PMU APIs

These APIs provide the information and functionality required by the test suite that accesses features of System PMU.

**Table 3-11: PMU API and their descriptions**

| API name                            | Function prototype                                                                                                      | Description                                                                                                                                                                                          |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| create_info_table                   | void pal_pmu_create_info_table(PMU_INFO_TABLE *PmuTable);                                                               | Abstracts the steps to gather information about system PMU in the platform and fills the PmuTable.                                                                                                   |
| get_event_info                      | uint32_t pal_pmu_get_event_info(PMU_EVENT_TYPE_e event_type, PMU_NODE_INFO_TYPE node_type);                             | Returns the IMPLEMENTATION DEFINED event ID based on the requested PMU event and PMU node type. The IMPLEMENTATION DEFINED event ID must be filled into event_list array at <code>pal_pmu.c</code> . |
| check_monitor_count_value           | uint32_t pal_pmu_check_monitor_count_value(uint64_t interface_acpid, uint32_t count_value, uint32_t eventid);           | This API checks if the PMU monitor count value is valid.                                                                                                                                             |
| generate_traffic                    | uint32_t pal_generate_traffic(uint64_t interface_acpid, uint32_t pmu_node_index, uint32_t mon_index, uint32_t eventid); | This API generates required workload for the given PMU node and event id.                                                                                                                            |
| get_multi_traffic_support_interface | uint32_t pal_pmu_get_multi_traffic_support_interface(uint64_t *interface_acpid, uint32_t *num_traffic_type_support);    | This API returns the ACPI HID of the interface which supports multi traffic and number of multi traffic supported.                                                                                   |

The following structures hold information about the system PMU.



```
/*Instance of system pmu info*/
typedef struct {
    uint8_t type;           /* The component that this PMU block is
                                associated with*/
    uint64_t primary_instance; /* Primary node instance, specific to the
                                PMU type*/
    uint32_t secondary_instance; /* Secondary node instance, specific to
                                the PMU type*/
    uint8_t dual_page_extension; /* Support of the dual-page mode*/
    uint64_t base0;          /* Base address of Page 0 of the PMU*/
    uint64_t base1;          /* Base address of Page 1 of the PMU, valid only
                                if dual_page_extension is 1*/
} PMU_INFO_BLOCK;
```

```
typedef struct {
    uint32_t pmu_count;      /* Total number of PMU info blocks*/
    PMU_INFO_BLOCK info[];   /* PMU info blocks for each PMU nodes*/
} PMU_INFO_TABLE;
```

### 3.2.12 RAS APIs

These APIs provide the information and functionality required by the test suite that accesses features of RAS.

**Table 3-12: RAS APIs and their descriptions**

| API name               | Function prototype                                                              | Description                                                                                                                                                                                                                    |
|------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ras_create_info_table  | void pal_ras_create_info_table(RAS_INFO_TABLE *RasInfoTable);                   | Abstracts the steps to gather information about RAS from AEST ACPI Table in the platform and fills the RasInfoTable.                                                                                                           |
| ras2_create_info_table | void pal_ras2_create_info_table(RAS2_INFO_TABLE *ras2_info_table);              | Abstracts the steps to gather information about RAS from RAS2 ACPI Table in the platform and fills the Ras2InfoTable.                                                                                                          |
| setup_error            | uint32_t pal_ras_setup_error(RAS_ERR_IN_t in_param, RAS_ERR_OUT_t *out_param);  | Platform defined API to setup the error.<br><br><i>in_param</i> : Input parameters set from the test which are used to setup the error.<br><br><i>out_param</i> : Return values from the platform which are used in the test.  |
| inject_error           | uint32_t pal_ras_inject_error(RAS_ERR_IN_t in_param, RAS_ERR_OUT_t *out_param); | Platform defined API to inject the error.<br><br><i>in_param</i> : Input parameters set from the test which are used to setup the error.<br><br><i>out_param</i> : Return values from the platform which are used in the test. |
| wait_timeout           | void pal_ras_wait_timeout(uint32_t count);                                      | Platform defined API to wait for a timeout.<br><br><i>count</i> : Multiplier for timeout_small/medium.                                                                                                                         |

| API name                  | Function prototype                           | Description                                                                                                                                                                             |
|---------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| check_plat_poison_support | uint32_t pal_ras_check_plat_poison_support() | Returns the Poison storage and forwarding support capability in the platform.<br><br>0: Poison storage and forwarding not supported.<br><br>1: Poison storage and forwarding supported. |

- The following enumerator holds the RAS node types:

```
typedef enum {
    NODE_TYPE_PE = 0x0,
    NODE_TYPE_MC = 0x1,
    NODE_TYPE_SMMU = 0x2,
    NODE_TYPE_VDR = 0x3,
    NODE_TYPE_GIC = 0x4,
    NODE_TYPE_LAST_ENTRY
} RAS_NODE_TYPE_e;
```

- The following structures hold information about each RAS node.

```
typedef enum {
    RAS_INTF_TYPE_SYS_REG,      /* System register RAS node interface
type */
    RAS_INTF_TYPE_MMIO          /* MMIO RAS node interface type */
} RAS_NODE_intf_TYPE;

typedef struct {
    uint32_t processor_id;
    uint32_t resource_type;
    uint32_t flags;
    uint64_t affinity;
    uint64_t res_specific_data; /* Resource Specific Data */
} RAS_NODE_PE_DATA;

typedef struct {
    uint32_t proximity_domain;
} RAS_NODE_MC_DATA;

typedef struct {
    RAS_NODE_intf_TYPE intf_type; /* Interface Type */
    uint32_t flags;
    uint64_t base_addr;           /* Base address to MMIO region,
valid for MMIO intf type */
    uint32_t start_rec_index;     /* Start Record Index */
    uint32_t num_err_rec;         /* Number of error records
(implemented & unimplemented) */
    uint64_t err_rec_implement;   /* bitmap of error records
implemented */
    uint64_t err_status_reporting; /* bitmap indicates which error
records within this error
reporting using ERRGSR */
    uint64_t addressing_mode;     /* bitmap based policy for
ERR<n>ADDR field of error records */
} RAS_INTERFACE_INFO;

typedef struct {
    uint32_t type;
    uint32_t flag;
    uint32_t gsiv;
    uint32_t its_grp_id;
} RAS_INTERRUPT_INFO;

typedef union {
    RAS_NODE_PE_DATA pe;
```



Note

```

        RAS_NODE_MC_DATA      mc;
} RAS_NODE_DATA;

typedef struct {
    RAS_NODE_TYPE_e      type;           /* Node Type PE/GIC/SMMU */
    UINT16_t             length;         /* Length of the Node */
    uint64_t              num_intr_entries; /* Number of Interrupt
                                             Entries */
    RAS_NODE_DATA        node_data;       /* Node Specific Data */
    RAS_INTERFACE_INFO   intf_info;       /* Node Interface Info */
    RAS_INTERRUPT_INFO   intr_info[2];    /* Node Interrupt Info */
} RAS_NODE_INFO;

typedef struct {
    uint32_t             num_nodes;      /* Number of total RAS Nodes */
    uint32_t             num_pe_node;    /* Number of PE RAS Nodes */
    uint32_t             num_mc_node;    /* Number of Memory Controller Nodes */
    RAS_NODE_INFO        node[];         /* Array of RAS nodes */
} RAS_INFO_TABLE;

typedef enum {
    RAS2_TYPE_MEMORY = 0 /* RAS2 memory feature type*/
} RAS2_FEAT_TYPE;

typedef struct {
    uint32_t             proximity_domain; /* Proximity domain of the memory
                                              */
    uint32_t             patrol_scrub_support; /* Patrol scrub support flag */
} RAS2_MEM_INFO;

typedef union {
    RAS2_MEM_INFO        mem_feat_info; /* Memory feature specific info */
} RAS2_BLOCK_INFO;

typedef struct {
    RAS2_FEAT_TYPE       type;           /* RAS2 feature type*/
    RAS2_BLOCK_INFO      block_info;     /* RAS2 block info */
} RAS2_BLOCK;

typedef struct {
    uint32_t             num_all_block;  /* Number of RAS2 feature blocks */
    uint32_t             num_of_mem_block; /* Number of memory feature blocks
                                              */
    RAS2_BLOCK           blocks[];       /* RAS2 blocks */
} RAS2_INFO_TABLE;

```

### 3.2.13 MPAM APIs

These APIs provide the information and functionality required by the test suite that accesses features of MPAM and other information to verify it.

**Table 3-13: MPAM APIs and their descriptions**

| API name          | Function prototype                                            | Description                                                                                                |
|-------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| create_info_table | void pal_mpam_create_info_table(MPAM_INFO_TABLE *MpamTable);  | Abstracts the steps to gather information about MPAM in the platform and fills the MpamTable.              |
| create_info_table | void pal_hmat_create_info_table(HMAT_INFO_TABLE *HmatTable);  | Abstracts the steps to gather information about memory attributes in the platform and fills the HmatTable. |
| create_info_table | void pal_srat_create_info_table(SRAT_INFO_TABLE * SratTable); | Abstracts the steps to gather information about memory range in the platform and fills the SratTable.      |

| API name          | Function prototype                                                                      | Description                                                                                      |
|-------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| create_info_table | void pal_cache_create_info_table(CACHE_INFO_TABLE *CacheTable, PE_INFO_TABLE *PeTable); | Abstracts the steps to gather information about Caches in the platform and fills the CacheTable. |

- The following structures hold information about the cache information platform.

```
/*only the fields and flags required by ACS are parsed from ACPI
PPTT table*/
/*Cache flags indicate validity of cache info provided by PPTT
Table*/
typedef struct {
    uint32_t size_property_valid;
    uint32_t cache_type_valid;
    uint32_t cache_id_valid;
} CACHE_FLAGS;

/* Since most of platform doesn't support cache id field (ACPI
6.4+), ACS uses PPTT offset as key
to uniquely identify a cache, In future once platforms align with
ACPI 6.4+ my_offset member
might be removed from cache entry*/
typedef struct {
    CACHE_FLAGS flags;           /* Cache flags */
    uint32_t my_offset;          /* Cache PPTT structure offset */
    uint32_t next_level_index;   /* Index of next level cache entry in
CACHE_INFO_TABLE */
    uint32_t size;               /* Size of the cache in bytes */
    uint32_t cache_id;           /* Unique, non-zero identifier for
this cache */
    uint32_t is_private;         /* Field indicate whether cache is
private */
    UINT8 cache_type;            /* Cache type */
} CACHE_INFO_ENTRY;

typedef struct {
    uint32_t num_of_cache;        /* Total of number of cache info
entries */
    CACHE_INFO_ENTRY cache_info[]; /* Array of cache info entries */
} CACHE_INFO_TABLE;
```



Note

- The following structures hold memory attribute information about the platform.

```
typedef struct {
    uint32_t mem_prox_domain; /* Proximity domain of the memory
region*/
    uint64_t write_bw;        /* Maximum write bandwidth */
    uint64_t read_bw;         /* Maximum read bandwidth */
} HMAT_BW_ENTRY;

typedef struct {
    uint32_t num_of_mem_prox_domain; /* Number of Memory Proximity
Domains */
    HMAT_BW_ENTRY bw_info[];        /* Array of bandwidth info based
on proximity domain */
} HMAT_INFO_TABLE;
```

- The following structures hold the memory range information and GICC affinity structure information about the platform.

```
typedef enum {
    SRAT_NODE_MEM_AFF = 0x01,
    SRAT_NODE_GICC_AFF = 0x03
} SRAT_NODE_TYPE_e;

/**@brief SRAT GICC Affinity Structure**/

typedef struct {
```

```

    uint32_t prox_domain;      /* Proximity domain*/
    uint32_t proc_uid;        /* ACPI Processor UID */
    uint32_t flags;           /* Flags*/
    uint32_t clk_domain;      /* Clock Domain*/
} SRAT_GICC_AFF_ENTRY;

/**@brief SRAT Memory Affinity Structure**/

typedef struct {
    uint32_t prox_domain;      /* Proximity domain */
    uint32_t flags;           /* flags */
    uint64_t addr_base;        /* mem range address base */
    uint64_t addr_len;         /* mem range address len */
} SRAT_MEM_AFF_ENTRY;

typedef union {
    SRAT_MEM_AFF_ENTRY mem_aff;
    SRAT_GICC_AFF_ENTRY gicc_aff;
} SRAT_NODE_INFO;

typedef struct {
    uint32_t node_type;        /* Node type*/
    SRAT_NODE_INFO node_data;
} SRAT_INFO_ENTRY;

typedef struct {
    uint32_t num_of_srat_entries;
    uint32_t num_of_mem_ranges;
    SRAT_INFO_ENTRY srat_info[];
} SRAT_INFO_TABLE;

```

- The following structures hold information about MPAM in the platform.

```

/*MPAM resource Node*/
typedef struct {
    uint8_t ris_index;
    uint8_t locator_type; /* Identifies location of this resource */
    uint64_t descriptor1; /* Primary acpi description of location */
    uint32_t descriptor2; /* Secondary acpi description of location */
}
MPAM_RESOURCE_NODE;

/*MPAM MSC Node*/

typedef struct {
    uint64_t msc_base_addr; /* base addr of mem-map MSC reg */
    uint32_t msc_addr_len; /* MSC mem map size */
    uint32_t max_nrdy;    /* max time in microseconds that MSC not
                           ready after config change */
    uint32_t rsrc_count;  /* number of resource nodes */
    MPAM_RESOURCE_NODE rsrc_node[]; /* Details of resource node */
}
MPAM_MSC_NODE;

/*MPAM info table*/

typedef struct {
    uint32_t msc_count;     /* Number of MSC node */
    MPAM_MSC_NODE msc_node[]; /* Details of MSC node */
}
MPAM_INFO_TABLE;

```

# Appendix A NIST Statistical Test Suite

This appendix describes the integration of NIST Statistical Test Suite with SBSA ACS.

## A.1 NIST Statistical Test Suite

Randomness testing plays a fundamental role in many areas of computer science, especially cryptography. Well-designed cryptographic primitives like hash functions and stream ciphers should produce pseudorandom data.

The outputs of such generators may be used in cryptographic applications like generation of key material. Generators suitable for use in cryptographic applications must meet stronger requirements than for other applications. In particular, their outputs must be unpredictable in the absence of knowledge of the inputs.

### Statistical test suites

Randomness testing is performed using test suites consisting of many tests, each focusing on a different feature. These tests can be used as the first steps in determining if a generator is suitable for a particular cryptographic application.

### SBSA ACS with NIST STS

There are five well-known statistical test suites namely NIST Statistical Test Suite (STS), Diehard, TestU01, ENT, and CryptX. Only the first three test suites are commonly used for the randomness analysis because CryptX is a commercial software and ENT provides only basic randomness testing. Since NIST STS has a special position for being published as an official document, it is often used in the preparation of formal certifications or approvals.

### Building NIST STS with SBSA ACS

To build NIST STS with SBSA ACS, [NIST STS 2.1.2 package](#) is required and downloaded automatically as part of the build process.

See the updated version of the [NIST STS tool for randomness testing](#) documentation. The reason for the update is, the original source code provided with NIST does not compile cleanly in UEFI because it does not provide erf() and erfc() functions in the standard math library. Implementation of these functions has been added as part of SBSA VAL and a patch file is created.

### Running NIST STS with SBSA ACS

For information on running NIST STS, see the Arm® SBSA NIST User Guide. For details about NIST STS, see [A Statistical Test Suite for Random and Pseudorandom Number Generators for Cryptographic Applications](#).

## Interpreting the results

The final analysis report is generated after the statistical testing is complete. It contains a summary of empirical results that are displayed on the console. A test is unsuccessful when P-value < 0.01. Then the sequence under test should be considered as non-random.

The minimum pass rate for each statistical test except for the random excursion (variant) test is approximately 8 for a sample size of ten binary sequences. The minimum pass rate for the random excursion (variant) test is undefined.



For SBSA compliance, passing NIST STS is optional.

Note

---

# Proprietary Notice

This document is protected by copyright and other related rights and the use 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 Limited ("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 the subject matter of this document infringes any third party patents.

The content of this document is informational only. Any solutions presented herein are subject to changing conditions, information, scope, and data. This document was produced using reasonable efforts based on information available as of the date of issue of this document. The scope of information in this document may exceed that which Arm is required to provide, and such additional information is merely intended to further assist the recipient and does not represent Arm's view of the scope of its obligations. You acknowledge and agree that you possess the necessary expertise in system security and functional safety and that you shall be solely responsible for compliance with all legal, regulatory, safety and security related requirements concerning your products, notwithstanding any information or support that may be provided by Arm herein. In addition, you are responsible for any applications which are used in conjunction with any Arm technology described in this document, and to minimize risks, adequate design and operating safeguards should be provided for by you.

This document may include technical inaccuracies or typographical errors. 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, any patents, copyrights, trade secrets, trademarks, or other rights.

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.

Reference by Arm to any third party's products or services within this document is not an express or implied approval or endorsement of the use thereof.

This document consists solely of commercial items. You shall be responsible for ensuring that any permitted 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.

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 this document shall prevail.

The validity, construction and performance of this notice shall be governed by English Law.

The Arm corporate logo and words marked with ® or ™ are registered trademarks or trademarks of Arm Limited (or its affiliates) in the US and/or elsewhere. Please follow Arm's trademark usage guidelines at <https://www.arm.com/company/policies/trademarks>. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

PRE-1121-V1.0

# Product and document information

Read the information in these sections to understand the release status of the product and documentation, and the conventions used in the Arm documents.

## Product status

All products and Services provided by Arm require deliverables to be prepared and made available at different levels of completeness. The information in this document indicates the appropriate level of completeness for the associated deliverables.

### Product completeness status

The information in this document is for a Beta product, that is a product under development.

## Revision history

These sections can help you understand how the document has changed over time.

### Document release information

The Document history table gives the issue number and the released date for each released issue of this document.

#### Document history

| Issue   | Date              | Confidentiality  | Change                 |
|---------|-------------------|------------------|------------------------|
| 0800-01 | 10 December 2025  | Non-Confidential | REL 8.0.0 BETA release |
| 0701-08 | 28 May 2025       | Non-Confidential | REL 7.2.2 EAC release  |
| 0701-07 | 25 March 2025     | Non-Confidential | REL 7.2.1 EAC release  |
| 0701-06 | 29 March 2024     | Non-Confidential | REL 7.2.0 BETA release |
| 0701-05 | 19 December 2023  | Non-Confidential | REL 7.1.4 EAC release  |
| 0701-04 | 28 September 2023 | Non-Confidential | REL 7.1.3 EAC release  |

| Issue   | Date              | Confidentiality  | Change                                                    |
|---------|-------------------|------------------|-----------------------------------------------------------|
| 0701-03 | 29 June 2023      | Non-Confidential | REL 7.1.2 EAC release                                     |
| 0701-02 | 28 March 2023     | Non-Confidential | REL 7.1.1 BETA-1 release                                  |
| 0701-01 | 16 January 2023   | Non-Confidential | REL 7.1 BETA-0 release                                    |
| 0700-00 | 15 June 2022      | Non-Confidential | REL 7.0 ALPHA release                                     |
| 0601-01 | 28 October 2022   | Non-Confidential | REL 6.1                                                   |
| 0302-01 | 26 July 2022      | Non-Confidential | REL 3.2                                                   |
| 0301-01 | 27 September 2021 | Non-Confidential | REL 3.1                                                   |
| 0300-01 | 30 September 2020 | Non-Confidential | REL 3.0                                                   |
| 0200-04 | 20 March 2020     | Non-Confidential | REL 2.4                                                   |
| 0200-03 | 18 September 2019 | Non-Confidential | REL 2.3                                                   |
| 0200-02 | 26 April 2019     | Non-Confidential | REL 2.2                                                   |
| 0200-01 | 27 December 2018  | Non-Confidential | REL 2.1. The document now follows a new numbering format. |
| E       | 11 May 2018       | Non-Confidential | REL 2.0                                                   |
| D       | 19 January 2018   | Non-Confidential | Alpha release for REL 2.0                                 |
| C       | 13 July 2017      | Non-Confidential | REL 1.0                                                   |
| B       | 31 March 2017     | Non-Confidential | Beta release                                              |
| A       | 30 November 2016  | Non-Confidential | Alpha release                                             |

The Change history tables describe the technical changes between released issues of this document in reverse order. Issue numbers match the revision history in [Document release information](#) on page 52.

**Table 2: Differences between Issue E and Issue 0200-01**

| Change                                | Location                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Information about exerciser is added. | See the following sections: <ul style="list-style-type: none"><li>• <a href="#">1.3 Compliance test suites</a> on page 6.</li><li>• <a href="#">2.2 Test build and execution flow</a> on page 18.</li><li>• <a href="#">3.2.1 API naming convention</a> on page 21.</li><li>• <a href="#">3.2.8 Exerciser APIs</a> on page 35.</li></ul> |

**Table 3: Differences between Issue 0200-01 and Issue 0200-02**

| Change                                                    | Location                                                          |
|-----------------------------------------------------------|-------------------------------------------------------------------|
| A note about exerciser is added.                          | See <a href="#">1.3 Compliance test suites</a> on page 6.         |
| pal_baremetal folder is added to the directory structure. | See <a href="#">2.2 Test build and execution flow</a> on page 18. |
| Added a note about PAL bare-metal reference code.         | See <a href="#">3.1 Overview of PAL API</a> on page 21.           |

**Table 4: Differences between Issue 0200-02 and Issue 0200-03**

| Change                | Location |
|-----------------------|----------|
| No technical changes. | -        |

**Table 5: Differences between Issue 0200-03 and Issue 0200-04**

| Change                                           | Location                                                                                                                                                                                                                                          |
|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A new section about exerciser is added.          | See <a href="#">1.5 Exerciser</a> on page 11.                                                                                                                                                                                                     |
| NIST STS information is updated in these topics. | See <ul style="list-style-type: none"><li>• <a href="#">1.3 Compliance test suites</a> on page 6.</li><li>• <a href="#">2.2 Test build and execution flow</a> on page 18.</li><li>• <a href="#">3.2 PAL API definitions</a> on page 21.</li></ul> |
| APIs are added in all the modules.               | See <a href="#">3.2 PAL API definitions</a> on page 21.                                                                                                                                                                                           |
| A new appendix about NIST STS is added.          | See <a href="#">A. NIST Statistical Test Suite</a> on page 48.                                                                                                                                                                                    |

**Table 6: Differences between Issue 0200-04 and Issue 0300-01**

| Change                                                                          | Location                                                    |
|---------------------------------------------------------------------------------|-------------------------------------------------------------|
| A new section about GIC ITS is added.                                           | See <a href="#">1.6 GIC ITS</a> on page 14.                 |
| GIC ITS PAL APIs are added to GIC APIs section.                                 | See <a href="#">3.2.3 GIC APIs</a> on page 23.              |
| SBSA ACS directory structure is updated.                                        | See <a href="#">2.2.1 Source code directory</a> on page 18. |
| read_cfg and write_cfg APIs in the PCIe APIs table are updated.                 | See <a href="#">3.2.4 PCIe APIs</a> on page 25.             |
| New configuration parameters are added to the Exerciser APIs set_param and ops. | See <a href="#">3.2.8 Exerciser APIs</a> on page 35.        |
| New APIs are added to Miscellaneous APIs section.                               | See <a href="#">3.2.9 Miscellaneous APIs</a> on page 38.    |

**Table 7: Differences between Issue 0300-01 and Issue 0700-00**

| Change                                                                                                                                                                                                                               | Location                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Updated the SBSA ACS directory structure.                                                                                                                                                                                            | See <a href="#">2.2.1 Source code directory</a> on page 18.                                                                                                                                                                                                                                                                                                                  |
| Added a new section for PMU event test suite.                                                                                                                                                                                        | See <a href="#">1.4.3 PMU event test suite</a> on page 9.                                                                                                                                                                                                                                                                                                                    |
| Added new APIs.                                                                                                                                                                                                                      | See:<br><ul style="list-style-type: none"> <li>• <a href="#">3.2.11 PMU APIs</a> on page 42</li> <li>• <a href="#">3.2.12 RAS APIs</a> on page 43</li> <li>• <a href="#">3.2.13 MPAM APIs</a> on page 45</li> </ul>                                                                                                                                                          |
| Updated the following sections:<br><ul style="list-style-type: none"> <li>• Abbreviations</li> <li>• Compliance tests</li> <li>• Test platform abstraction</li> <li>• Building the tests</li> <li>• API naming convention</li> </ul> | See:<br><ul style="list-style-type: none"> <li>• <a href="#">1.1 Abbreviations</a> on page 5</li> <li>• <a href="#">1.3 Compliance test suites</a> on page 6</li> <li>• <a href="#">1.7 Test platform abstraction</a> on page 15</li> <li>• <a href="#">2.2.2 Building the tests</a> on page 20</li> <li>• <a href="#">3.2.1 API naming convention</a> on page 21</li> </ul> |

**Table 8: Differences between Issue 0302-01 and Issue 0601-01**

| Change                        | Location                                        |
|-------------------------------|-------------------------------------------------|
| Added an abbreviation for HVC | See <a href="#">1.1 Abbreviations</a> on page 5 |
| Enhancement changes           | Applicable sections.                            |

**Table 9: Differences between Issue 0700-00 and Issue 0701-01**

| Change                                                                      | Location                                                                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Updated abbreviations table.                                                | See <a href="#">1.1 Abbreviations</a> on page 5                                                                                                                                                                                                                            |
| Added memory to the compliance test components.                             | See:<br><ul style="list-style-type: none"> <li>• <a href="#">1.3 Compliance test suites</a> on page 6</li> <li>• <a href="#">1.7 Test platform abstraction</a> on page 15</li> </ul>                                                                                       |
| Added baremetal_app and prebuilt_images folders to the directory structure. | See <a href="#">2.2.1 Source code directory</a> on page 18                                                                                                                                                                                                                 |
| Updated supported configuration parameters for set_param and ops.           | See <a href="#">3.2.8 Exerciser APIs</a> on page 35                                                                                                                                                                                                                        |
| Added new APIs in PMU API.                                                  | See <a href="#">3.2.11 PMU APIs</a> on page 42                                                                                                                                                                                                                             |
| Updated RAS APIs.                                                           | See <a href="#">3.2.12 RAS APIs</a> on page 43                                                                                                                                                                                                                             |
| Updated information structures.                                             | See:<br><ul style="list-style-type: none"> <li>• <a href="#">3.2.2 PE APIs</a> on page 22</li> <li>• <a href="#">3.2.5 IO-Virt APIs</a> on page 30</li> <li>• <a href="#">3.2.12 RAS APIs</a> on page 43</li> <li>• <a href="#">3.2.13 MPAM APIs</a> on page 45</li> </ul> |

**Table 10: Differences between Issue 0701-01 and Issue 0701-02**

| Change                                         | Location                                                 |
|------------------------------------------------|----------------------------------------------------------|
| Updated the Figure 2-1: Layered software stack | See <a href="#">1.4 Layered software stack</a> on page 7 |

| Change                                                  | Location                                                                                                                                                                                                                  |
|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Updated PAL API's to PE, PCIe and Miscellaneous modules | See:<br><ul style="list-style-type: none"> <li>• <a href="#">3.2.2 PE APIs on page 22</a></li> <li>• <a href="#">3.2.4 PCIe APIs on page 25</a></li> <li>• <a href="#">3.2.9 Miscellaneous APIs on page 38</a></li> </ul> |

**Table 11: Differences between Issue 0701-02 and Issue 0701-03**

| Change                                                                                       | Location                                                                                                                                                   |
|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Replaced UINT32 with uint32_t and UINT64 with uint64_t in PCIe APIs and PE APIs.             | See:<br><ul style="list-style-type: none"> <li>• <a href="#">3.2.2 PE APIs on page 22</a></li> <li>• <a href="#">3.2.4 PCIe APIs on page 25</a></li> </ul> |
| Updated the interrupt routine table in IO-Virt APIs.                                         | See, <a href="#">3.2.5 IO-Virt APIs on page 30</a>                                                                                                         |
| Updated the Function prototype for Miscellaneous APIs.                                       | See, <a href="#">3.2.9 Miscellaneous APIs on page 38</a>                                                                                                   |
| Updated the Function prototype for NIST API.                                                 | See, <a href="#">3.2.10 NIST API on page 42</a>                                                                                                            |
| Replaced UINT32 with uint32_t and UINT64 with uint64_t in PMU APIs and updated the API name. | See, <a href="#">3.2.11 PMU APIs on page 42</a>                                                                                                            |
| Replaced UINT32 with uint32_t and UINT64 with uint64_t in RAS APIs.                          | See, <a href="#">3.2.12 RAS APIs on page 43</a>                                                                                                            |
| Replaced UINT32 with uint32_t in MPAM APIs.                                                  | See, <a href="#">3.2.13 MPAM APIs on page 45</a>                                                                                                           |

**Table 12: Differences between Issue 0701-03 and Issue 0701-04**

| Change                                                                      | Location                                        |
|-----------------------------------------------------------------------------|-------------------------------------------------|
| Removed the API scan_bridge_devices_and_check_memtype from PCIe APIs table. | See, <a href="#">3.2.4 PCIe APIs on page 25</a> |
| Removed the API max_pasids from the SMMU APIs table.                        | See, <a href="#">3.2.6 SMMU APIs on page 32</a> |

**Table 13: Differences between Issue 0701-04 and Issue 0701-05**

| Change                                                                              | Location                                                    |
|-------------------------------------------------------------------------------------|-------------------------------------------------------------|
| Updated the SBSA ACS directory structure figure.                                    | See, <a href="#">2.2.1 Source code directory on page 18</a> |
| Updated the PCIe APIs and their descriptions table.                                 | See, <a href="#">3.2.4 PCIe APIs on page 25</a>             |
| Removed the API get_legacy_irq_map from the Exerciser APIs and their details table. | See, <a href="#">3.2.8 Exerciser APIs on page 35</a>        |

**Table 14: Differences between Issue 0701-05 and Issue 0701-06**

| Change                                                       | Location                                                      |
|--------------------------------------------------------------|---------------------------------------------------------------|
| Updated the SBSA ACS directory structure figure.             | See, <a href="#">2.2.1 Source code directory on page 18</a> . |
| Added ETE to the Modules and corresponding API names table.  | See, <a href="#">3.2.1 API naming convention on page 21</a> . |
| Added new APIs in the Exerciser APIs and descriptions table. | See, <a href="#">3.2.8 Exerciser APIs on page 35</a> .        |

**Table 15: Differences between Issue 0701-06 and Issue 0701-07**

| Change                                                                       | Location                                        |
|------------------------------------------------------------------------------|-------------------------------------------------|
| Updated Function prototype for the API get_mcfg_ecam in the PCIe APIs table. | See, <a href="#">3.2.4 PCIe APIs on page 25</a> |
| Added API get_num_nongic_ctrl in the GIC APIs table.                         | See, <a href="#">3.2.3 GIC APIs on page 23</a>  |

**Table 16: Differences between Issue 0701-07 and Issue 0701-08**

| Change                                                                                                                                      | Location                                                     |
|---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| Updated SBSA to SYSARCH in multiple sections.                                                                                               | -                                                            |
| Updated the directory name in the SYSARCH ACS directory structure description table and updated the SYSARCH ACS directory structure figure. | See, <a href="#">2.2.1 Source code directory</a> on page 18. |

**Table 17: Differences between Issue 0701-08 and Issue 0800-01**

| Change                | Location |
|-----------------------|----------|
| No technical changes. | -        |

## Conventions

The following subsections describe conventions used in Arm documents.

### 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: [developer.arm.com/glossary](https://developer.arm.com/glossary).

### Typographic conventions

Arm documentation uses typographical conventions to convey specific meaning.

| Convention                 | Use                                                                                                                                                                                                     |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| italic                     | Citations.                                                                                                                                                                                              |
| <b>bold</b>                | Interface elements, such as menu names.<br><br>Terms in descriptive lists, where appropriate.                                                                                                           |
| monospace                  | Text that you can enter at the keyboard, such as commands, file and program names, and source code.                                                                                                     |
| monospace <u>underline</u> | A permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.                                                                         |
| <and>                      | Encloses replaceable terms for assembler syntax where they appear in code or code fragments.<br><br>For example:<br><br><code>MRC p15, 0, &lt;Rd&gt;, &lt;CRn&gt;, &lt;CRm&gt;, &lt;Opcode_2&gt;</code> |
| <b>SMALL CAPITALS</b>      | Terms that have specific technical meanings as defined in the Arm® Glossary. For example, <b>IMPLEMENTATION DEFINED</b> , <b>IMPLEMENTATION SPECIFIC</b> , <b>UNKNOWN</b> , and <b>UNPREDICTABLE</b> .  |



We recommend the following. If you do not follow these recommendations your system might not work.



**Warning**

Your system requires the following. If you do not follow these requirements your system will not work.



**Danger**

You are at risk of causing permanent damage to your system or your equipment, or of harming yourself.

---



**Note**

This information is important and needs your attention.

---



**Tip**

This information might help you perform a task in an easier, better, or faster way.

---



**Remember**

This information reminds you of something important relating to the current content.

---

# Useful resources

This document contains information that is specific to this product. See the following resources for other useful information.

Arm documents are available on [developer.arm.com/documentation](https://developer.arm.com/documentation).

Confidential documents are only available to licensees, when logged in. Each document link in the following tables provides direct access to the online version of the document.

| Arm product resources                                    | Document ID | Confidentiality  |
|----------------------------------------------------------|-------------|------------------|
| <a href="#">Arm® Base System Architecture 1.0</a>        | DEN0094C    | Non-Confidential |
| <a href="#">Arm® Server Base System Architecture 7.1</a> | DEN0029H    | Non-Confidential |
| <a href="#">GICv3 and GICv4 Software Overview</a>        | DAI0492     | Non-Confidential |

| Arm architecture and specifications                                                                                           | Document ID | Confidentiality  |
|-------------------------------------------------------------------------------------------------------------------------------|-------------|------------------|
| <a href="#">Arm® Architecture Reference Manual for A-profile architecture</a>                                                 | DDI0487     | Non-Confidential |
| <a href="#">Arm® Generic Interrupt Controller Architecture Specification for GIC architecture version 3.0 and version 4.0</a> | IHI0069     | Non-Confidential |