

# **Arm® SBSA Architecture Compliance Bare-metal**

Revision: r7p1

## **User Guide**

Non-Confidential

Issue 08

Copyright © 2020-2025 Arm Limited (or its affiliates). 102311\_0701\_08\_en All rights reserved.



# Arm<sup>®</sup> SBSA Architecture Compliance Bare-metal **User Guide**

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

#### **Release Information**

#### **Document history**

| Issue   | Date              | Confidentiality  | Change                   |
|---------|-------------------|------------------|--------------------------|
| 0701-08 | 28 May 2025       | Non-Confidential | REL 7.2.2 EAC release    |
| 0701-07 | 29 October 2024   | 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 | 7 November 2023   | Non-Confidential | REL 7.1.3 EAC release    |
| 0701-03 | 28 September 2023 | Non-Confidential | REL 7.1.3 EAC release    |
| 0701-02 | 29 June 2023      | Non-Confidential | REL 7.1.2 EAC release    |
| 0701-01 | 28 March 2023     | Non-Confidential | REL 7.1.1 BETA-1 release |
| 0302-01 | 26 July 2022      | Non-Confidential | Fifth release            |
| 0301-01 | 27 September 2021 | Non-Confidential | Fourth release           |
| 0100-03 | 11 May 2021       | Non-Confidential | Third release            |
| 0100-02 | 25 March 2021     | Non-Confidential | Second release           |
| 0100-01 | 25 November 2020  | Non-Confidential | First release            |

## **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

## **Confidentiality Status**

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

Unrestricted Access is an Arm internal classification.

#### **Product Status**

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

#### Feedback on content

Information about how to give feedback on the content.

If you have comments on content then send an e-mail to support-systemready-acs@arm.com.. Give:

- The title Arm® SBSA Architecture Compliance Bare-metal User Guide.
- The number 102311\_0701\_08\_en.
- If applicable, the page number(s) to which your comments refer.
- A concise explanation of your comments.

Arm also welcomes general suggestions for additions and improvements.



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

## 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.

# **Contents**

| 1. Introduction                        | 8  |
|----------------------------------------|----|
| 1.1 Conventions                        | 3  |
| 1.2 Useful resources                   | 9  |
| 1.3 Other information                  | 10 |
| 2. Overview to SBSA ACS                | 11 |
| 2.1 Abbreviations                      | 11 |
| 2.2 SBSA ACS                           | 12 |
| 2.3 ACS design                         | 12 |
| 2.4 Boot framework                     | 13 |
| 2.4.1 Boot process and boot flow       | 13 |
| 2.4.2 Boot framework for Bare-metal.   |    |
| 2.5 Steps to customize bare-metal code |    |
| 2.5.1 Test suites                      | 16 |
| 3. Execution of SBSA ACS               | 17 |
| 3.1 SoC emulation environment          |    |
| 3.1.1 PE                               |    |
| 3.1.2 PCle                             |    |
| 3.1.3 DMA                              | 21 |
| 3.1.4 SMMU and device tests            | 22 |
| 3.1.5 GIC                              | 25 |
| 3.1.6 Timer                            | 26 |
| 3.1.7 Watchdog timer                   | 27 |
| 3.1.8 Memory                           | 27 |
| 3.1.9 MPAM                             | 28 |
| 3.1.10 HMAT                            | 31 |
| 3.1.11 RAS                             | 32 |
| 3.1.12 PMU                             | 32 |
| 3.1.13 MMU Configuration               | 33 |
| 3.1.14 Peripherals                     | 33 |
| 3.2 Bare-metal Boot                    | 3/ |

| 4. Porting requirements    | 35 |
|----------------------------|----|
| 4.1 PAL implementation     | 35 |
| 4.1.1 PE                   | 35 |
| 4.1.2 GIC                  | 36 |
| 4.1.3 Timer                | 36 |
| 4.1.4 IOVIRT               | 36 |
| 4.1.5 PCle                 | 37 |
| 4.1.6 SMMU                 | 38 |
| 4.1.7 Peripheral           | 39 |
| 4.1.8 MPAM                 | 39 |
| 4.1.9 RAS                  | 40 |
| 4.1.10 DMA                 | 40 |
| 4.1.11 Exerciser           | 41 |
| 4.1.12 Memory map          | 42 |
| 4.1.13 Miscellaneous       | 42 |
| 5. SBSA ACS flow           | 44 |
| 5.1 SBSA ACS flow diagram  | 44 |
| 5.2 SBSA test example flow | 45 |
| A. Revisions               | 46 |
| A.1 Revisions              | 46 |

## 1. Introduction

## 1.1 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.

| Convention                 | Use                                                                                                                                                                                |  |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| italic                     | Citations.                                                                                                                                                                         |  |
| bold                       | 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></and>                | Encloses replaceable terms for assembler syntax where they appear in code or code fragments.  For example:  MRC p15, 0, <rd>, <crn>, <crm>, <opcode_2></opcode_2></crm></crn></rd> |  |
| SMALL CAPITALS             | Terms that have specific technical meanings as defined in the Arm® Glossary. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE.             |  |



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



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



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



This information is important and needs your attention.



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



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

## 1.2 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. Confidential documents are only available to licensees, when logged in.

Each document link in the tables below provides direct access to the online version of the document.

| Arm product resources                                    | Document ID           | Confidentiality  |
|----------------------------------------------------------|-----------------------|------------------|
| Arm® SBSA Architecture Compliance Test Scenario          | PJDOC-2042731200-3439 | Non-Confidential |
| Arm® SBSA Architecture Compliance User Guide             | 101547                | Non-Confidential |
| Arm® SBSA Architecture Compliance Validation Methodology | 101544                | Non-Confidential |
| Arm® Server Base System Architecture 7.1                 | DEN0029H              | Non-Confidential |



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

Adobe PDF reader products can be downloaded at http://www.adobe.com.

## 1.3 Other information

See the Arm® website for other relevant information.

- Arm® Developer.
- Arm® Documentation.
- Technical Support.
- Arm® Glossary.

## 2. Overview to SBSA ACS

This chapter provides an overview on Arm SBSA ACS, the ACS design, and steps to customize the bare-metal code.

## 2.1 Abbreviations

The following table lists the abbreviations used in this document.

Table 2-1: Abbreviations and expansions

| Abbreviation | Expansion                                          |
|--------------|----------------------------------------------------|
| ACS          | Architecture Compliance Suite                      |
| ETE          | Embedded Trace Extension                           |
| DMA          | Direct Memory Access                               |
| ECAM         | Enhanced Configuration Access Mechanism            |
| GIC          | Generic Interrupt Controller                       |
| HMAT         | Heterogenous Memory Attribute Table                |
| IORT         | Input Output Remapping Table                       |
| IOVIRT       | Input Output Virtualization                        |
| ITS          | Interrupt Translation Service                      |
| MMU          | Memory Management Unit                             |
| MPAM         | Memory System Resource Partitioning and Monitoring |
| MPIDR        | Multiprocessor ID Register                         |
| MSI          | Message-Signaled Interrupt                         |
| PAL          | Platform Abstraction Layer                         |
| PCC          | Platform Communications Channel                    |
| PCle         | Peripheral Component Interconnect Express          |
| PE           | Processing Element                                 |
| PMU          | Performance Monitoring Unit                        |
| PPTT         | Processor Properties Topology Table                |
| RAS          | Reliability, Availability, and Serviceability      |
| RC           | Root Complex                                       |
| RP           | Root Port                                          |
| SBSA         | Server Base System Architecture                    |
| SoC          | System on Chip                                     |
| SMC          | Secure Monitor Call                                |
| SMMU         | System Memory Management Unit                      |
| SRAT         | System Resource Affinity Table                     |
| UART         | Universal Asynchronous Receiver and Transmitter    |

| Abbreviation | Expansion                             |
|--------------|---------------------------------------|
| UEFI         | Unified Extensible Firmware Interface |
| VAL          | Validation Abstraction Layer          |

## 2.2 SBSA ACS

Arm specifies a 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. This ensures standard system architecture to enable a suitably built single OS image to run on all the hardware compliant with this specification.

Arm provides the SBSA Architecture Compliance Suite (ACS) which contains self-checking portable C-based test cases to verify the compliance of hardware platforms to Server Base System Architecture (SBSA).

For more information on Arm SBSA ACS, see the README.

## 2.3 ACS design

The ACS is designed in a layered architecture that consists of the following components:

- Platform Abstraction Layer (PAL) is a C-based, Arm-defined API 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 baremetal abstraction.
  - For each component, PAL implementation must populate a data structure which involves supplying SoC-specific information such as base addresses, IRQ numbers, capabilities of PE, PCIe, RC, SMMU, DMA, and others.
  - PAL also uses client drivers underneath to retrieve certain device-specific information and to configure the devices.
- Validation Abstraction Layer (VAL) provides an abstraction over PAL and does not change based on the platform. This layer uses PAL layer to achieve a certain functionality. The following example achieves read memory functionality.

```
val_pcie_read_cfg -> pal_pcie_read_cfg
```

- Test pool is a layer which contains a list of test cases implemented for each component.
- Application is the top-level layer which allocates memory for component-specific tables and executes the test cases for each component.

The ACS test components are classified as follows:

- PF
- GIC

- PCle
- Exerciser
- I/O virtualization
- SMMU
- Watchdog
- Memory
- MPAM
- PMU
- RAS
- HMAT
- NIST
- ETE

## 2.4 Boot framework

The bootwrapper is a simple implementation of a boot loader to boot up the system and transition to the ACS where specific set of tests are run.

The bootwrapper initializes the hardware and loads the ACS into the memory, allowing the system to start up, independent of UEFI and execute ACS tests automatically. This further reduces porting complexity for the partners and provides them with off-the-shelf system Init code.

## 2.4.1 Boot process and boot flow

The boot process is the sequence of operations that occurs when a computer system is poweredon or restarted, allowing it to transition from a power-off state to an operational state, where the operating system can run.

A boot loader, also known as a boot manager, is a piece of software responsible for initiating the boot process and loading the operating system into memory. Boot loader is located in firmware or a dedicated boot partition and is executed when the system is powered-on or restarted.

The cold boot path in this implementation of TF-A depends on the execution state. For AArch64, it is divided into five steps (in the order of execution):

- Boot Loader stage 1 (BL1) AP Trusted ROM
- Boot Loader stage 2 (BL2) Trusted Boot Firmware
- Boot Loader stage 3-1 (BL31) EL3 Run time Software
- Boot Loader stage 3-2 (BL32) Secure-EL1 Payload (optional)
- Boot Loader stage 3-3 (BL33) Non-trusted Firmware

## 2.4.2 Boot framework for Bare-metal

With the introduction of bootwrapper, the UEFI layer is bypassed in the ACS boot flow. SBSA ACS with bootwrapper runs as non-trusted firmware at BL33.

The following figures show the overview of System boot flow and ACS boot flow in a system environment.

Figure 2-1: System boot flow



Figure 2-2: ACS Boot framework flow



## 2.5 Steps to customize bare-metal code

The following are the steps to customize bare-metal code for different platforms.



The pal baremetal reference code is located in baremetal.

1. Run the command ./generate.py <platform\_name>.

mkdir <platform\_name>

2. Running the command creates the folder with the platform name and the PAL APIs under target/<platform\_name>/src/pal\_sbsa.c to be filled.

```
cp -r RDN2/ platform name/
```

- 3. Port all the required APIs. For more details on the list of APIs, see the Porting requirements.
- 4. Modify the files target/<platform\_name>/include/platform\_override\_fvp.h and target/ <platform\_name>/include/platform\_image\_def.h with platform-specific information. For more details on sample implementation, see the Execution of SBSA ACS.

## 2.5.1 Test suites

The following table lists the bare-metal components for each test implementation.

Table 2-2: Bare-metal components

| Test suites                   | Files                              |
|-------------------------------|------------------------------------|
| PE                            | pal_pe.c                           |
| GIC                           | pal_gic.c                          |
| PCle                          | pal_pcie.c, pal_pcie_enumeration.c |
| Exerciser                     | pal_exerciser.c                    |
| IOVIRT                        | pal_iovirt.c                       |
| SMMU                          | pal_smmu.c                         |
| Timer and Watchdog            | pal_timer_wd.c                     |
| Peripherals (UART and Memory) | pal_peripherals.c                  |
| DMA                           | pal_dma.c                          |
| MPAM                          | pal_mpam.c                         |
| PMU                           | pal_pmu.c                          |
| RAS                           | pal_ras.c                          |
| HMAT                          | pal_hmat.c                         |
| Miscellaneous                 | pal_misc.c                         |



PAL implementation requires porting when the underlying platform design changes.

## 3. Execution of SBSA ACS

This chapter provides information on the execution of the SBSA ACS on a full-chip SoC emulation environment.

## 3.1 SoC emulation environment

Executing SBSA ACS on a full-chip emulation environment requires implementation of PAL. This involves providing a collection of SoC-specific information such as capabilities, base addresses, IRQ numbers to the test logic.

In Unified Extensible Firmware Interface (UEFI) base systems, all the static information is present in UEFI tables. The PAL implementation which is based on UEFI, uses the generated header file for populating data structures. For a bare-metal system, this information must be supplied in a tabular format which becomes easy for PAL API implementation.

#### 3.1.1 PE

This section provides information on the number of PEs in the system.

#### PE-specific information

Tests contain comparison of Multiprocessor ID Register (MPIDR) values with actual values read from register. Such interrupts are generated for the Performance Monitoring Unit (PMU) lines and tested.

#### PLATFORM\_OVERRIDE\_PEx\_MPIDR:

MPIDR register value represents the xth PE hierarchy (cluster, core).

#### PLATFORM\_OVERRIDE\_PEx\_INDEX:

Represents the xth PE.

#### PLATFORM\_OVERRIDE\_PEx\_PMU\_GSIV:

PMU interrupt number for xth PE.

A platform with eight PEs is populated as follows:

| #define PLATFORM_OVERRIDE_PE_CNT                                                                                          | 0x8                  |
|---------------------------------------------------------------------------------------------------------------------------|----------------------|
| #define PLATFORM_OVERRIDE_PE0_INDEX                                                                                       | 0x0                  |
| #define PLATFORM_OVERRIDE_PE0_MPIDR                                                                                       | 0x0                  |
| #define PLATFORM_OVERRIDE_PE0_PMU_GSIV                                                                                    | 0x17                 |
| <pre>#define PLATFORM_OVERRIDE_PE1_INDEX #define PLATFORM_OVERRIDE_PE1_MPIDR #define PLATFORM_OVERRIDE_PE1_PMU_GSIV</pre> | 0x1<br>0x100<br>0x17 |
| #define PLATFORM_OVERRIDE_PE2_INDEX                                                                                       | 0x2                  |
| #define PLATFORM_OVERRIDE_PE2_MPIDR                                                                                       | 0x200                |

```
#define PLATFORM OVERRIDE PE2 PMU GSIV 0x17
#define PLATFORM_OVERRIDE_PE3_INDEX
#define PLATFORM_OVERRIDE_PE3_MPIDR
                                              0x3
                                              0x300
#define PLATFORM OVERRIDE PE3 PMU GSIV 0x17
#define PLATFORM OVERRIDE PE4 INDEX
                                              0x4
#define PLATFORM OVERRIDE PE4 MPIDR
                                              0x10000
#define PLATFORM OVERRIDE PE4 PMU GSIV 0x17
#define PLATFORM OVERRIDE PE5 INDEX
                                             0x5
#define PLATFORM OVERRIDE PE5 MPIDR
                                             0x10100
#define PLATFORM OVERRIDE PE5 PMU GSIV 0x17
#define PLATFORM OVERRIDE PE6 INDEX
                                              0×6
#define PLATFORM OVERRIDE PE6 MPIDR
                                             0x10200
#define PLATFORM OVERRIDE PE6 PMU GSIV 0x17
#define PLATFORM OVERRIDE PE7 INDEX
                                              0 \times 7
#define PLATFORM_OVERRIDE_PE7_MPIDR 0x10
#define PLATFORM_OVERRIDE_PE7_PMU_GSIV 0x17
                                              0x10300
```

Header file representation:

```
typedef struct {
uint32 t num of pe;
} PE \overline{INFO} HDR;
Obrief structure instance for PE entry
typedef struct {
 uint32_t pe_num;
uint32_t attr;
                                            /* PE Index */
 uint32_t attr;
uint64_t mpidr;
                                            /* PE attributes */
                                            /* PE MPIDR */
 /* GIC Maintenance Interrupt */
/* ACPI Processor UID */
cache_info_table */
uint32_t trbe_interrupt;
}PE_INFO_ENTRY;
                                            /* TRBE Interrupt */
typedef struct {
PE INFO HDR header;
PE INFO ENTRY pe info[];
} PE INFO TABLE;
```

## SMBIOS-specific information

The parameters required for SMBIOS with reference values are as follows:

```
#define PLATFORM_OVERRIDE_SMBIOS_SLOT_COUNT 0x1
#define PLATFROM_OVERRIDE_SMBIOS_SLOT0_FAMILY 0x102
#define PLATFROM_OVERRIDE_SMBIOS_SLOT0_CORE_COUNT 16
```

```
typedef struct {
uint16_t processor_family;
uint16_t core_count;
} PE_SMBIOS_TYPE4_INFO;
```

```
typedef struct {
  uint32_t slot_count;
PE_SMBIOS_TYPE4_INFO type4_info[];
} FE_SMBIOS_PROCESSOR_INFO_TABLE;
```

#### 3.1.1.1 Cache configuration

This section provides information on the cache info for each PE:

#### 3.1.2 PCle

This section provides information on the number of Peripheral Component Interconnect express (PCle) root ports and the information required for PCle enumeration.

```
#define PLATFORM OVERRIDE PCIE ECAMO HB COUNT 1

#define PLATFORM OVERRIDE PCIE ECAMO SEG NUM 0x0

#define PLATFORM OVERRIDE PCIE ECAMO START BUS NUM 0x0

#define PLATFORM OVERRIDE PCIE ECAMO END BUS NUM 0x8

#define PLATFORM OVERRIDE PCIE ECAMO EP BAR64 0x4000100000

#define PLATFORM OVERRIDE PCIE ECAMO RP BAR64 0x4000000000

#define PLATFORM OVERRIDE PCIE ECAMO EP NPBAR32 0x60000000

#define PLATFORM OVERRIDE PCIE ECAMO EP PBAR32 0x60600000

#define PLATFORM OVERRIDE PCIE ECAMO RP BAR32 0x60850000
```

#### PLATFORM OVERRIDE PCIE ECAMx EP BAR64:

The address required for 64-bit Prefetchable Memory Base for an PCle End Point.

#### PLATFORM\_OVERRIDE\_PCIE\_ECAMx\_RP\_BAR64:

The address required for 64-bit Prefetchable Memory Base for PCle Type 1 devices.

#### PLATFORM\_OVERRIDE\_PCIE\_ECAMx\_EP\_NPBAR32:

The address required for 32-bit Non-Prefetchable Memory Base for an PCle End Point.

#### PLATFORM\_OVERRIDE\_PCIE\_ECAMx\_EP\_PBAR32:

The address required for 32-bit Prefetchable Memory Base for an PCle End Point.

#### PLATFORM\_OVERRIDE\_PCIE\_ECAMx\_RP\_BAR32:

The address required for 32-bit Memory Base for a PCle Type 1 devices.

Parameters required for the PCle enumeration for a platform is populated as follows:

#### PLATFORM\_OVERRIDE\_NUM\_ECAM:

Represents the number of Enhanced Configuration Access Mechanism (ECAM) regions in the system.

#### PLATFORM\_MAX\_HB\_COUNT:

Represents the maximum number of Host bridges in the system..

#### PLATFORM\_OVERRIDE\_PCIE\_ECAM\_BASE\_ADDR\_x:

ECAM base address: ECAM maps PCIe configuration space to a memory address. The memory address to the current configuration space must be provided here.

#### PLATFORM\_OVERRIDE\_PCIE\_SEGMENT\_GRP\_NUM\_x:

Segment number of the xth ECAM region.

#### PLATFORM\_OVERRIDE\_PCIE\_START\_BUS\_NUM\_x:

Starting bus number of the xth ECAM region.

#### PLATFORM\_OVERRIDE\_PCIE\_END\_BUS\_NUM\_x:

Ending bus number of the xth ECAM region.

A platform with one ECAM region is populated as follows:

```
/* PCIE platform config parameters */
#define PLATFORM_OVERRIDE_NUM_ECAM 1

/* Platform config parameters for ECAM_0 */
#define PLATFORM_OVERRIDE_PCIE_ECAM_BASE_ADDR_0 0x60000000
#define PLATFORM_OVERRIDE_PCIE_SEGMENT_GRP_NUM_0 0x0
#define PLATFORM_OVERRIDE_PCIE_START_BUS_NUM_0 0x0
#define PLATFORM_OVERRIDE_PCIE_END_BUS_NUM_0 0xff
```

Header file representation:

```
typedef struct {
  uint64_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;

typedef struct {
  uint32_t num_entries;
  PCIE_INFO_BLOCK block[];
} PCIE_INFO_TABLE;</pre>
```

#### 3.1.2.1 PCIE device hierarchy table

This hierarchy table is used to obtain platform-specific support such as DMA, P2P and so on.

Parameters to be populated for each PCIe device is as follows:

```
PLATFORM_PCIE_DEVx_CLASSCODE 0x6040000
PLATFORM_PCIE_DEVx_VENDOR_ID 0x13B5
PLATFORM_PCIE_DEVx_DEV_ID 0xDEF
PLATFORM_PCIE_DEVx_BUS_NUM 0
```

```
PLATFORM PCIE DEVx DEV NUM 1
PLATFORM PCIE DEVx FUNC NUM 0
PLATFORM PCIE DEVx SEG NUM 0
PLATFORM PCIE DEVx DMA SUPPORT 0
PLATFORM PCIE DEVx DMA COHERENT 0
PLATFORM PCIE DEVx P2P SUPPORT 1
PLATFORM PCIE DEVx DMA 64BIT 0
PLATFORM PCIE DEVx BEHIND SMMU 1
PLATFORM PCIE DEVx ATC SUPPORT 0
```

Header file representation:

```
typedef struct {
  uint64_t class_code;
  uint32_t device_id;
  uint32_t vendor_id;
  uint32_t bus;
  uint32_t dev;
  uint32_t func;
  uint32_t func;
  uint32_t dma_support;
  uint32_t dma_coherent;
  uint32_t dma_fotherent;
  uint32_t dma_fotherent;
  uint32_t dma_fotherent;
  uint32_t dma_fotherent;
  uint32_t dma_fotherent;
  uint32_t dma_fotherent;
  PERIPHERAL_IRQ_MAP irq_map;
} PCIE_READ_BLOCK;
```

#### 3.1.3 DMA

This section provides the configuration options for Direct Memory Access (DMA) controller-based tests. Additionally, it describes the parameters for the number of DMA bus Requesters, and DMA Requester attributes that can be customized.

#### 3.1.3.1 Number of DMA controllers

Header file representation:

```
#define PLATFORM_OVERRIDE_DMA_CNT 0
```

#### PLATFORM\_OVERRIDE\_DMA\_CNT:

Represents the number of DMA controllers in the system.

#### 3.1.3.2 DMA Requester attributes

```
uint32_t flags;
}DMA_INFO_BLOCK;
```

The actual information stored in the above pointers are implementation-specific.

#### 3.1.4 SMMU and device tests

This section provides an overview on SMMU and the device tests. It also provides information on the number of IOVIRT nodes, SMMUs, RC, Named component, PMCG, ITS blocks, I/O virtualization node-specific information, SMMU node-specific information, RC-specific information, and I/O virtual address mapping.

#### 3.1.4.1 Number of IOVIRT Nodes

Parameters to be filled are:

```
#define IORT NODE COUNT 0x13
```

#### IORT\_NODE\_COUNT:

Represents the total number of Root Complex (RC), SMMU, ITS, PMCG, and other nodes represented in IORT structure.

#### 3.1.4.2 Number of SMMUs

Parameters to be filled are:

```
#define IOVIRT SMMUV3 COUNT 5
```

```
#define IOVIRT_SMMUV2_COUNT 0
```

#### SMMU\_COUNT:

Represents the number of SMMUs in the system.

#### 3.1.4.3 Number of RCs

Parameters to be filled are:

```
#define RC_COUNT 0x1
```

#### RC\_COUNT:

Represents the number of RCs present in the system.

#### 3.1.4.4 Number of PMCGs

Parameters to be filled are:

```
#define PMCG_COUNT 0x1
```

#### PMCG\_COUNT:

Represents the number of Performance Monitor Counter Groups (PMCGs) present in the system.

### 3.1.4.5 Number of named components

Parameters to be filled are:

```
#define IOVIRT_NAMED_COMPONENT_COUNT 2
```

#### IOVIRT\_NAMED\_COMPONENT\_COUNT

Represents the number of named components present in the system.

### 3.1.4.6 Number of ITS blocks

Parameters to be filled are:

```
#define IOVIRT_ITS_COUNT 0x1
```

#### IOVIRT\_ITS\_COUNT:

Represents the number of Interrupt Translation Service (ITS) nodes in the system.

### 3.1.4.7 I/O virtualization node-specific information

```
typedef struct {
uint32_t type;
uint32_t num_data_map;
NODE_DATA_data;
uint32_t flags;
NODE_DATA_MAP_data_map[];
}IOVIRT_BLOCK;

typedef union {
char name[MAX_NAMED_COMP_LENGTH];
IOVIRT_RC_INFO_BLOCK_rc;
IOVIRT_PMCG_INFO_BLOCK_pmcg;
uint32_t its_count;
SMMU_INFO_BLOCK_smmu;
}NODE_DATA;
```

#### 3.1.4.8 SMMU node-specific information

Header file representation:

#### IOVIRT\_SMMUV3\_BASE\_ADDRESS:

Represents the SMMU base address in the system.

#### 3.1.4.9 Root Complex node specific information

Header file representation:

### 3.1.4.10 PMCG node-specific information

Header file representation:

```
typedef struct {
uint64_t base;
uint32_t overflow_gsiv;
uint32_t node_ref;
} IOVIRT_PMCG_INFO_BLOCK;
```

## 3.1.4.11 Named component node specific information

Header file representation:

```
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;
```

### Named component-specific information on Coresight components

```
typedef struct {
char identifier[MAX_CS_COMP_LENGTH]; // Hardware ID for Coresight ARM
implementations
```

```
char dev_name[MAX_CS_COMP_LENGTH]; // Device name of Coresight components
} PLATFORM_OVERRIDE_CORESIGHT_COMP_INFO_BLOCK;

typedef struct {
PLATFORM_OVERRIDE_CORESIGHT_COMP_INFO_BLOCK component[CS_COMPONENT_COUNT];
} PLATFORM_OVERRIDE_CS_COMP_NODE_DATA;
```

### 3.1.4.12 I/O virtual address mapping

Header file representation:

```
typedef struct {
  uint32_t input_base;
  uint32_t id_count;
  uint32_t output_base;
  uint32_t output_ref;
}ID_MAP;
```

#### 3.1.5 GIC

This section provides the parameters for Generic Interrupt Controller (GIC) specific test.

#### **GIC-specific tests**

Parameters to be filled are:

```
#define PLATFORM OVERRIDE GICD COUNT
                                                            0x1
#define PLATFORM OVERRIDE GICRD COUNT
                                                            0x1
#define PLATFORM_OVERRIDE_GICITS_COUNT
#define PLATFORM_OVERRIDE_GICH_COUNT
                                                            0x1
                                                            0x1
#define PLATFORM OVERRIDE GICMSIFRAME COUNT 0x0
#define PLATFORM_OVERRIDE_GICC_TYPE
#define PLATFORM_OVERRIDE_GICD_TYPE
#define PLATFORM_OVERRIDE_GICC_GICRD_TYPE
                                                            0x1000
                                                            0x1001
                                                           0x1002
#define PLATFORM_OVERRIDE_GICR_GICRD_TYPE
                                                           0x1003
#define PLATFORM_OVERRIDE_GICITS_TYPE 0x1004
#define PLATFORM_OVERRIDE_GICMSIFRAME_TYPE 0x1005
#define PLATFORM OVERRIDE GICH TYPE
                                                           0x1006
#define PLATFORM_OVERRIDE_GICC_BASE
#define PLATFORM_OVERRIDE_GICD_BASE
                                                            0x30000000
                                                           0x30000000
#define PLATFORM OVERRIDE GICRD BASE
                                                           0x300C0000
#define PLATFORM_OVERRIDE_GICITS_BASE
                                                            0x30040000
#define PLATFORM_OVERRIDE_GICH_BASE
#define PLATFORM_OVERRIDE_GICITS_ID
                                                            0x2C010000
#define PLATFORM OVERRIDE GICIRD LENGTH
                                                            (0x20000*8)
```

```
typedef struct {
  uint32_t gic_version;
  uint32_t num_gicc;
  uint32_t num_gicd;
  uint32_t num_gicrd;
  uint32_t num_gicits;
  uint32_t num_gich;
  uint32_t num_siframes;
  uint32_t gicc_type;
  uint32_t gicd_type;
  uint32_t gicrd_type;
```

```
uint32_t gicrd_length;
uint32_t gicits_type;
uint64_t gicc_base[PLATFORM_OVERRIDE_GICC_COUNT];
uint64_t gicd_base[PLATFORM_OVERRIDE_GICD_COUNT];
uint64_t gicrd_base[PLATFORM_OVERRIDE_GICRD_COUNT];
uint64_t gicits_base[PLATFORM_OVERRIDE_GICTTS_COUNT];
uint64_t gicits_id[PLATFORM_OVERRIDE_GICTTS_COUNT];
uint64_t gich_base[PLATFORM_OVERRIDE_GICH_COUNT];
uint64_t gicm_siframe_base[PLATFORM_OVERRIDE_GICMSIFRAME_COUNT];
uint64_t gicm_siframe_id[PLATFORM_OVERRIDE_GICMSIFRAME_COUNT];
uint32_t gicm_siframe_flags[PLATFORM_OVERRIDE_GICMSIFRAME_COUNT];
uint32_t gicm_siframe_spi_count[PLATFORM_OVERRIDE_GICMSIFRAME_COUNT];
uint32_t gicm_siframe_spi_base[PLATFORM_OVERRIDE_GICMSIFRAME_COUNT];
uint32_t gicm_siframe_spi_base[PLATFORM_OVERRIDE_GICMSIFRAME_COUNT];
} PLATFORM_OVERRIDE_GIC_INFO_TABLE;
```

#### 3.1.6 Timer

This section provides the parameters for timer-specific tests.

#### 3.1.6.1 Timer information

Parameters to be filled are:

```
#define PLATFORM_OVERRIDE_PLATFORM_TIMER_COUNT  0x2
#define PLATFORM_OVERRIDE_S_EL1_TIMER_GSIV  0x1D
#define PLATFORM_OVERRIDE_NS_EL1_TIMER_GSIV  0x1E
#define PLATFORM_OVERRIDE_NS_EL2_TIMER_GSIV  0x1A
#define PLATFORM_OVERRIDE_VIRTUAL_TIMER_GSIV  0x1B
#define PLATFORM_OVERRIDE_EL2_VIR_TIMER_GSIV  28
```

```
typedef struct {
uint32 t s el1 timer flag;
uint32 t ns ell timer flag;
uint32 t el2 timer flag;
uint32 t el2 virt timer flag;
uint32 t s el1 timer gsiv;
uint32 t ns ell timer gsiv;
uint32_t el2_timer_gsiv;
uint32_t virtual_timer_flag;
uint32 t virtual timer qsiv;
uint32_t e12_virt_timer_gsiv;
uint32_t num_platform_timer;
uint32_t num_watchdog;
uint32_t sys_timer_status;
}TIMER_INFO_HDR;
typedef struct {
uint32_t type;
uint32_t timer_count;
uint64 t block cntl base;
uint8 t frame num[8];
uint64 t GtCnTBase[8];
uint64 t GtCntEl0Base[8];
uint32 t gsiv[8];
uint32_t virt_gsiv[8];
uint32_t flags[8];
}TIMER INFO GTBLOCK;
```

```
typedef struct {
TIMER_INFO_HDR header;
TIMER_INFO_GTBLOCK gt_info[];
}TIMER_INFO_TABLE;
```

## 3.1.7 Watchdog timer

This section provides the parameters for the number of watchdog timer tests and watchdog information.

Parameters to be filled are:

```
#define PLATFORM_OVERRIDE_WD_TIMER_COUNT 2
```

## 3.1.7.1 Watchdog information

The following is the list of watchdog timers present in the system:

- Watchdog timer number
- Control base
- Refresh base
- Interrupt number
- Flags

Header file representation:

## **3.1.8** Memory

This section provides information on the memory map in the system.

#### PLATFORM\_OVERRIDE\_MEMORY\_ENTRY\_COUNT:

Represents the number of memory range entries.

#### PLATFORM\_OVERRIDE\_MEMORY\_ENTRYx\_PHY\_ADDR:

Represents the physical address of the xth memory entry.

#### PLATFORM\_OVERRIDE\_MEMORY\_ENTRYx\_VIRT\_ADDR:

Represents the virtual address of the xth memory entry.

#### PLATFORM\_OVERRIDE\_MEMORY\_ENTRYx\_SIZE:

Represents the size of the xth memory entry.

#### PLATFORM\_OVERRIDE\_MEMORY\_ENTRYx\_TYPE:

Represents the type of the xth memory entry.

The following is an example for memory map.

```
#define PLATFORM_OVERRIDE_MEMORY_ENTRY_COUNT
#define PLATFORM_OVERRIDE_MEMORY_ENTRYO PHY ADDR
                                                                    0 \times 4
                                                                    0xC000000
#define PLATFORM OVERRIDE MEMORY ENTRYO VIRT ADDR 0xC000000
                                                                    0x4000000
#define PLATFORM OVERRIDE MEMORY ENTRYO SIZE
#define PLATFORM OVERRIDE MEMORY ENTRYO TYPE #define PLATFORM OVERRIDE MEMORY ENTRY1 PHY ADDR
                                                                   MEMORY_TYPE_DEVICE 0x10000000
#define PLATFORM OVERRIDE MEMORY ENTRY1 VIRT ADDR 0x10000000
#define PLATFORM OVERRIDE MEMORY ENTRY1 SIZE #define PLATFORM OVERRIDE MEMORY ENTRY1 TYPE
                                                             0xC17uuuu
MEMORY_TYPE_NOT_POPULATED
                                                                    0xC170000
#define PLATFORM OVERRIDE MEMORY ENTRY2 PHY ADDR
                                                                   0xFF600000
#define PLATFORM OVERRIDE MEMORY ENTRY2 VIRT ADDR 0xfF600000 #define PLATFORM OVERRIDE MEMORY ENTRY2 SIZE 0x10000
#define PLATFORM OVERRIDE MEMORY ENTRY2
                                                                    0x10000
#define PLATFORM OVERRIDE MEMORY ENTRY2 TYPE
                                                                   MEMORY TYPE RESERVED
#define PLATFORM OVERRIDE MEMORY ENTRY3 PHY ADDR
                                                                   0x8000<del>0</del>000
#define PLATFORM OVERRIDE MEMORY ENTRY3 VIRT ADDR
#define PLATFORM OVERRIDE MEMORY ENTRY3 SIZE
                                                                   0x80000000
                                                                    0×7F000000
#define PLATFORM OVERRIDE MEMORY ENTRY3 TYPE
                                                                   MEMORY TYPE NORMAL
```

Header file representation:

```
typedef struct {
    MEM_INFO_TYPE_e type;
    uint64_t phy_addr;
    uint64_t virt_addr;
    uint64_t size;
    uint64_t flags; //To Indicate Cacheablility etc..
}MEM_INFO_BLOCK;
```

#### 3.1.9 MPAM

This section provides information on the Memory System Resource Partitioning and Monitoring of the system.

Parameters to be filled are:

```
#define MPAM MAX MSC NODE
                                                        0 \times 1
#define MPAM MAX RSRC NODE
                                                        0x1
#define PLATFORM MPAM MSC COUNT
                                                        0 \times 1
                                                       0x1010028000
#define PLATFORM MPAM MSCx BASE ADDR
#define PLATFORM MPAM MSCx ADDR LEN #define PLATFORM MPAM MSCx MAX NRDY
                                                       0x2004
                                                        10000000
#define PLATFORM MPAM MSCx RSRC COUNT
                                                       0 \times 1
#define PLATFORM MPAM MSCx RSRCx RIS INDEX
                                                        0 \times 0
#define PLATFORM MPAM MSCx RSRCx LOCATOR TYPE
                                                        0x1
#define PLATFORM MPAM MSCx RSRCx DESCRIPTOR1
                                                        0x0
#define PLATFORM MPAM MSCx RSRCx DESCRIPTOR2
```

#### Header file representation:

```
* @brief Mpam Resource Node
typedef struct {
uint8_t ris_index;
uint8_t locator_type;
                                             /* Identifies location of this resource */
uint64_t descriptor1;
uint32_t descriptor2;
                                            /* Primary acpi description of location */
                                             /* Secondary acpi description of location */
} MPAM RESOURCE NODE;
* @brief Mpam MSC Node
typedef struct {
    subspace ID based on interface type. */
    uint32_t msc_addr_len; /* MSC mem map size */
uint32_t max_nrdy; /* max time in microseconds that MSC not ready
after config change */
    after config change */
uint32_t rsrc_count; /* number of resource nodes */
MPAM_RESOURCE_NODE rsrc_node[]; /* Details of resource node */
} MPAM MSC NODE;
* @brief Mpam info table
typedef struct {
                                    /* Number of MSC node */
/* Details of MSC node */
uint32 t msc count;
MPAM MSC NODE msc node[];
} MPAM INFO TABLE;
```

#### 3.1.9.1 SRAT

This section provides information on the System Affinity table of the system.

Parameters to be filled are:

```
#define PLATFORM_OVERRIDE_NUM_SRAT_ENTRIES 17
#define PLATFORM_OVERRIDE_MEM_AFF_CNT 1
#define PLATFORM_OVERRIDE_GICC_AFF_CNT 16
```

The memory affinity and GICC Affinity parameters to be filled are:

```
#define PLATFORM SRAT MEMx PROX DOMAIN 0x0
#define PLATFORM SRAT MEMx FLAGS 0x1
#define PLATFORM SRAT MEMx ADDR BASE 0x8080000000
#define PLATFORM SRAT MEMx ADDR LEN 0x3F7F7FFFFF
#define PLATFORM SRAT GICCx PROX DOMAIN 0x0
#define PLATFORM SRAT GICCx PROC UID 0x0
#define PLATFORM SRAT GICCx FLAGS 0x1
#define PLATFORM SRAT GICCx CLK DOMAIN 0x0
```

#### Header file representation:

```
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_ENTRY srat_info[];
} SRAT_INFO_TABLE;
```

#### 3.1.9.2 PCC

Parameters to be filled are:

Following fields follow generic\_address\_structure defined in platform\_override\_sbsa\_struct.h

```
#define PLATFORM_PCC_SUBSPACE0_DOORBELL_REG {0x0, 0x0, 0x0, 0x0, 0x0eADDEAD}
#define PLATFORM_PCC_SUBSPACE0_CMD_COMPLETE_UPDATE_REG {0x0, 0x0, 0x0, 0x0, 0x0, 0xDEADDEAD}
#define PLATFORM_PCC_SUBSPACE0_CMD_COMPLETE_CHK_REG {0x0, 0x0, 0x0, 0x0, 0x0eADDEAD}
```

```
uint32_t min_req_turnaround_usec;
                                                     /* minimum request turnaround
 time \overline{*}/
GENERIC ADDRESS STRUCTURE cmd complete chk req; /* command complete check
 register */
uint64 t cmd complete chk mask;
                                                      /* command complete check mask */
GENERIC_ADDRESS_STRUCTURE cmd_complete_update_reg; /* command complete update
 register */
uint64_t cmd_complete_update_preserve;
                                                     /* command complete update
preserve */
uint64_t cmd_complete_update_set;
mask */
                                                    /* command complete update set
} PLATFORM OVERRIDE PCC SUBSPACE TYPE 3;
typedef union {
PLATFORM_OVERRIDE_PCC_SUBSPACE_TYPE_3 pcc_ss_type_3; /* PCC type 3 info */
} PLATFORM OVERRIDE PCC TYPE SPECIFIC INFO;
typedef struct {
uint32 t subspace idx;
                                                       /* PCC subspace index in PCCT
ACPI table */
uint32 t subspace type;
                                                       /* type of PCC subspace */
PLATFORM OVERRIDE PCC TYPE SPECIFIC INFO
type_spec_info;
                                                       /* PCC subspace type specific
 info */
} PLATFORM OVERRIDE PCC INFO;
typedef struct {
                                                       /* number of PCC subspace info
uint32 t subspace cnt;
stored */
PLATFORM_OVERRIDE_PCC_INFO pcc_info[PLATFORM_PCC_SUBSPACE_COUNT];
/* array of PCC info blocks */
} PLATFORM OVERRIDE PCC INFO TABLE;
```

#### 3.1.10 HMAT

This sections provides information on the Heterogeneous Memory Attribute Table

Parameters required to be populated are:

```
} HMAT_INFO_TABLE;
```

#### 3.1.11 RAS

This section provides Information on the Reliability, Availability and Serviceability features of the system.

Parameters to be filled are:

```
#define PLATFORM_OVERRIDE_NUM_RAS_NODES 0x1
#define PLATFORM_OVERRIDE_NUM_PE_RAS_NODES 0x1
#define PLATFORM_OVERRIDE_NUM_MC_RAS_NODES 0x0
#define RAS2_MAX_NUM_BLOCKS 0x4
```

Header file representation:

```
typedef struct {
RAS NODE TYPE e type;
                                                     /* Node Type PE/GIC/SMMU */
uint16 t length;
                                                     /* Length of the Node */
                                                    /* Number of Interrupt Entry */
uint64_t num_intr_entries;
RAS NODE DATA node data;
RAS INTERFACE INFO intf info;
RAS INTERRUPT INFO intr info[2];
                                                    /* Node Specific Data */
/* Node Interface Info */
                                                    /* Node Interrupt Info */
} RAS NODE INFO;
typedef struct {
uint32_t num_nodes;
uint32_t num_pe_node;
uint32_t num_mc_node;
                                                     /* Number of total RAS Nodes */
                                                     /* Number of PE RAS Nodes */
                                                     /* Number of Memory Controller Nodes */
RAS NODE INFO node[];
                                                     /* Array of RAS nodes */
} RAS INFO TABLE;
typedef struct {
RAS2_FEAT_TYPE type;
RAS2_BLOCK_INFO block_info;
                                                     /* RAS2 feature type*/
                                                     /* RAS2 block info */
} RA$Z 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 INFO TABLE;
```

#### 3.1.12 PMU

This section provides Information on the Performance Monitoring Unit of the system.

Parameters to be filled are:

```
#define MAX_NUM_OF_PMU_SUPPORTED 512
#define PLATFORM_OVERRIDE_PMU_NODE_CNT 0x1
#define PLATFORM_PMU_NODEx_BASE0 0x1010028000
#define PLATFORM_PMU_NODEx_BASE1 0x0
```

```
#define PLATFORM_PMU_NODEx_TYPE 0x2
#define PLATFORM_PMU_NODEx_PRI_INSTANCE 0x0
#define PLATFORM_PMU_NODEx_SEC_INSTANCE 0x0
#define PLATFORM_PMU_NODEx_DUAL_PAGE_EXT 0x0
```

Header file representation:

```
typedef struct {
uint8 t type;
                                   /* The component that this PMU block is
associated with*/
uint64_t primary_instance;
type*/
                                    /* Primary node instance, specific to the PMU
uint32 t secondary instance;
                                    /* Secondary node instance, specific to the PMU
type*7
                                    /* Support of the dual-page mode*/
uint8_t dual_page_extension;
uint6\overline{4} t base\overline{60};
                                    /* Base address of Page 0 of the PMU*/
                                    /* Base address of Page 1 of the PMU,
uint64 t base1;
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.1.13 MMU Configuration

This section provides information on the MMU for the PE MMU.

The parameters required for the PE MMU are populated as follows:

```
#define PLATFORM_PAGE_SIZE 0x1000
#define PLATFORM_OVERRIDE_MMU_PGT_IAS 48
#define PLATFORM_OVERRIDE_MMU_PGT_OAS 48
```

## 3.1.14 Peripherals

This section provides information on the peripherals in the system.

Parameters to be filled are:

```
#define PLATFORM OVERRIDE PERIPHERAL COUNT 3 //UART + USB + SATA
#define UART_ADDRESS 0xF98DFE18
#define BASE_ADDRESS_ADDRESS_SPACE_ID
                                                                   0 \times 0
#define BASE ADDRESS REGISTER BIT WIDTH
                                                                  0x20
#define BASE ADDRESS REGISTER BIT OFFSET 0x0
#define BASE ADDRESS ADDRESS SIZE 0x3
#define BASE ADDRESS ADDRESS 0x2
                                                                  0x2A400000
#define UART_BAUD_RATE
#define UART_CLK_RATE_HZ
#define UART_INTERRUPT_TYPE
                                                                  115200
                                                                  48000000
#define UART IRQ
                                                                   0
#define UART_GLOBAL_SYSTEM_INTERRUPT #define UART_PCI_DEVICE_ID
                                                                   0x70
                                                                   0xFFFF
#define UART PCI VENDOR ID
                                                                   0xFFFF
#define UART_PCI_BUS_NUMBER
#define UART_PCI_DEV_NUMBER
                                                                   0 \times 0
                                                                   0x0
```

| <pre>#define UART_PCI_FUNC_NUMBER #define UART_PCI_FLAGS #define UART_PCI_SEGMENT</pre> | 0x0<br>0x0<br>0x0 |  |
|-----------------------------------------------------------------------------------------|-------------------|--|
|-----------------------------------------------------------------------------------------|-------------------|--|



Ensure that the BASE\_ADDRESS\_ADDRESS, UART\_BAUD\_RATE, and UART\_CLK\_RATE\_HZ are configured properly to get PL011 UART prints on the console.

## 3.2 Bare-metal Boot

This section provides information on the Bare-metal boot requirements of the system.

The following system-specific definitions must be filled to load bootable image.

Parameters to be filled are:

For more information on how to run SBSA ACS with bootwrapper code, see the README.



PLATFORM\_NORMAL\_WORLD\_IMAGE\_BASE is the entry point to BL33.

## 4. Porting requirements

This chapter provides information on different PAL APIs in PE, GIC, timer, IOVIRT, PCIe, SMMU, peripheral, DMA, PMU, MPAM, RAS, exerciser, and other miscellaneous APIs.

## 4.1 PAL implementation

PAL is a C-based, Arm-defined API that you can implement. Each test platform requires a PAL implementation of its own.

The bare-metal reference code provides a reference implementation for a subset of APIs. Additional code must be implemented to match the target SoC implementation under the tests.

There are two implementation types for the PAL APIs and are classified in the following tables:



- Yes: indicates that the implementation of this API is already present. Since the values are platform-specific, it must be taken from the platform configuration file
- Platform-specific: you must implement all the APIs that are marked as platform-specific.

#### 4.1.1 PE

The following table lists the different types of APIs in PE.

Table 4-1: PE APIs and their details

| API name             | Function prototype                                                                              | Implementation        |
|----------------------|-------------------------------------------------------------------------------------------------|-----------------------|
| create_info_table    | <pre>void pal_pe_create_info_table(PE_INFO_TABLE *PeTable);</pre>                               | Yes                   |
| call_smc             | <pre>void pal_pe_call_smc(ARM_SMC_ARGS *args);</pre>                                            | Yes                   |
| execute_payload      | <pre>void pal_pe_execute_payload(ARM_SMC_ARGS *args);</pre>                                     | Yes                   |
| update_elr           | <pre>void pal_pe_update_elr(void *context,uint64_toffset);</pre>                                | Platform-<br>specific |
| get_esr              | <pre>uint64_t pal_pe_get_esr(void *context);</pre>                                              | Platform-<br>specific |
| data_cache_ops_by_va | <pre>void pal_pe_data_cache_ops_by_va(uint64_t addr, uint32_t type);</pre>                      | Yes                   |
| get_far              | <pre>uint64_t pal_pe_get_far(void *context);</pre>                                              | Platform-<br>specific |
| install_esr          | <pre>uint32_t pal_pe_install_esr(uint32_t exception_type, void(*esr) (uint64_t, void *));</pre> | Platform-<br>specific |
| get_num              | uint32_t pal_pe_get_num();                                                                      | Yes                   |

| API name         | Function prototype | Implementation        |
|------------------|--------------------|-----------------------|
| psci_get_conduit |                    | Platform-<br>specific |

## 4.1.2 GIC

The following table lists the different types of APIs in GIC.

Table 4-2: GIC APIs and their details

| API name            | Function prototype                                                                                        | Implementation        |
|---------------------|-----------------------------------------------------------------------------------------------------------|-----------------------|
| create_info_table   | <pre>void pal_gic_create_info_table(GIC_INFO_TABLE* gic_info_table);</pre>                                | Yes                   |
| install_isr         | <pre>uint32_t pal_gic_install_isr(uint32_t int_id, void(*isr)(void));</pre>                               | Platform-<br>specific |
| end_of_interrupt    | <pre>uint32_t pal_gic_end_of_interrupt(uint32_t int_id);</pre>                                            | Platform-<br>specific |
| request_irq         | <pre>uint32_t pal_gic_request_irq(unsigned intirq_num, unsigned int mapped_<br/>irq_num,void *isr);</pre> | Platform-<br>specific |
| free_irq            | <pre>void pal_gic_free_irq(unsigned int irq_num,unsigned int mapped_<br/>irq_num);</pre>                  | Platform-<br>specific |
| set_intr_trigger    | <pre>uint32_t pal_gic_set_intr_trigger(uint32_t int_idINTR_TRIGGER_<br/>INFO_TYPE_etrigger_type);</pre>   | Platform-<br>specific |
| get_num_nongic_ctrl | <pre>uint32_t pal_get_num_nongic_ctrl(void);</pre>                                                        | Platform-<br>specific |

## 4.1.3 Timer

The following table lists the different types of APIs in timer.

Table 4-3: Timer APIs and their details

| API name              | Function prototype                                                                | Implementation |
|-----------------------|-----------------------------------------------------------------------------------|----------------|
|                       | <pre>void pal_timer_create_info_table(TIMER_INFO_TABLE *timer_ info_table);</pre> | Yes            |
| wd_create_info_table  | <pre>void pal_wd_create_info_table(WD_INFO_TABLE *wd_table);</pre>                | Yes            |
| get_counter_frequency | <pre>uint64_t pal_timer_get_counter_frequency(void);</pre>                        | Yes            |

#### **4.1.4 IOVIRT**

The following table lists the different types of APIs in IOVIRT.

Table 4-4: IOVIRT APIs and their details

| API name             | Function prototype                                                       | Implementation |
|----------------------|--------------------------------------------------------------------------|----------------|
| create_info_table    | <pre>void pal_iovirt_create_info_table(IOVIRT_INFO_TABLE *iovirt);</pre> | Yes            |
| unique_rid_strid_map | <pre>uint32_t pal_iovirt_unique_rid_strid_map(uint64_t rc_block);</pre>  | Yes            |

| API name               | Function prototype                                                                                             | Implementation |
|------------------------|----------------------------------------------------------------------------------------------------------------|----------------|
| check_unique_ctx_initd | <pre>uint32_t pal_iovirt_check_unique_ctx_intid(uint64_t smmu_block);</pre>                                    | Yes            |
|                        | <pre>uint64_t pal_iovirt_get_rc_smmu_base(IOVIRT_INFO_TABLE *iovirt, uint32_t rc_seg_num, uint32_t rid);</pre> | Yes            |

## 4.1.5 PCle

The following table lists the different types APIs in PCIe.

Table 4-5: PCIe APIs and their details

| API name           | Function prototype                                                                                                                                    | Implementation        |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| create_info_table  | <pre>void pal_pcie_create_info_table (PCIE_INFO_TABLE *PcieTable);</pre>                                                                              | Yes                   |
| read_cfg           | <pre>uint32_t pal_pcie_read_cfg(uint32_t bdf, uint32_t offset,<br/>uint32_t *data);</pre>                                                             | Yes                   |
| get_msi_vectors    | <pre>uint32_t pal_get_msi_vectors(uint32_t seg,uint32_t bus,<br/>uint32_t dev, uint32_t fn, PERIPHERAL_VECTOR_LIST**mvector);</pre>                   | Platform-<br>specific |
| get_pcie_type      | <pre>uint32_t pal_pcie_get_pcie_type(uint32_t seg,uint32_t bus, uint32_t dev, uint32_t fn);</pre>                                                     | Yes                   |
| p2p_support        | uint32_t pal_pcie_p2p_support(void);                                                                                                                  | Yes                   |
| 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> | Yes                   |
| get_bdf_wrapper    | <pre>uint32_t pal_pcie_get_bdf_wrapper (uint32_t class_code,<br/>uint32_t start_bdf);</pre>                                                           | Yes                   |
| bdf_to_dev         | <pre>void *pal_pci_bdf_to_dev(uint32_t bdf);</pre>                                                                                                    | Yes                   |
| pal_pcie_ecam_base | <pre>uint64_t pal_pcie_ecam_base(uint32_t seg,uint32_t bus,<br/>uint32_t dev, uint32_tfunc)</pre>                                                     | Yes                   |
| pci_cfg_read       | <pre>uint32_t pal_pci_cfg_read(uint32_t bus, uint32_t dev, uint32_<br/>t func, uint32_t offset, uint32_t *value)</pre>                                | Yes                   |
| pci_cfg_write      | <pre>void pal_pci_cfg_write(uint32_t bus, uint32_t dev, uint32_t func, uint32_t offset, uint32_t data)</pre>                                          | Yes                   |
| program_bar_reg    | <pre>void pal_pcie_program_bar_reg(uint32_tbus, uint32_t dev, uint32_t func)</pre>                                                                    | Yes                   |
| enumerate_device   | <pre>uint32_t pal_pcie_enumerate_device(uint32_t bus, uint32_t sec_bus)</pre>                                                                         | Yes                   |
| get_bdf            | <pre>uint32_t pal_pcie_get_bdf(uint32_t ClassCode, uint32_t StartBdf)</pre>                                                                           | Yes                   |
| increment_bus_dev  | uint32_t pal_increment_bus_dev(uint32_t StartBdf)                                                                                                     | Yes                   |
| get_base           | uint64_t pal_pcie_get_base(uint32_t bdf, uint32_t bar_index)                                                                                          | Yes                   |
| io_read_cfg        | <pre>uint32_t pal_pcie_io_read_cfg(uint32_t Bdf, uint32_t offset, uint32_t *data);</pre>                                                              | Yes                   |
| io_write_cfg       | <pre>void pal_pcie_io_write_cfg(uint32_t bdf, uint32_t offset,<br/>uint32_t data);</pre>                                                              | Yes                   |
| get_snoop_bit      | <pre>uint32_t pal_pcie_get_snoop_bit(uint32_t seg, uint32_t bus,<br/>uint32_t dev, uint32_t fn);</pre>                                                | Yes                   |

| API name                        | Function prototype                                                                                                                  | Implementation        |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| is_device_behind_smmu           | <pre>uint32_t pal_pcie_is_device_behind_smmu(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                          | Yes                   |
| get_dma_support                 | <pre>uint32_t pal_pcie_get_dma_support(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                                | Yes                   |
| get_dma_coherent                | <pre>uint32_t pal_pcie_get_dma_coherent(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                               | Yes                   |
| ls_devicedma_64bit              | <pre>uint32_t pal_pcie_is_devicedma_64bit(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                             | Yes                   |
| get_legacy_irq_map              | <pre>uint32_t pal_pcie_get_legacy_irq_map(uint32_t Seg, uint32_t Bus, uint32_t Dev, uint32_t Fn, PERIPHERAL_IRQ_MAP *IrqMap);</pre> | Platform-<br>specific |
| get_root_port_bdf               | <pre>uint32_t pal_pcie_get_root_port_bdf(uint32_t *Seg, uint32_t *Bus, uint32_t *Dev, uint32_t *Func);</pre>                        | Yes                   |
| dev_p2p_support                 | <pre>uint32_t pal_pcie_dev_p2p_support(uint32_t seg, uint32_t bus,<br/>uint32_t dev, uint32_t fn);</pre>                            | Yes                   |
| is_cache_present                | <pre>uint32_t pal_pcie_is_cache_present(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                               | Yes                   |
| is_onchip_peripheral            | <pre>uint32_t pal_pcie_is_onchip_peripheral(uint32_t bdf);</pre>                                                                    | Platform-<br>specific |
| check_device_list               | uint32_t pal_pcie_check_device_list(void);                                                                                          | Yes                   |
| get_rp_transaction_frwd_support | <pre>uint32_t pal_pcie_get_rp_transaction_frwd_support(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn)</pre>                 | Platform-<br>specific |
| check_device_valid              | <pre>uint32_t pal_pcie_check_device_valid(uint32_t bdf);</pre>                                                                      | Platform-<br>specific |
| mem_get_offset                  | <pre>uint32_t pal_pcie_mem_get_offset(uint32_t bdf, PCIE_ MEM_TYPE_INFO_emem_type);</pre>                                           | Platform-<br>specific |
| bar_mem_read                    | <pre>uint32_t pal_pcie_bar_mem_read(uint32_t Bdf, uint64_t address, uint32_t *data);</pre>                                          | Yes                   |
| bar_mem_write                   | <pre>uint32_t pal_pcie_bar_mem_write(uint32_t Bdf, uint64_t address, uint32_t data);</pre>                                          | Yes                   |
| dsm_ste_tags                    | uint32_t pal_pcie_dsm_ste_tags(void);                                                                                               | No                    |

## 4.1.6 SMMU

The following table lists the different types of APIs in SMMU.

Table 4-6: SMMU APIs and their details

| API name                  | Function prototype                                                             | Implementation        |
|---------------------------|--------------------------------------------------------------------------------|-----------------------|
| check_device_iova         | <pre>uint32_t pal_smmu_check_device_iova(void *port, uint64_t dma_addr);</pre> | Platform-<br>specific |
| device_start_monitor_iova | <pre>void pal_smmu_device_start_monitor_iova(void *port);</pre>                | Platform-<br>specific |
| device_stop_monitor_iova  | <pre>void pal_smmu_device_stop_monitor_iova(void *port);</pre>                 | Platform-<br>specific |
| pa2iova                   | <pre>uint64_t pal_smmu_pa2iova(uint64_t smmu_base, unit64_t pa);</pre>         | Platform-<br>specific |

| API name           | Function prototype                                                                                     | Implementation        |
|--------------------|--------------------------------------------------------------------------------------------------------|-----------------------|
| smmu_disable       | <pre>uint32_t pal_smmu_disable(uint64_t smmu_base);</pre>                                              | Platform-<br>specific |
| create_pasid_entry | <pre>uint32_t pal_smmu_create_pasid_entry(uint64_t smmu_base, uint32_t pasid);</pre>                   | Platform-<br>specific |
| get_device_path    | <pre>uint32_t pal_get_device_path(const char *hid, char hid_path[][MAX_<br/>NAMED_COMP_LENGTH]);</pre> | Yes                   |
| is_etr_behind_catu | <pre>uint32_t pal_smmu_is_etr_behind_catu(char *etr_path);</pre>                                       | Platform-<br>specific |

## 4.1.7 Peripheral

The following table lists the different types of APIs in peripheral.

Table 4-7: Peripheral APIs and their details

| API name                    | Function prototype                                                                                     | Implementation        |
|-----------------------------|--------------------------------------------------------------------------------------------------------|-----------------------|
| create_info_table           | <pre>void pal_peripheral_create_info_table(PERIPHERAL_INFO_TABLE *per_info_table);</pre>               | Yes                   |
| is_pcie                     | <pre>uint32_t pal_peripheral_is_pcie(uint32_t seg, uint32_t bus,<br/>uint32_t dev, uint32_t fn);</pre> | Yes                   |
| memory_create_info_table    | <pre>void pal_memory_create_info_table(MEMORY_INFO_TABLE *memoryInfoTable);</pre>                      | Platform-<br>specific |
| memory_ioremap              | <pre>uint64_t pal_memory_ioremap(void *addr, uint32_t size, uint32_t attr);</pre>                      | Platform-<br>specific |
| memory_unmap                | <pre>void pal_memory_unmap(void *addr);</pre>                                                          | Platform-<br>specific |
| memory_get_unpopulated_addr | <pre>uint64_t pal_memory_get_unpopulated_addr(uint64_t *addr, uint32_t instance)</pre>                 | Platform-<br>specific |

## 4.1.8 MPAM

The following table lists the different types of APIs in MPAM:

Table 4-8: MPAM APIs and their details

| API name          | Functional prototype                                                      | Implemention |
|-------------------|---------------------------------------------------------------------------|--------------|
| create_info_table | <pre>void pal_mpam_create_ info_table(MPAM_INFO_TABLE *MpamTable);</pre>  | Yes          |
| create_info_table | <pre>void pal_hmat_create_ info_table(HMAT_INFO_TABLE *HmatTable);</pre>  | Yes          |
| create_info_table | <pre>void pal_srat_create_info_ table(SRAT_INFO_TABLE * SratTable);</pre> | Yes          |

| API name          | Functional prototype                                                                                | Implemention |
|-------------------|-----------------------------------------------------------------------------------------------------|--------------|
| create_info_table | <pre>void pal_cache_create_ info_table(CACHE_INFO_TABLE *CacheTable, PE_INFO_TABLE *PeTable);</pre> | Yes          |
| create_info_table | <pre>void pal_pcc_create_ info_table(PCC_INFO_TABLE *PccInfoTable);</pre>                           | Yes          |

## 4.1.9 RAS

The following table lists the different types of APIs in RAS:

Table 4-9: RAS APIs and their details

| API name                  | Function prototype                                                                          | Implementation        |
|---------------------------|---------------------------------------------------------------------------------------------|-----------------------|
| ras_create_info_table     | <pre>void pal_ras_create_info_table(RAS_ INFO_TABLE*RasInfoTable);</pre>                    | Yes                   |
| ras2_create_info_table    | <pre>void pal_ras2_create_info_table(RAS2_INFO_TABLE*ras2_info_table);</pre>                | Yes                   |
| setup_error               | <pre>uint32_t pal_ras_setup_error(RAS_ERR_IN_t in_param, RAS_ERR_OUT_t *out_param);</pre>   | Platform-<br>specific |
| inject_error              | <pre>uint32_t pal_ras_inject_error(RAS_ERR_IN_t in_param, RAS_ERR_OUT_ t *out_param);</pre> | Platform-<br>specific |
| wait_timeout              | <pre>void pal_ras_wait_timeout(uint32_t count);</pre>                                       | Platform-<br>specific |
| check_plat_poison_support | uint32_t pal_ras_check_plat_poison_support()                                                | Platform-<br>specific |

## 4.1.10 DMA

The following table lists the different types of APIs in DMA.

Table 4-10: DMA APIs and their details

| API name          | Function prototype                                                                                                              | Implementation        |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| create_info_table | <pre>void pal_dma_create_info_table(DMA_INFO_TABLE *dma_info_table);</pre>                                                      | Yes                   |
| start_from_device | <pre>uint32_t pal_dma_start_from_device(void *dma_target_buf, uint32_t length,void *host,void *dev);</pre>                      | Platform-<br>specific |
| start_to_device   | <pre>uint32_t pal_dma_start_to_device(void *dma_source_buf, uint32_t length, void *host, void *target, uint32_t timeout);</pre> | Platform-<br>specific |
| mem_alloc         | <pre>uint64_t pal_dma_mem_alloc(void *buffer, uint32_t length, void *dev, uint32_t flags);</pre>                                | Platform-<br>specific |
| scsi_get_dma_addr | <pre>void pal_dma_scsi_get_dma_addr(void *port, void *dma_addr, uint32_t *dma_len);</pre>                                       | Platform-<br>specific |
| mem_get_attrs     | <pre>int pal_dma_mem_get_attrs(void *buf, uint32_t *attr, uint32_t *sh)</pre>                                                   | Platform-<br>specific |
| dma_mem_free      | <pre>void pal_dma_mem_free(void *buffer, addr_tmem_dma, unsigned int length, void *port,unsigned int flags);</pre>              | Platform-<br>specific |

## 4.1.11 Exerciser

The following table lists the different types of APIs in exerciser.

Table 4-11: Exerciser APIs and their details

| API name                             | Function prototype                                                                                                        | Implementation        |
|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------|
| get_ecsr_base                        | uint64_t pal_exerciser_get_ecsr_base(uint32_t Bdf,uint32_t BarIndex)                                                      | Platform-<br>specific |
| get_pcie_config_offset               | <pre>uint64_t pal_exerciser_get_pcie_config_offset(uint32_t Bdf)</pre>                                                    | Platform-<br>specific |
| start_dma_direction                  | uint32_t pal_exerciser_start_dma_direction(uint64_t Base, EXERCISER_DMA_ATTRDirection)                                    | Platform-<br>specific |
| find_pcie_capability                 | <pre>uint32_t pal_exerciser_find_pcie_capability(uint32_t ID,<br/>uint32_t Bdf, uint32_t Value, uint32_t *Offset)</pre>   | Platform-<br>specific |
| set_param                            | <pre>uint32_t pal_exerciser_set_param(EXERCISER_PARAM_TYPE type, uint64_t value1, uint64_t value2, uint32_t bdf);</pre>   | Platform-<br>specific |
| get_param                            | <pre>uint32_t pal_exerciser_get_param(EXERCISER_PARAM_TYPE type, uint64_t *value1, uint64_t *value2, uint32_t bdf);</pre> | Platform-<br>specific |
| set_state                            | <pre>uint32_t pal_exerciser_set_state(EXERCISER_STATE state, uint64_t *value, uint32_t bdf);</pre>                        | Platform-<br>specific |
| get_state                            | <pre>uint32_t pal_exerciser_get_state(EXERCISER_STATE *state, uint32_t bdf);</pre>                                        | Platform-<br>specific |
| ops                                  | <pre>uint32_t pal_exerciser_ops(EXERCISER_OPS ops,uint64_t param, uint32_t instance);</pre>                               | Platform-<br>specific |
| get_data                             | <pre>uint32_t pal_exerciser_get_data(EXERCISER_DATA_TYPE type, exerciser_data_t *data, uint32_tbdf, uint64_t ecam);</pre> | Platform-<br>specific |
| is_bdf_exerciser                     | uint32_t pal_is_bdf_exerciser(uint32_t bdf)                                                                               | Platform-<br>specific |
| disable_rp_pio_register              | <pre>void pal_exerciser_disable_rp_pio_register(uint32_t bdf)</pre>                                                       | Platform-<br>specific |
| check_poison_data_forwarding_support | <pre>uint32_t pal_exerciser_check_poison_ data_forwarding_support()</pre>                                                 | Platform-<br>specific |
| get_pcie_ras_compliant_err_node      | uint32_t pal_exerciser_get_pcie_ras_compliant_err_<br>node(uint32_t bdf, uint32_t rp_bdf)                                 | Platform-<br>specific |
| get_ras_status                       | <pre>uint64_t pal_exerciser_get_ras_status(uint32_t ras_node,<br/>uint32_t bdf, uint32_t rp_bdf)</pre>                    | Platform-<br>specific |
| set_bar_response                     | <pre>uint32_t pal_exerciser_set_bar_response(uint32_t bdf)</pre>                                                          | Platform-<br>specific |

## 4.1.12 Memory map

The following table lists the different types of APIs required for Memory Map.

Table 4-12: Miscellaneous APIs and their descriptions

| API name          | Function prototype                                   | Description       |
|-------------------|------------------------------------------------------|-------------------|
| add_mmap          | <pre>void pal_mmu_add_mmap(void);</pre>              | Platform-specific |
| get_mmap_list     | <pre>void *pal_mmu_get_mmap_list(void);</pre>        | Platform-specific |
| get_mapping_count | <pre>uint32_t pal_mmu_get_mapping_count(void);</pre> | Platform-specific |

## 4.1.13 Miscellaneous

The following table lists the different types of miscellaneous PAL APIs.

Table 4-13: Miscellaneous APIs and their details

| API name            | Function prototype                                                                       | Implementation        |
|---------------------|------------------------------------------------------------------------------------------|-----------------------|
| mmio_read8          | uint8_t pal_mmio_read8(uint64_t addr);                                                   | Yes                   |
| mmio_read16         | uint16_t pal_mmio_read16(uint64_t addr);                                                 | Yes                   |
| mmio_read           | uint32_t pal_mmio_read(uint64_t addr);                                                   | Yes                   |
| mmio_read64         | uint64_t pal_mmio_read64(uint64_t addr);                                                 | Yes                   |
| mmio_write8         | <pre>void pal_mmio_write8(uint64_t addr, uint8_t data);</pre>                            | Yes                   |
| mmio_write16        | <pre>void pal_mmio_write16(uint64_t addr, uint16_t data);</pre>                          | Yes                   |
| mmio_write          | <pre>void pal_mmio_write(uint64_t addr, uint32_t data);</pre>                            | Yes                   |
| mmio_write64        | <pre>void pal_mmio_write64(uint64_t addr, uint64_t data);</pre>                          | Yes                   |
| print               | <pre>void pal_print(char8_t *string, uint64_t data);</pre>                               | Platform-<br>specific |
| uart_print          | <pre>void pal_uart_print(int log, const char *fmt,);</pre>                               | Yes                   |
| print_raw           | void pal_print_raw(uint64_t addr, char *string, uint64_t data)                           | Yes                   |
| mem_free            | <pre>void pal_mem_free(void *buffer);</pre>                                              | Platform-<br>specific |
| mem_compare         | <pre>int pal_mem_compare(void *src, void *dest, uint32_t len);</pre>                     | Yes                   |
| mem_set             | <pre>void pal_mem_set(void *buf, uint32_t size,uint8_t value);</pre>                     | Yes                   |
| mem_allocate_shared | <pre>void pal_mem_allocate_shared(uint32_t num_pe, uint32_t sizeofentry);</pre>          | Yes                   |
| mem_get_shared_addr | <pre>uint64_t pal_mem_get_shared_addr(void);</pre>                                       | Yes                   |
| mem_free_shared     | <pre>void pal_mem_free_shared(void);</pre>                                               | Yes                   |
| mem_alloc           | <pre>void *pal_mem_alloc(uint32_t size);</pre>                                           | Yes                   |
| mem_virt_to_phys    | <pre>void *pal_mem_virt_to_phys(void *va);</pre>                                         | Platform-<br>specific |
| mem_alloc_cacheable | <pre>void *pal_mem_alloc_cacheable(uint32_t Bdf, uint32_t Size, void **Pa);</pre>        | Platform-<br>specific |
| mem_free_cacheable  | <pre>void pal_mem_free_cacheable(uint32_t Bdf, uint32_t Size, void *Va, void *Pa);</pre> | Platform-<br>specific |

| API name         | Function prototype                                                                               | Implementation        |
|------------------|--------------------------------------------------------------------------------------------------|-----------------------|
| mem_phys_to_virt | <pre>void *pal_mem_phys_to_virt ( uint64_t Pa);</pre>                                            | Platform-<br>specific |
| strncmp          | <pre>uint32_t pal_strncmp(const char8_t *str1, const char8_t *str2, uint32_t len);</pre>         | Yes                   |
| memcpy           | <pre>void *pal_memcpy(void *DestinationBuffer, const void *SourceBuffer, uint32_t Length);</pre> | Yes                   |
| time_delay_ms    | <pre>uint64_t pal_time_delay_ms(uint64_t time_ms);</pre>                                         | Platform-<br>specific |
| page_size        | <pre>uint32_t pal_mem_page_size();</pre>                                                         | Platform-<br>specific |
| alloc_pages      | <pre>void *pal_mem_alloc_pages (uint32 NumPages);</pre>                                          | Platform-<br>specific |
| free_pages       | <pre>void pal_mem_free_pages (void *PageBase, uint32_t NumPages);</pre>                          | Platform-<br>specific |
| mem_calloc       | <pre>void *pal_mem_calloc(uint32_t num, uint32_t Size);</pre>                                    | Yes                   |
| aligned_alloc    | <pre>void *pal_aligned_alloc( uint32_t alignment, uint32_t size );</pre>                         | Yes                   |
| mem_free_aligned | <pre>void pal_mem_free_aligned(void *buffer);</pre>                                              | Platform-<br>specific |
| strncpy          | <pre>void *pal_strncpy(void *DestinationStr, const void *SourceStr, uint32_t Length);</pre>      | Yes                   |
| uart_pl011_putc  | <pre>void pal_driver_uart_pl011_putc(int c);</pre>                                               | Yes                   |

# 5. SBSA ACS flow

This chapter provides the SBSA ACS flow diagram and SBSA test example flow.

## 5.1 SBSA ACS flow diagram

The following flow diagram shows the sequence of events from initialization of devices, initialization of SBSA test data structures, and test case execution.

Figure 5-1: SBSA flow diagram



## 5.2 SBSA test example flow

If the device is Message-Signaled Interrupt (MSI) enabled, then the flag is set to MSI\_ENABLED by the PAL layer. The test checks whether the device is of type endpoint and then checks if the flags are set to MSI\_ENABLED.

The following flowchart shows the test that checks MSI support in a PCIe device.

Figure 5-2: SBSA example flow diagram



# Appendix A Revisions

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

## A.1 Revisions

This section consists of all the technical changes between different versions of this document.

#### Table A-1: Issue A

| Change         | Location |
|----------------|----------|
| First release. | -        |

#### Table A-2: Differences between Issue A and Issue 0100-02

| Change                                                                                                                                                                                      | Location                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| 1. Changed the file name of the component Timer and Watchdog.                                                                                                                               | See 2.5.1 Test suites on                       |
| 2. Added two more components - DMA and Miscellaneous.                                                                                                                                       | page 15.                                       |
| Changed the node count in IOVIRT nodes.                                                                                                                                                     | See 3.1.4.1 Number of IOVIRT Nodes on page 22. |
| Added PLATFORM_OVERRIDE_GICITS_ID and PLATFORM_OVERRIDE_GICIRD_LENGTH in the GIC-specific tests section.                                                                                    | See 3.1.5 GIC on page 25.                      |
| Removed request_msi, free_msi, its_configure, and get_max_lpi_id APIs in the GIC section.                                                                                                   | See 4.1.2 GIC on page 36.                      |
| Removed pal_pci_read_config_byte and pci_write_config_byte and added 10 new APIs in the PCIe section.                                                                                       | See 4.1.5 PCle on page 37.                     |
| Removed the create_info_table API in the SMMU section.                                                                                                                                      | See 4.1.6 SMMU on page 38.                     |
| Removed pal_pcie.c and pal_pcie_enumeration.c APIs and added 8 new APIs in the Peripheral section.                                                                                          | See 4.1.7 Peripheral on page 39.               |
| Renamed pal_mem_alloc_coherent API to pal_mem_alloc_cacheable API and pal_mem_free_coherent API to pal_mem_free_cacheable API. Added pal_mem_phys_to_virt API in the Miscellaneous section. | See 4.1.13 Miscellaneous on page 42.           |

#### Table A-3: Differences between Issue 0100-02 and Issue 0100-03

| Change                                             | Location                         |
|----------------------------------------------------|----------------------------------|
| Added get_rp_transaction_frwd_support API in PCIe. | See 4.1.5 PCle on page 37.       |
| Added pal_is_bdf_exerciser API in Exerciser.       | See 4.1.11 Exerciser on page 41. |

#### Table A-4: Differences between Issue 0100-03 and Issue 0301-01

| Change                                 | Location                                   |
|----------------------------------------|--------------------------------------------|
| Updated the Execution of SBSA ACS      | See 3. Execution of SBSA ACS on page 17.   |
| Updated the Porting requirements       | See 4. Porting requirements on page 35.    |
| Added memory topic.                    | See 3.1.8 Memory on page 27.               |
| Updated the SBSA example flow diagram. | See 5.2 SBSA test example flow on page 44. |

#### Table A-5: Differences between Issue 0301-01 and Issue 0302-01

| Change                                              | Location                                                                                |
|-----------------------------------------------------|-----------------------------------------------------------------------------------------|
| Updated information for the PCIe enumeration        | See 3. Execution of SBSA ACS on page 17.                                                |
| Added new APIs in Timer, PCIe, and<br>Miscellaneous | See 4.1.3 Timer on page 36, 4.1.5 PCle on page 37, and 4.1.13 Miscellaneous on page 42. |

#### Table A-6: Differences between Issue 0302-01 and Issue 0701-01

| Change                                   | Location                                              |  |
|------------------------------------------|-------------------------------------------------------|--|
| Changes to cp -r FVP/RDN2/platform_name  | See 2.5 Steps to customize bare-metal code on page 15 |  |
| Added MPAM, PMU, RAS and HMAT components | See:                                                  |  |
|                                          | • 3.1.9 MPAM on page 28                               |  |
|                                          | • 3.1.12 PMU on page 32                               |  |
|                                          | • 3.1.11 RAS on page 32                               |  |
|                                          | • 3.1.10 HMAT on page 31                              |  |
| Added PAL APIs                           | See:                                                  |  |
|                                          | • 4.1.8 MPAM on page 39                               |  |
|                                          | • 4.1.9 RAS on page 40                                |  |
|                                          | 4.1.13 Miscellaneous on page 42                       |  |

#### Table A-7: Differences between Issue 0701-01 and Issue 0701-02

| Change                                                             | Location                                                          |
|--------------------------------------------------------------------|-------------------------------------------------------------------|
| Added Named component specific information on Coresight components | See 3.1.4.11 Named component node specific information on page 24 |
| Added PAL APIs                                                     | See 4.1.5 PCle on page 37                                         |

#### Table A-8: Differences between Issue 0701-02 and Issue 0701-03

| Change                                                       | Location                                              |
|--------------------------------------------------------------|-------------------------------------------------------|
| Updated the steps to customize bare-metal code.              | See 2.5 Steps to customize bare-metal code on page 15 |
| Removed the API max_pasids from the SMMU APIs table.         | See 4.1.6 SMMU on page 38                             |
| Updated SBSA example flow diagram in SBSA test example flow. | See 5.2 SBSA test example flow on page 44             |

#### Table A-9: Differences between Issue 0701-03 and Issue 0701-04

| Change                                                                                             | Location                                                                                                           |
|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Added new sections, Boot framework, Boot process and boot flow, and Boot framework for Bare-metal. | See, 2.4 Boot framework on page 13, 2.4.1 Boot process and boot flow on page 13, and Boot framework for Bare-metal |
| Updated the information required for PCle enumeration.                                             | See, 3.1.2 PCle on page 19.                                                                                        |
| Added MMU in abbreviation.                                                                         | See 2.1 Abbreviations on page 11                                                                                   |
| Added a new section for MMU configuration.                                                         | See, 3.1.13 MMU Configuration on page 33.                                                                          |
| Added a new section Peripherals.                                                                   | See, Peripherals.                                                                                                  |
| Added a new section Bare-metal Boot.                                                               | See, Bare-metal Boot.                                                                                              |
| Added new APIs in Miscellaneous APIs and their details table and updated the Function prototype.   | See, 4.1.13 Miscellaneous on page 42.                                                                              |

#### Table A-10: Differences between Issue 0701-04 and Issue 0701-05

| Change                                                  | Location                              |
|---------------------------------------------------------|---------------------------------------|
| Added a new section for Memory map.                     | See, 4.1.12 Memory map on page 41.    |
| Updated the Miscellaneous APIs and their details table. | See, 4.1.13 Miscellaneous on page 42. |
| Updated the PCIe APIs and their details table.          | See, 3.1.2 PCle on page 19.           |

#### Table A-11: Differences between Issue 0701-05 and Issue 0701-06

| Change                                                           | Location                                                |
|------------------------------------------------------------------|---------------------------------------------------------|
| Updated the folder name from pal_baremetal to baremetal/target/. | See, 2.5 Steps to customize bare-metal code on page 15. |
| Updated the PCIe root ports and parameters.                      | See, 3.1.2 PCle on page 19.                             |
| Added new APIs in the Exerciser APIs and their details table.    | See, 4.1.11 Exerciser on page 41.                       |

#### Table A-12: Differences between Issue 0701-06 and Issue 0701-07

| Change                                                    | Location                     |
|-----------------------------------------------------------|------------------------------|
| Updated MPAM, Header file representation.                 | See, 3.1.9 MPAM on page 28.  |
| Added PCC component.                                      | See, 3.1.9.2 PCC on page 30. |
| Added a new API in the PCIe APIs and their details table. | See, 4.1.5 PCle on page 37.  |
| Added a new API in the MPAM APIs and their details table. | See, 4.1.8 MPAM on page 39.  |

#### Table A-13: Differences between Issue 0701-07 and Issue 0701-08

| Change                                              | Location                                                |
|-----------------------------------------------------|---------------------------------------------------------|
| Updated the steps to customize the bare-metal code. | See, 2.5 Steps to customize bare-metal code on page 15. |