# CMSIS-Core Validation This folder contains a test suite that validates CMSIS-Core implementations. It uses [**Fixed Virtual Platforms**](https://developer.arm.com/Tools%20and%20Software/Fixed%20Virtual%20Platforms) to run tests to verify correct operation of the CMSIS-Core functionality on various Arm Cortex based processors. ## Folder structure ```txt 📂 CoreValidation ┣ 📂 Include Include files for test cases etc. ┣ 📂 Layer Layers for creating the projects. ┣ 📂 Project Solution and project files to build tests for various configurations. ┗ 📂 Source Test case source code. ``` ## Test matrix Currently, the following build configurations are provided: 1. Compiler - Arm Compiler 6 (AC6) - GNU Compiler (GCC) - LLVM/Clang (Clang) 2. Devices - Cortex-M0 - Cortex-M0+ - Cortex-M3 - Cortex-M4 (with FPU) - Cortex-M7 (with DP FPU) - Cortex-M23 - w/o security extensions (TrustZone) - in secure mode - in non-secure mode - Cortex-M33 (with FPU and DSP extensions) - w/o security extensions (TrustZone) - in secure mode - in non-secure mode - Cortex-M35P (with FPU and DSP extensions) - w/o security extensions (TrustZone) - in secure mode - in non-secure mode - Cortex-M55 (with FPU and DSP extensions) - w/o security extensions (TrustZone) - in secure mode - in non-secure mode - Cortex-M85 (with FPU and DSP extensions) - w/o security extensions (TrustZone) - in secure mode - in non-secure mode - Cortex-A5 - w/o NEON extensions - Cortex-A7 - w/o NEON extensions - Cortex-A9 - w/o NEON extensions 3. Optimization Levels - none - balanced - size - speed ## Prerequisites The following tools are required to build and run the CoreValidation tests: - [CMSIS-Toolbox 2.1.0](https://artifacts.keil.arm.com/cmsis-toolbox/2.1.0/)* - [CMake 3.25.2](https://cmake.org/download/)* - [Ninja 1.10.2](https://github.com/ninja-build/ninja/releases)* - [Arm Compiler 6.20](https://artifacts.keil.arm.com/arm-compiler/6.20/21/)* - [GCC Compiler 13.2.1](https://artifacts.keil.arm.com/arm-none-eabi-gcc/13.2.1/)* - [Clang Compiler 17.0.1](https://github.com/ARM-software/LLVM-embedded-toolchain-for-Arm/releases/tag/release-17.0.1)* - [Arm Virtual Hardware for Cortex-M based on FastModels 11.22.39](https://artifacts.keil.arm.com/avh/11.22.39/)* - [Python 3.9](https://www.python.org/downloads/) The executables need to be present on the `PATH`. For tools distributed via vcpkg (*) this can be achieved automatically: ```bash ./CMSIS/CoreValidation/Project $ vcpkg activate ``` Install the Python packages required by `build.py`: ```bash ./CMSIS/CoreValidation/Project $ pip install -r requirements.txt ``` ## Build and run To build and run the CoreValidation tests for one or more configurations use the following command line. Select the ``, ``, and `` level to `build` and `run` for. ```bash ./CMSIS/CoreValidation/Project $ ./build.py -c -d -o [build] [run] ``` For example, build and run the tests using GCC for Cortex-M3 with low optimization, execute: ```bash ./CMSIS/CoreValidation/Project $ ./build.py -c GCC -d CM3 -o none build run [GCC][Cortex-M3][none](build:csolution) csolution convert -s Validation.csolution.yml -c Validation.GCC_low+CM3 [GCC][Cortex-M3][none](build:csolution) csolution succeeded with exit code 0 [GCC][Cortex-M3][none](build:cbuild) cbuild Validation.GCC_low+CM3/Validation.GCC_low+CM3.cprj [GCC][Cortex-M3][none](build:cbuild) cbuild succeeded with exit code 0 [GCC][Cortex-M3][none](run:model_exec) VHT_MPS2_Cortex-M3 -q --simlimit 100 -f ../Layer/Target/CM3/model_config.txt -a Validation.GCC_low+CM3/Validation.GCC_low+CM3_outdir/Validation.GCC_low+CM3.elf [GCC][Cortex-M3][none](run:model_exec) VHT_MPS2_Cortex-M3 succeeded with exit code 0 Matrix Summary ============== compiler device optimize build clean extract run ---------- --------- ---------- ------- ------- --------- ----- GCC Cortex-M3 none success (skip) (skip) 35/35 ``` The full test report is written to `Core_Validation-GCC-none-CM3-.junit` file. ## License [![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)