# Arm® SBSA ACS Bare-metal

Version 1.0

**User Guide** 



#### Arm® SBSA ACS Bare-metal

#### **User Guide**

Copyright © 2020, 2021 Arm Limited or its affiliates. All rights reserved.

#### **Release Information**

#### **Document History**

| Issue   | Date             | Confidentiality  | Change         |
|---------|------------------|------------------|----------------|
| 0100-01 | 25 November 2020 | Non-Confidential | First release  |
| 0100-02 | 25 March 2021    | Non-Confidential | Second release |

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

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

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

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

This document may include technical inaccuracies or typographical errors.

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

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

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

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

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

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

(LES-PRE-20349)

#### **Confidentiality Status**

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

Unrestricted Access is an Arm internal classification.

#### **Product Status**

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

#### **Web Address**

developer.arm.com

#### Progressive terminology commitment

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

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

If you find offensive terms in this document, please contact terms@arm.com.

# Contents

# **Arm® SBSA ACS Bare-metal User Guide**

|           | Pref  | face                               |      |
|-----------|-------|------------------------------------|------|
|           |       | About this book                    | 7    |
|           |       | Feedback                           | 9    |
| Chapter 1 | Intro | oduction to SBSA                   |      |
|           | 1.1   | SBSA ACS                           | 1-11 |
|           | 1.2   | ACS design                         | 1-12 |
|           | 1.3   | Steps to customize bare-metal code | 1-13 |
| Chapter 2 | SoC   | emulation environment              |      |
|           | 2.1   | SoC emulation environment          | 2-15 |
| Chapter 3 | DMA   | A tests                            |      |
|           | 3.1   | Number of DMA controllers          | 3-18 |
|           | 3.2   | DMA master attributes              | 3-19 |
| Chapter 4 | SMN   | MU and device tests                |      |
|           | 4.1   | SMMU and device tests              | 4-21 |
| Chapter 5 | GIC   | tests                              |      |
|           | 5.1   | GIC-specific tests                 | 5-24 |
| Chapter 6 | Time  | er tests                           |      |
| -         | 6.1   | Timer Tests                        | 6-26 |
|           |       |                                    |      |

|            | 6.2  | Timer information         | 6-27      |
|------------|------|---------------------------|-----------|
| Chapter 7  | Wato | chdog timer tests         |           |
|            | 7.1  | Number of watchdog timers | 7-29      |
|            | 7.2  | Watchdog information      | 7-30      |
| Chapter 8  | Port | ing requirements          |           |
|            | 8.1  | PAL                       | 8-32      |
|            | 8.2  | GIC                       | 8-33      |
|            | 8.3  | Timer                     | 8-34      |
|            | 8.4  | IOVIRT                    | 8-35      |
|            | 8.5  | PCIe                      | 8-36      |
|            | 8.6  | SMMU                      | 8-39      |
|            | 8.7  | Peripheral                | 8-40      |
|            | 8.8  | DMA                       | 8-41      |
|            | 8.9  | Exerciser                 | 8-42      |
|            | 8.10 | Miscellaneous             | 8-44      |
| Chapter 9  | SBS  | A ACS flow                |           |
|            | 9.1  | SBSA ACS flow diagram     |           |
|            | 9.2  | SBSA test example flow    | 9-48      |
| Appendix A | Revi | isions                    |           |
|            | Δ1   | Revisions                 | Anny-A-50 |

# **Preface**

This preface introduces the Arm® SBSA ACS Bare-metal User Guide.

It contains the following:

- About this book on page 7.
- Feedback on page 9.

#### About this book

This document provides information on the SBSA ACS Bare-metal.

#### Using this book

This book is organized into the following chapters:

#### Chapter 1 Introduction to SBSA

This section provides an introduction to Arm SBSA describing the ACS architecture and the directory structure.

#### Chapter 2 SoC emulation environment

This chapter provides details of the parameters that can be customized in platform name/ include/platform override fvp.h as per the actuals with respect to PE and PCIe on an SoC emulation environment

#### Chapter 3 DMA tests

This section describes the configuration options for Direct Memory Access (DMA) controllerbased tests. Additionally, it describes the parameters for the number of DMA bus masters, and DMA master attributes that can be customized.

#### Chapter 4 SMMU and device tests

This chapter provides an overview on SMMU and device tests. Additionally, it describes the parameters for the number of IOVIRT nodes, SMMUs, RC, PMCG, ITS blocks, I/O virtualization node-specific information, SMMU node-specific information, RC-specific information, and I/O virtual address mapping that can be customized.

#### Chapter 5 GIC tests

This chapter describes the parameters for Generic Interrupt Controller (GIC) specific test that can be customized.

#### Chapter 6 Timer tests

This chapter describes the parameters for timer tests, and timer information that can be customized.

#### Chapter 7 Watchdog timer tests

This chapter describes the parameters for the number of watchdog timer tests, and watchdog information that can be customized.

#### Chapter 8 Porting requirements

This chapter provides information on different APIs in PAL, GIC, timer, IOVIRT, PCIe, SMMU, peripheral, DMA, exerciser, miscellaneous.

#### Chapter 9 SBSA ACS flow

This chapter provides an overview on the SBSA ACS flow diagram, and SBSA test example flow.

#### Appendix A Revisions

This section describes the technical changes made in this book.

#### **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*<sup>®</sup> *Glossary* for more information.

#### Typographic conventions

italic

Introduces special terminology, denotes cross-references, and citations.

#### bold

Highlights interface elements, such as menu names. Denotes signal names. Also used for terms in descriptive lists, where appropriate.

#### monospace

Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.

#### <u>mono</u>space

Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.

# monospace italic

Denotes arguments to monospace text where the argument is to be replaced by a specific value.

#### monospace bold

Denotes language keywords when used outside example code.

#### <and>

Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example:

#### SMALL CAPITALS

Used in body text for a few terms that have specific technical meanings, that are defined in the *Arm® Glossary*. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE.

#### Other information

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

### **Feedback**

#### Feedback on this product

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

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

#### Feedback on content

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

- The title Arm SBSA ACS Bare-metal User Guide.
- The number 102311 0100 02 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.                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note                                                                                                                                                          |
| 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. |

# Chapter 1 Introduction to SBSA

This section provides an introduction to Arm SBSA describing the ACS architecture and the directory structure.

It contains the following sections:

- 1.1 SBSA ACS on page 1-11.
- 1.2 ACS design on page 1-12.
- 1.3 Steps to customize bare-metal code on page 1-13.

# 1.1 SBSA ACS

This chapter describes about the Arm SBSA ACS.

Arm specifies a hardware system architecture which is based on Arm 64-bit architecture. Server system software such as operating systems, hypervisors, and firmware can rely on it. This ensures standard system architecture to enable a suitably built single OS image to run on all hardware compliant with this specification.

Arm provides a test suite named Architecture Compliance Test Suite (ACS) which contains self-checking portable C-test cases to verify the compliance of hardware platforms to SBSA.

Arm SBSA ACS can be downloaded from https://github.com/ARM-software/sbsa-acs.

# 1.2 ACS design

This section describes the layered architecture in the ACS design.

ACS is designed in a layered architecture that consists as follows:

- 1. Platform Adaptation 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 bare-metal abstraction.
  - For each component, PAL implementation must populate a data structure which involves in 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.
- 2. Validation Adaptation Layer (VAL) is a layer which provides an abstraction over PAL and does not change based on platform. This layer calls the PAL layer to achieve a certain functionality, for example:

```
val_pcie_read_cfg -> pal_pcie_read_cfg
```

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

The ACS test components are classified as follows:

- PE
- GIC
- PCIe
- Exerciser
- I/O virtualization or SMMU
- Timer
- Watchdog
- Power wakeup semantics

# 1.3 Steps to customize bare-metal code

This section describes the steps to customize bare-metal code.

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

1. Create a directory under the <local path>/sbsa-acs/platform/pal baremetal/ folder.

```
mkdir platform_name
```

Mada

2. Copy the reference code from <local\_path>/sbsa-acs/platform/pal\_baremetal/FVP/ folder to the folder created, platform name.

```
cp -r FVP/ platform_name/
```

- 3. Port all the required APIs mentioned in *Chapter 8 Porting requirements* on page 8-31.
- 4. Modify the file platform\_name/include/platform\_override\_fvp.h with platform-specific information. For sample implementation, refer Chapter 2 to Chapter 7.

This section contains the following subsection:

• 1.3.1 Directory structure on page 1-13.

#### 1.3.1 Directory structure

This section describes about the bare-metal layer.

A brief description about the bare-metal layer is as follows:

pal\_baremetal contains the bare-metal implementation for each test component specified as follows:

Table 1-1 Bare-metal component

| Component                     | File                               |  |
|-------------------------------|------------------------------------|--|
| PE                            | pal_pe.c                           |  |
| GIC                           | pal_gic.c                          |  |
| PCIe                          | 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                          |  |
| Miscellaneous                 | pal_misc.c                         |  |

|        | — Note —       |         |         |      |        |          |            |        |          |
|--------|----------------|---------|---------|------|--------|----------|------------|--------|----------|
| PAL im | olementation r | equires | porting | when | the un | derlying | g platform | design | changes. |

# Chapter 2 **SoC emulation environment**

This chapter provides details of the parameters that can be customized in platform\_name/include/platform\_override\_fvp.h as per the actuals with respect to PE and PCIe on an SoC emulation environment.

It contains the following section:

• 2.1 SoC emulation environment on page 2-15.

#### 2.1 SoC emulation environment

This section describes the execution of the SBSA ACS on a full chip 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 and many more to the test logic. In UEFI bases systems, all the static information is present in UEFI tables. PAL implementation that is based on UEFI, reads this information from the tables and populates the PAL data structures. For a bare-metal system, this information must be supplied in table format which can be read by the PAL API implementation. The PAL implementation uses generated header file for populating data structures.

This section contains the following subsections:

- 2.1.1 Number of PEs on page 2-15.
- 2.1.2 PE-specific information on page 2-15.
- 2.1.3 Number of PCIe root ports on page 2-15.
- 2.1.4 PCIe root port information on page 2-16.
- 2.1.5 PCIe peripherals on page 2-16.

#### 2.1.1 Number of PEs

This section describes the number of Processing Elements (PEs) in the design.

The following is a header file representation of the PEs in the design.

For example: If the PE count is equal to 1, then use the following code:

```
#define PLATFORM_OVERRIDE_PE0_INDEX 0x0
#define PLATFORM_OVERRIDE_PE0_MPIDR 0x0
#define PLATFORM_OVERRIDE_PE0_PMU_GSIV 0x17
#define PLATFORM_OVERRIDE_PE1_INDEX 0x1
#define PLATFORM_OVERRIDE_PE1_MPIDR 0x100
#define PLATFORM_OVERRIDE_PE1_PMU_GSIV 0x17
```

#### 2.1.2 PE-specific information

This section describes the number of PE-specific information.

Tests contain comparison of MPIDR values with actual values read from register. Such interrupts are generated for the performance monitoring interrupt lines and tested.

#### #pe\_mpidr

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

#### pe\_index

the PE number.

#### #pe\_performanceinterruptgsiv

Performance monitoring interrupt number for each core.

Header file representation:

```
#define PLATFORM_OVERRIDE_PE_CNT 0x8
```

For example: If the PE count is equal to 1, then use the following code:

#### 2.1.3 Number of PCIe root ports

This section describes the number of Peripheral Component Interconnect express (PCIe) root ports.

Header file representation:

```
#define PLATFORM_OVERRIDE_NUM_ECAM 1
```

For example:

### 2.1.4 PCle root port information

This section describes the PCIe root port information with an example.

Following information corresponding to the root port is described as follows:

- Enhanced Configuration Access Mechanism (ECAM) base address: ECAM maps PCIe configuration space to memory address. The memory address to the current configuration space must be provided here.
- Start bus number: starting bus number on this segment.
- End bus number: ending bus number on this segment
- · Segment number

For example:

#### 2.1.5 PCle peripherals

This section provides information on the number of PCIe peripheral counts.

Header file representation:

```
#define PLATFORM_PCIE_P2P_NOT_SUPPORTED 1

#define PLATFORM_PERIPHERAL_COUNT 2

#define PERIPHERAL0_DMA_SUPPORT 1

#define PERIPHERAL0_DMA_COHERENT 1

#define PERIPHERAL0_DMA_GABIT 0

#define PERIPHERAL0_DMA_GABIT 0

#define PERIPHERAL0_BEHIND_SMMU 1

#define PERIPHERAL0_ATC_SUPPORT 0
```

# Chapter 3 **DMA tests**

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

It contains the following sections:

- 3.1 Number of DMA controllers on page 3-18.
- 3.2 DMA master attributes on page 3-19.

# 3.1 Number of DMA controllers

This section provides data for the number of DMA controllers.

Header file representation:

#define PLATFORM\_OVERRIDE\_DMA\_CNT

# 3.2 DMA master attributes

This section provides data for the DMA master attributes.

Header file representation:

# Chapter 4 SMMU and device tests

This chapter provides an overview on SMMU and device tests. Additionally, it describes the parameters for the number of IOVIRT nodes, SMMUs, RC, PMCG, ITS blocks, I/O virtualization node-specific information, SMMU node-specific information, RC-specific information, and I/O virtual address mapping that can be customized.

It contains the following section:

• 4.1 SMMU and device tests on page 4-21.

#### 4.1 SMMU and device tests

This chapter provides an overview on SMMU and the device tests.

Additionally, this chapter provides information on the number of IOVIRT nodes, SMMUs, RC, PMCG, ITS blocks, I/O virtualization node-specific information, SMMU node-specific information, RC-specific information, I/O virtual address mapping.

This section contains the following subsections:

- 4.1.1 Number of IOVIRT Nodes on page 4-21.
- 4.1.2 Number of SMMUs on page 4-21.
- 4.1.3 Number of RC on page 4-21.
- 4.1.4 Number of PMCG on page 4-21.
- 4.1.5 Number of ITS blocks on page 4-21.
- 4.1.6 I/O virtualization node-specific information on page 4-21.
- 4.1.7 SMMU node-specific information on page 4-22.
- 4.1.8 RC-specific information on page 4-22.
- 4.1.9 I/O virtual address mapping on page 4-22.

#### 4.1.1 Number of IOVIRT Nodes

This section provides data for the number of IOVIRT nodes.

Header file representation:

#define IORT NODE COUNT 0x3

#### 4.1.2 Number of SMMUs

This section provides data for the System Memory Management Unit (SMMU) count.

Header file representation:

#define SMMU\_COUNT 0x1

#### 4.1.3 Number of RC

This section provides details on the number of Root Complex (RC) count.

Header file representation:

#define RC COUNT 0x1

#### 4.1.4 Number of PMCG

This section provides details on the number of Performance Monitor Counter Groups (PMCG) in the system.

Header file representation:

#define PMCG\_COUNT 0x1

#### 4.1.5 Number of ITS blocks

This section provides details on the number of Interrupt Translation Service (ITS) blocks in GIC.

Header file representation:

#define IOVIRT\_ITS\_COUNT 0x1

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

This section provides details on I/O virtualization node-specific information.

Header file representation:

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

### 4.1.7 SMMU node-specific information

This section describes the SMMU node-specific information.

Header file representation:

```
typedef struct {
uint32_t arch_major_rev;  ///< Version 1 or 2 or 3
uint64_t base;  ///< SMMU Controller base address
}SMMU_INFO_BLOCK;</pre>
```

### 4.1.8 RC-specific information

This section provides data on the RC-specific information.

Header file representation:

#### 4.1.9 I/O virtual address mapping

This section provides data on the 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;
```

# Chapter 5 GIC tests

This chapter describes the parameters for Generic Interrupt Controller (GIC) specific test that can be customized.

It contains the following section:

• 5.1 GIC-specific tests on page 5-24.

# 5.1 GIC-specific tests

This section provides details on GIC-specific tests.

Header file representation:

# Chapter 6 Timer tests

This chapter describes the parameters for timer tests, and timer information that can be customized.

It contains the following sections:

- 6.1 Timer Tests on page 6-26.
- 6.2 Timer information on page 6-27.

# 6.1 Timer Tests

This section provides information on timer tests.

Header file representation:

#define PLATFORM\_OVERRIDE\_TIMER\_COUNT 0x2

# 6.2 Timer information

This section provides information on the timers present in the system.

Header file representation:

# Chapter 7 Watchdog timer tests

This chapter describes the parameters for the number of watchdog timer tests, and watchdog information that can be customized.

It contains the following sections:

- 7.1 Number of watchdog timers on page 7-29.
- 7.2 Watchdog information on page 7-30.

# 7.1 Number of watchdog timers

This section provides information on the number of watchdog timers present in the system.

Header file representation:

#define PLATFORM\_OVERRIDE\_WD\_TIMER\_COUNT 2

# 7.2 Watchdog information

This section provides information on the number of watchdog timers present in the system.

The following information about each of the watchdog timers is present on the system:

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

Header file representation:

# Chapter 8 **Porting requirements**

This chapter provides information on different APIs in PAL, GIC, timer, IOVIRT, PCIe, SMMU, peripheral, DMA, exerciser, miscellaneous.

It contains the following sections:

- 8.1 PAL on page 8-32.
- 8.2 GIC on page 8-33.
- 8.3 Timer on page 8-34.
- *8.4 IOVIRT* on page 8-35.
- 8.5 PCIe on page 8-36.
- 8.6 SMMU on page 8-39.
- 8.7 Peripheral on page 8-40.
- 8.8 DMA on page 8-41.
- 8.9 Exerciser on page 8-42.
- 8.10 Miscellaneous on page 8-44.

### 8.1 PAL

This section provides information on different APIs in PAL.

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

Table 8-1 PAL

| API name             | Function prototype                                                                              | Implementation    |
|----------------------|-------------------------------------------------------------------------------------------------|-------------------|
| create_info_table    | <pre>void pal_pe_create_info_table(PE_INF O_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-specific |
| get_esr              | <pre>uint64_t pal_pe_get_esr(void *context);</pre>                                              | Platform-specific |
| data_cache_ops_by_va | <pre>void pal_pe_data_cache_ops_by_va(uin t64_taddr, uint32_t type);</pre>                      | Yes               |
| get_far              | <pre>uint64_t pal_pe_get_far(void *context);</pre>                                              | Platform-specific |
| install_esr          | <pre>uint32_t pal_pe_install_esr(uint32_t exception_type, void(*esr) (uint64_t, void *));</pre> | Platform-specific |

| Note — |
|--------|
| 1016   |

The following points describes the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

# 8.2 GIC

This section provides information on different types of APIs in GIC.

The following table is the list of different APIs in GIC:

Table 8-2 GIC

| API name          | Function prototype                                                                                  | Implementation    |
|-------------------|-----------------------------------------------------------------------------------------------------|-------------------|
| create_info_table | <pre>void pal_gic_create_info_table(GIC_I NFO_TABLE*gic_info_table);</pre>                          | Yes               |
| install_isr       | <pre>uint32_t pal_gic_install_isr(uint32_t int_id, void(*isr)(void));</pre>                         | Platform-specific |
| end_of_interrupt  | <pre>uint32_t pal_gic_end_of_interrupt(uint32 _t int_id);</pre>                                     | Platform-specific |
| request_irq       | <pre>uint32_t pal_gic_request_irq(unsigned intirq_num, unsigned int mapped_irq_num,void*isr);</pre> | Platform-specific |
| free_irq          | <pre>void pal_gic_free_irq(unsigned int irq_num,unsigned int mapped_irq_num);</pre>                 | Platform-specific |
| set_intr_trigger  | <pre>uint32_tpal_gic_set_intr_trigge r(uint32_tint_idINTR_TRIGGER_IN FO_TYPE_etrigger_type);</pre>  | Platform-specific |



The following points describe the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

### 8.3 Timer

This section provides information on different types of APIs in timer.

The following table is the list of different APIs in timer:

Table 8-3 Timer

| API name             | Function prototype                                                                | Implementation |
|----------------------|-----------------------------------------------------------------------------------|----------------|
| create_info_table    | <pre>void pal_timer_create_info_table(TIM ER_INFO_TABLE *timer_info_table);</pre> | Yes            |
| wd_create_info_table | <pre>void pal_wd_create_info_table(WD_INF O_TABLE *wd_table);</pre>               | Yes            |



The following points describe the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

### 8.4 IOVIRT

This section provides information on different types of APIs in IOVIRT.

The following table is the list of different APIs in IOVIRT:

Table 8-4 IOVIRT

| API name               | Function prototype                                                                               | Implementation |
|------------------------|--------------------------------------------------------------------------------------------------|----------------|
| create_info_table      | <pre>void pal_iovirt_create_info_table(IO VIRT_INFO_TABLE *iovirt);</pre>                        | Yes            |
| unique_rid_strid_map   | <pre>uint32_t pal_iovirt_unique_rid_strid_ma p(uint64_t rc_block);</pre>                         | Yes            |
| check_unique_ctx_initd | <pre>uint32_t pal_iovirt_check_unique_ctx_int id(uint64_t smmu_block);</pre>                     | Yes            |
| get_rc_smmu_base       | <pre>uint64_t pal_iovirt_get_rc_smmu_base(IOV IRT_INFO_TABLE *iovirt, uint32_trc_seg_num);</pre> | Yes            |

| Note |
|------|
|------|

The following points describe the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

# 8.5 PCle

This section provides information on different APIs in PCIe.

The following table is the list of different APIs in PCIe:

Table 8-5 PCle

| API name                                  | Function prototype                                                                                                                                    | Implementation    |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| create_info_table                         | <pre>void pal_pcie_create_info_table(PCIE _INFO_TA BLE*PcieTable);</pre>                                                                              | Yes               |
| read_cfg                                  | <pre>uint32_t pal_pcie_read_cfg(uint32_tbdf, uint32_t offset, uint32_t *data);</pre>                                                                  | Yes               |
| get_msi_vectors                           | <pre>uint32_t pal_get_msi_vectors(uint32_t seg,uint32_t bus, uint32_t dev, uint32_tfn, PERIPHERAL_VECTOR_LIST**mvector );</pre>                       | Platform-specific |
| scan_bridge_devices_and_check_m<br>emtype | <pre>uint32_t pal_pcie_scan_bridge_devices_an d_check_memtype (uint32_t seg,uint32_t bus, uint32_tdev, uint32_tfn);</pre>                             | Yes               |
| get_pcie_type                             | <pre>uint32_t pal_pcie_get_pcie_type(uint32_t seg,uint32_t bus, uint32_t dev, uint32_tfn);</pre>                                                      | Yes               |
| p2p_support                               | <pre>uint32_t pal_pcie_p2p_support(void);</pre>                                                                                                       | Yes               |
| read_ext_cap_word                         | <pre>void pal_pcie_read_ext_cap_word(uint 32_t seg, uint32_t bus, uint32_t dev,uint32_t fn, uint32_t ext_cap_id,uint8_t offset, uint16_t *val);</pre> | Yes               |
| multifunction_support                     | <pre>uint32_t pal_pcie_multifunction_support( uint32_t seg, uint32_t bus, uint32_t dev,uint32_t fn);</pre>                                            | Yes               |
| get_bdf_wrapper                           | <pre>uint32_t pal_pcie_get_bdf_wrapper (uint32ClassCode, uint32 StartBdf);</pre>                                                                      | Yes               |
| bdf_to_dev                                | <pre>void *pal_pci_bdf_to_dev(uint32_t bdf);</pre>                                                                                                    | Yes               |

## Table 8-5 PCIe (continued)

| API name           | Function prototype                                                                                              | Implementation |
|--------------------|-----------------------------------------------------------------------------------------------------------------|----------------|
| pal_pcie_ecam_base | <pre>uint64_t pal_pcie_ecam_base(uint32_t seg,uint32_t bus, uint32_t dev, uint32_tfunc)</pre>                   | Yes            |
| pci_cfg_read       | <pre>uint32_t pal_pci_cfg_read(uint32_t bus,uint32_t dev, uint32_t func, uint32_toffset, uint32_t *value)</pre> | Yes            |
| pci_cfg_write      | <pre>void pal_pci_cfg_write(uint32_t bus,uint32_t dev, uint32_t func, uint32_toffset, 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(uint3 2_tbus, uint32_t sec_bus)</pre>                                   | Yes            |
| get_bdf            | <pre>uint32_t pal_pcie_get_bdf(uint32_tClassC ode, uint32_t StartBdf)</pre>                                     | Yes            |
| increment_bus_dev  | <pre>uint32_t pal_increment_bus_dev(uint32_tS tartBdf)</pre>                                                    | Yes            |
| get_base           | uint64_t pal_pcie_get_base(uint32_t bdf,uint32_t bar_index)                                                     | Yes            |
| bdf_to_dev         | <pre>void *pal_pci_bdf_to_dev(uint32_t bdf)</pre>                                                               | 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, uint32_t data);</pre>                            | Yes            |
| get_device_type    | <pre>uint32_t pal_pcie_get_device_type(uint32 _t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>           | Yes            |

### Table 8-5 PCIe (continued)

| API name                      | Function prototype                                                                                                                   | Implementation    |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| get_snoop_bit                 | <pre>uint32_t pal_pcie_get_snoop_bit(uint32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                                   | Yes               |
| 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(uint3 2_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                               | Yes               |
| Is_devicedma_64bit            | <pre>uint32_t pal_pcie_is_devicedma_64bit(uin t32_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                             | Yes               |
| <pre>get_legacy_irq_map</pre> | <pre>uint32_t pal_pcie_get_legacy_irq_map(uin t32_t Seg, uint32_t Bus, uint32_t Dev, uint32_t Fn, PERIPHERAL_IRQ_MAP *IrqMap);</pre> | Platform-specific |
| get_root_port_bdf             | <pre>uint32_t pal_pcie_get_root_port_bdf(uint 32_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, uint32_t dev, uint32_t fn);</pre>                                | Yes               |
| is_cache_present              | <pre>uint32_t pal_pcie_is_cache_present(uint3 2_t seg, uint32_t bus, uint32_t dev, uint32_t fn);</pre>                               | Yes               |

|   | Note |  |
|---|------|--|
| - | Note |  |

The following points describe the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

### 8.6 SMMU

This section provides information on different APIs in SMMU.

The following table is the list of different APIs in SMMU:

Table 8-6 SMMU

| API name                  | Function prototype                                                                   | Implementation    |
|---------------------------|--------------------------------------------------------------------------------------|-------------------|
| check_device_iova         | <pre>uint32_t pal_smmu_check_device_iova(void *port, uint64_t dma_addr);</pre>       | Platform-specific |
| device_start_monitor_iova | <pre>void pal_smmu_device_start_monitor_i ova(void *port);</pre>                     | Platform-specific |
| device_stop_monitor_iova  | <pre>void pal_smmu_device_stop_monitor_io va(void *port);</pre>                      | Platform-specific |
| max_pasids                | <pre>uint32_t pal_smmu_max_pasids(uint64_tsmm u_base);</pre>                         | Yes               |
| pa2iova                   | uint64_t pal_smmu_pa2iova(uint64 SmmuBase,unit64 Pa);                                | Platform-specific |
| smmu_disable              | <pre>uint32_t pal_smmu_disable(uint64 SmmuBase);</pre>                               | Platform-specific |
| create_pasid_entry        | <pre>uint32_t pal_smmu_create_pasid_entry(uin t64_tsmmu_base, uint32_t pasid);</pre> | Platform-specific |

| <br>Note |  |
|----------|--|
|          |  |

The following points describe the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

## 8.7 Peripheral

This section provides information on different APIs in peripheral.

The following table is the list of different APIs in peripheral:

Table 8-7 Peripheral

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



The following describes the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

### 8.8 **DMA**

This section provides information on different APIs in DMA.

The following table is the list of different APIs in DMA:

Table 8-8 DMA

| API name          | Function prototype                                                                                                             | Implementation    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------|
| create_info_table | <pre>void pal_dma_create_info_table(DMA_I NFO_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-specific |
| start_to_device   | <pre>uint32_t pal_dma_start_to_device(void*dm a_source_buf, uint32_t length, void *host,void *target, uint32_t timeout);</pre> | Platform-specific |
| mem_alloc         | <pre>uint64_t pal_dma_mem_alloc(void **buffer, uint32_tlength, void *dev, uint32_t flags);</pre>                               | Platform-specific |
| scsi_get_dma_addr | <pre>void pal_dma_scsi_get_dma_addr(void *port, void*dma_addr, uint32_t *dma_len);</pre>                                       | Platform-specific |
| mem_get_attrs     | <pre>int pal_dma_mem_get_attrs(void *buf, uint32_t*attr, uint32_t *sh)</pre>                                                   | Platform-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-specific |

| Note      |  |
|-----------|--|
| <br>11016 |  |

The following points describe the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

## 8.9 Exerciser

This section provides information on different APIs in exerciser.

The following table is the list of different APIs in exerciser:

Table 8-9 Exerciser

| API name                                         | Function prototype                                                                                                         | Implementation    |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------|
| pal_exerciser_get_ecsr_base                      | <pre>uint64_t pal_exerciser_get_ecsr_base(uin t32_t Bdf,uint32_t BarIndex)</pre>                                           | Platform-specific |
| <pre>pal_exerciser_get_pcie_config_o ffset</pre> | <pre>uint64_t pal_exerciser_get_pcie_config_o ffset(uint32_t Bdf)</pre>                                                    | Platform-specific |
| <pre>pal_exerciser_start_dma_directi on</pre>    | uint32_t pal_exerciser_start_dma_directi on(uint64_t Base, EXERCISER_DMA_ATTRDirection)                                    | Platform-specific |
| <pre>pal_exerciser_find_pcie_capabil ity</pre>   | <pre>uint32_t pal_exerciser_find_pcie_capabil ity(uint32_t ID, uint32_t Bdf, uint32_t Value,uint32_t *Offset)</pre>        | Platform-specific |
| pal_exerciser_set_param                          | <pre>uint32_t pal_exerciser_set_param(EXERCIS ER_PARAM_TYPE type, uint64_t value1, uint64_tvalue2, uint32_t bdf);</pre>    | Platform-specific |
| pal_exerciser_get_param                          | <pre>uint32_t pal_exerciser_get_param(EXERCIS ER_PARAM_TYPE type, uint64_t *value1, uint64_t*value2, uint32_t bdf);</pre>  | Platform-specific |
| pal_exerciser_set_state                          | <pre>uint32_t pal_exerciser_set_state(EXERCIS ER_STATEstate, uint64_t *value, uint32_t bdf);</pre>                         | Platform-specific |
| pal_exerciser_get_state                          | <pre>uint32_t pal_exerciser_get_state(EXERCIS ER_STATE*state, uint32_t bdf);</pre>                                         | Platform-specific |
| pal_exerciser_ops                                | <pre>uint32_t pal_exerciser_ops(EXERCISER_OPS ops,uint64_t param, uint32_t instance);</pre>                                | Platform-specific |
| pal_exerciser_get_data                           | <pre>uint32_t pal_exerciser_get_data(EXERCISE R_DATA_TYPE type, exerciser_data_t *data, uint32_tbdf, uint64_t ecam);</pre> | Platform-specific |

| Note                                                                |  |
|---------------------------------------------------------------------|--|
| The following points describe the implementation type for this API: |  |
|                                                                     |  |

1. Yes: This 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.

2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

## 8.10 Miscellaneous

This section provides information on different APIs in miscellaneous.

The following table lists different APIs in miscellaneous:

Table 8-10 Miscellaneous

| API name                | Function prototype                                                              | Implementation    |
|-------------------------|---------------------------------------------------------------------------------|-------------------|
| pal_mmio_read8          | <pre>uint8_t pal_mmio_read8(uint64_t addr);</pre>                               | Yes               |
| pal_mmio_read16         | <pre>uint16_t pal_mmio_read16(uint64_t addr);</pre>                             | Yes               |
| pal_mmio_read           | <pre>uint32_t pal_mmio_read(uint64_t addr);</pre>                               | Yes               |
| pal_mmio_read64         | <pre>uint64_t pal_mmio_read64(uint64_t addr);</pre>                             | Yes               |
| pal_mmio_write8         | <pre>void pal_mmio_write8(uint64_t addr,uint8_t data);</pre>                    | Yes               |
| pal_mmio_write16        | <pre>void pal_mmio_write16(uint64_t addr,uint16_t data);</pre>                  | Yes               |
| pal_mmio_write          | <pre>void pal_mmio_write(uint64_t addr,uint32_t data);</pre>                    | Yes               |
| pal_mmio_write64        | <pre>void pal_mmio_write64(uint64_t addr,uint64_t data);</pre>                  | Yes               |
| pal_print               | <pre>void pal_print(char8_t *string,<br/>uint64_tdata);</pre>                   | Platform-specific |
| pal_print_raw           | <pre>void pal_print_raw(uint64_t addr, char*string, uint64_t data)</pre>        | Yes               |
| pal_mem_free            | <pre>void pal_mem_free(void *buffer);</pre>                                     | Platform-specific |
| pal_mem_compare         | <pre>int pal_mem_compare(void *src,void *dest, uint32_t len);</pre>             | Yes               |
| pal_mem_set             | <pre>void pal_mem_set(void *buf, uint32_t size,uint8_t value);</pre>            | Yes               |
| pal_mem_allocate_shared | <pre>void pal_mem_allocate_shared(uint32_ tnum_pe, uint32_t sizeofentry);</pre> | Yes               |
| pal_mem_get_shared_addr | <pre>uint64_t pal_mem_get_shared_addr(void);</pre>                              | Yes               |
| pal_mem_free_shared     | <pre>void pal_mem_free_shared(void);</pre>                                      | Yes               |
| pal_mem_alloc           | <pre>void *pal_mem_alloc(uint32_t size);</pre>                                  | Platform-specific |
| pal_mem_virt_to_phys    | <pre>void *pal_mem_virt_to_phys(void *va);</pre>                                | Platform-specific |

Table 8-10 Miscellaneous (continued)

| API name                | Function prototype                                                                       | Implementation    |
|-------------------------|------------------------------------------------------------------------------------------|-------------------|
| pal_mem_alloc_cacheable | <pre>void *pal_mem_alloc_cacheable(uint32 _t Bdf, uint32_t Size, void **Pa);</pre>       | Platform-specific |
| pal_mem_free_cacheable  | <pre>void pal_mem_free_cacheable(uint32_t Bdf, uint32_t Size, void *Va, void *Pa);</pre> | Platform-specific |
| pal_mem_phys_to_virt    | <pre>void *pal_mem_phys_to_virt ( uint64_t Pa);</pre>                                    | Platform-specific |
| pal_strncmp             | <pre>uint32_t pal_strncmp(char8_t *str1, char8_t*str2, uint32_t len);</pre>              | Yes               |
| pal_memcpy              | <pre>void *pal_memcpy(void *dest_buffer, void*src_buffer, uint32_t len);</pre>           | Yes               |
| pal_time_delay_ms       | <pre>uint64_t pal_time_delay_ms(uint64_t time_ms);</pre>                                 | Platform-specific |
| page_size               | <pre>uint32_t pal_mem_page_size();</pre>                                                 | Platform-specific |
| alloc_pages             | <pre>void*pal_mem_alloc_pages (uint32NumPages);</pre>                                    | Platform-specific |
| free_pages              | <pre>void pal_mem_free_pages (void *PageBase,uint32_t NumPages);</pre>                   | Platform-specific |

| 1 | Note ——— |
|---|----------|
|   |          |

The following points describes the implementation type for this API:

- 1. Yes: This 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.
- 2. Platform-specific: You must implement all the APIs that are marked as platform-specific.

## Chapter 9 SBSA ACS flow

This chapter provides an overview on the SBSA ACS flow diagram, and SBSA test example flow.

It contains the following sections:

- 9.1 SBSA ACS flow diagram on page 9-47.
- 9.2 SBSA test example flow on page 9-48.

## 9.1 SBSA ACS flow diagram

This chapter provides information on the SBSA ACS flow diagram.

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



Figure 9-1 SBSA flow diagram

## 9.2 SBSA test example flow

This section shows the flow of a typical SBSA test.

This flow chart is for a test that checks MSI support of a PCIe device.

If the device is MSI enabled, the flag is set to MSI\_ENABLED by the PAL layer. The test checks whether the device is of type endpoint and then checks whether the flags are set to MSI\_ENABLED.



Figure 9-2 SBSA example flow diagram

# Appendix A **Revisions**

This section describes the technical changes made in this book.

It contains the following section:

• A.1 Revisions on page Appx-A-50.

## A.1 Revisions

### Table A-1 Issue A

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

Table A-2 Difference between Issue A and Issue 0100-02

| Change                                                                                                               | Location                                        |
|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| Changed the file name of the component 'timer and watchdog'.     Added two more components - DMA, and Miscellaneous. | See, 1.3.1 Directory structure on page 1-13.    |
| Changed the node count in IOVIRT nodes.                                                                              | See, 4.1.1 Number of IOVIRT Nodes on page 4-21. |
| Added a few GIC-specific tests.                                                                                      | See, 5.1 GIC-specific tests on page 5-24.       |
| Removed a few APIs in GIC.                                                                                           | See, 8.2 GIC on page 8-33.                      |
| Removed and added a few APIs in PCIe.                                                                                | See, 8.5 PCIe on page 8-36.                     |
| Removed the 'create_info_table' in SMMU.                                                                             | See, 8.6 SMMU on page 8-39.                     |
| Removed a few APIs from Peripheral.                                                                                  | See, 8.7 Peripheral on page 8-40.               |
| Renamed and added a few APIs in Miscellaneous.                                                                       | See, 8.10 Miscellaneous on page 8-44.           |