- Introduction
- Latest Release details
- Prebuilt Images
- Steps to Manually Build Image
- Image Directory Structure
- Details and Functionalities of the Image
- Verification on Arm Neoverse N2 reference design
- Security Implication
- License
- Feedback, contributions, and support
SystemReady band is a band of system compliance in the Arm SystemReady program that ensures interoperability of Arm based servers with standard operating systems and hypervisors.
SystemReady band compliant platforms must implement a minimum set of hardware and firmware features that an operating system can depend on to deploy the operating system image.
The SystemReady band compliance and testing requirements are specified in the Arm SystemReady Requirements Specification (SRS)
- Release version: v3.0.0-BET0
- The latest pre-built release of ACS is available for download here: v24.11_3.0.0-BET0
- The compliance suite is not a substitute for design verification.
- To review the ACS logs, Arm licensees can contact Arm directly through their partner managers.
- SystemReady-band Image Test Suite details
Test Suite | Test Suite Tag | Specification Version |
---|---|---|
Base System Architecture (BSA) | v24.11_REL1.0.9 | BSA v1.0 (c) |
Server Base System Architecture (SBSA) | v24.11_REL7.2.1 | SBSA v7.1 |
Base Boot Requirements (BBR) | v24.11_EBBR_REL2.2.0-BETA0_SBBR_REL2.1.0-BETA0_BBSR_REL1.3.0 | BBR v2.1 |
Base Boot Security Requirements (BBSR) | v24.11_EBBR_REL2.2.0-BETA0_SBBR_REL2.1.0-BETA0_BBSR_REL1.3.0 | BBSR v1.3 |
UEFI Self Certification Tests (UEFI-SCT) | 0e2ced3befa431bb1aebff005c4c4f1a9edfe6b4 | |
Firmware Test Suite (FWTS) | v24.09.00 |
- Prebuilt images for each release are available in the prebuilt_images folder.To access the prebuilt_images, click prebuilt_images.
- The prebuilt images are archived after compression to the .xz format. On Linux, use the xz utility to uncompress the image
xz -d systemready_acs_live_image.img.xz
On Windows, use the 7zip or a similar utility. - If you choose to use the prebuilt image, skip the build steps and navigate to the Verification on Arm Neoverse N2 reference design.
Before starting the ACS build, ensure that the following requirements are met:
- Ubuntu 20.04 or later LTS with at least 32GB of free disk space.
- Use bash shell.
- You must have sudo privilege to install tools required for build.
- Install
git
usingsudo apt install git
git config --global user.name "Your Name"
andgit config --global user.email "Your Email"
must be configured.
- To build a release version of the code, checkout the main branch with the appropriate release tag.
- To build the latest version of the code with bug fixes and new features, use the main branch.
-
Clone the arm-systemready repository
git clone https://github.com/ARM-software/arm-systemready.git
-
Navigate to the SystemReady band directory
cd arm-systemready/SystemReady-band
-
Run get_source.sh to download all related sources and tools for the build. Provide the sudo permission when prompted
./build-scripts/get_source.sh
-
To start the build of the ACS live image, execute the below step
./build-scripts/build-systemready-band-live-image.sh
-
If all the above steps are successful, then the bootable image will be available at
/path-to-arm-systemready/SystemReady-band/output/systemready_acs_live_image.img.xz
Note: The image is generated in a compressed (.xz) format. The image must be uncompressed before it is used.
This image comprise of single FAT file system partition recognized by UEFI:
- 'BOOT_ACS'
Approximate size: 640 MB
contains bootable applications and test suites.
contains a 'acs_results' directory which stores logs of the automated execution of ACS.
├── EFI
│ └── BOOT
│ ├── Shell.efi
│ ├── bbsr_startup.nsh
│ ├── bootaa64.efi
│ ├── grub.cfg
│ └── startup.nsh
├── acs_tests
│ ├── app
│ │ └── CapsuleApp.efi
│ ├── bbr
│ │ ├── SCT
│ │ ├── ScrtStartup.nsh
│ │ ├── SctStartup.nsh
│ │ └── bbsr_SctStartup.nsh
│ ├── bbsr-keys
│ │ ├── NullPK.auth
│ │ ├── TestDB1.auth
│ │ ├── TestDB1.der
│ │ ├── TestDBX1.auth
│ │ ├── TestDBX1.der
│ │ ├── TestKEK1.auth
│ │ ├── TestKEK1.der
│ │ ├── TestPK1.auth
│ │ └── TestPK1.der
│ ├── bsa
│ │ ├── Bsa.efi
│ │ ├── bsa.nsh
│ │ └── sbsa
│ ├── config
│ │ ├── acs_config.txt
│ │ ├── acs_run_config.ini
│ │ └── system_config.txt
│ ├── debug
│ │ └── debug_dump.nsh
│ └── parser
│ └── Parser.efi
├── acs_results
├── Image
└── ramdisk-buildroot.img
- EFI/BOOT contains the uefi automation startup scripts and grub related files
- Shell.efi - uefi shell executable
- bbsr_startup.nsh - bbsr uefi test startup file
- bootaa64.efi - grub executable
- grub.cfg - grub config file
- startup.nsh - uefi automation run startup file
- acs_tests contains executable files and configs related for test suites
- app directory contains CapsuleApp.efi
- bbr directory contains SCT related bianries and sequence files
- bbsr-keys contains cryptographic keys for secure boot and testing secure firmware updates
- bsa directory contains bsa uefi executable for bsa complaince
- bsa/sbsa directory contains sbsa uefi executable for bsa complaince
- config directory contains system, acs related config files
- debug directory contains script to gather debug information
- parser directory contains uefi parser executable to parse acs_config file
- acs_results will contain result logs of various test suite run
- Image - Linux kernel image file, also contains linux test suites and processing scripts
- /init.sh - linux automation script
- /usr/bin/secure_init.sh - linux automation script for bbsr
- /usr/bin/fwts - fwts executable
- /lib/modules/bsa_acs.ko - BSA Linux test kernel module
- /bin/bsa - BSA Linux app
- /lib/modules/sbsa_acs.ko - SBSA Linux test kernel module
- /bin/sbsa - SBSA Linux app
- /usr/bin/edk2-test-parser - SCT results parser
- /usr/bin/device_driver.sh - device driver script
- /usr/bin/log_parser - directory containing results post processing script
- ramdisk-buildroot.img - ram disk file
│ Linux Boot │
│*SystemReady band ACS (Automation) │
│ SCT for BBSR (optional) │
│ Linux Boot for BBSR (optional) │
│ Linux Boot with SetVirtualAddressMap enabled |
- Linux Boot : This option will boot the ACS Linux kernel and run the default Linux tool (linux debug dump, fwts, linux bsa, linux sbsa (if selected))
- noacs command line parameter: Edit the Linux Boot grub menu option and add noacs at the end of Linux Boot grub menu option, to boot into ACS Linux kernel without running the default Linux test suites.
- initcall_blacklist=psci_checker command line parameter: Edit the Linux Boot grub menu option and add initcall_blacklist=psci_checker to skip default linux psci_checker tool.
- SystemReady band ACS (Automation) : This is default option and will run the automated complaince
- UEFI complaince run - SCT, BSA UEFI, SBSA UEFI (if selected)
- Boots to Linux and run Linux complaince run - FWTS, BSA Linux, SBSA Linux (if selected)
- SCT for BBSR (optional) : This option will run the SCT tests required for BBSR complaince. For the verification steps of BBSR ACS, refer to the BBSR ACS Verification.
- Linux Boot for BBSR (optional) : This option will run the SCT tests required for BBSR complaince. For the verification steps of BBSR ACS, refer to the BBSR ACS Verification.
- Linux Boot with SetVirtualAddressMap enabled : This option is for debug purpose, to boot ACS Linux with SetVAMap on.
-
acs_config.txt: The file specifies the ARM specification version that the ACS tool suite complies with, and this information is included in the System_Information table of the ACS_Summary.html report.
-
acs_run_config.ini: This file is used to manage the execution of various ACS test suites and supports passing parameters to them.
The current options supported are:- SbsaRunEnabled - The value supported is 0 and 1.
- 0: Don't run SBSA complaince in automation run
- 1: Run SBSA complaince in automation run
- SbsaRunEnabled - The value supported is 0 and 1.
-
system_config.txt: The file is used to collect below system information which is required for ACS_Summary.html report, this needs to be manually filled by user.
- FW source code: Unknown
- Flashing instructions: Unknown
- product website: Unknown
- Tested operated Systems: Unknown
- Testlab assistance: Unknown
- The scripts will parse the results generated by various test suite tools and consolidate them into JSON files. These JSON files will adhere to a standard format, maintaining a consistent structure for all test suites
- Also for easier intrepretation, results will also be captured in HTML format.
- The JSON and HTML formatted results are present in /acs_results/acs_summary folder.
- Please follow the waiver application guide on details of waiver application to acs results
- Template of waiver.json can be found here
Note: UEFI EDK2 setting for "Console Preference": The default is "Graphical". When that is selected, Linux output will goes to the graphical console (HDMI monitor). To force serial console output, you may change the "Console Preference" to "Serial".
Follow the steps mentioned in RD-N2 platform software user guide to obtain RD-N2 FVP.
sudo permission is required for building RD-N2 software stack.
For software stack build instructions, follow BusyBox Boot link under Supported Features by RD-N2 platform software stack section in the same guide.
Note: After the download of software stack code, please do the below changes before starting the build steps.
RD-N2 should be built with the GIC changes as mentioned below as applicable.
- If the system supports LPIs (Interrupt ID > 8192) then firmware should support installation of handler for LPI interrupts.
- If you are using edk2, change the ArmGic driver in the ArmPkg to support installation of handler for LPIs.
- Add the following in <path to RDN2 software stack>/uefi/edk2/ArmPkg/Drivers/ArmGic/GicV3/ArmGicV3Dxe.c
- After [#define ARM_GIC_DEFAULT_PRIORITY 0x80] +#define ARM_GIC_MAX_NUM_INTERRUPT 16384 - Change this in GicV3DxeInitialize function. -mGicNumInterrupts = ArmGicGetMaxNumInterrupts (mGicDistributorBase); +mGicNumInterrupts = ARM_GIC_MAX_NUM_INTERRUPT;
-
Set the environment variable 'MODEL'
export MODEL=<absolute path to the RD-N2 FVP binary/FVP_RD_N2>
-
Launch the RD-N2 FVP with the pre-built image with the following command
cd /path to RD-N2_FVP platform software/model-scripts/rdinfra/platforms/rdn2
./run_model.sh -v /path-to-systemready-acs-live-image/systemready_acs_live_image.img
Note: When verifying ACS on hardware, ensure that ACS image is not in two different boot medias (USB, NVMe drives etc) attached to the device.
Known limitations:
On FVP models, with versions previous to 11.15.23, during the execution of the UEFI-SCT suite, the following behavior is observed:
- Execution of the 'UEFIRuntimeServices' tests may cause the test execution on FVP to stall and become non-responsive. The message displayed prior to this stall would be either “System may reset after 1 second…” or a print associated with 'SetTime' tests.
The FVP execution must be terminated and restarted by running the run_model.sh script to continue with the execution of the tests. The execution continues from the test that is next in sequence of the test prior to FVP stall.
- It may appear that the test execution has stalled with the message “Waiting for few seconds for signal …” displayed on the console. This is expected behavior and the progress of tests will continue after a 20-minute delay.
Arm SystemReady band ACS test suite may run at higher privilege level. An attacker may utilize these tests as a means to elevate privilege which can potentially reveal the platform security assets. To prevent the leakage of Secure information, it is strongly recommended that the ACS test suite is run only on development platforms. If it is run on production systems, the system should be scrubbed after running the test suite.
SystemReady ACS is distributed under Apache v2.0 License.
- For feedback, use the GitHub Issue Tracker that is associated with this repository.
- For support, send an email to [email protected] with details.
- Arm licensees can contact Arm directly through their partner managers.
- Arm welcomes code contributions through GitHub pull requests.
Copyright (c) 2022-2024, Arm Limited and Contributors. All rights reserved.