.. # SPDX-FileCopyrightText: Copyright (c) 2023-2024, Linaro Limited. # # SPDX-FileCopyrightText: Copyright 2023-2024 Arm Limited and/or its # affiliates # # SPDX-License-Identifier: MIT ############################################### Getting Started with Arm Corstone-1000 for MPS3 ############################################### This document explains how to build, deploy, and boot the Cassini distro on the Arm Corstone-1000 for MPS3. **NOTE:** Requires a micro SD card (at least 4 GB) and a USB drive (at least 16 GB) .. note:: Due to performance limitations, K3s is not currently supported on the Arm Corstone-1000 for MPS3. ***** Build ***** The kas configuration file ``kas/corstone1000-mps3.yml`` can be used to build images which target the Corstone-1000 for MPS3. ******************** Building MPS3 images ******************** To build Corstone-1000 MPS3 images with default options: .. code-block:: console kas build --update kas/cassini.yml:kas/corstone1000-mps3.yml This will produce a Corstone-1000 firmware image here: ``build/tmp/deploy/images/corstone1000-mps3/corstone1000-flash-firmware-image-corstone1000-mps3.wic`` And a Cassini distribution image here: ``build/tmp/deploy/images/corstone1000-mps3/cassini-image-base-corstone1000-mps3.wic.gz`` ``build/tmp/deploy/images/corstone1000-mps3/cassini-image-base-corstone1000-mps3.wic.bmap`` For other build options, refer to :doc:`../developer_manual/build_system` *************************************************** Prepare the firmware image for FPGA (Micro SD card) *************************************************** The user should download the FPGA bit file image from `this link `__ and under the section ``AN550: Arm® Corstone™-1000 for MPS3 Version 2.0``. Only copy the current directory structure under Boardfiles shown below on to the Micro SD Card. .. code-block:: console config.txt MB ├── BRD_LOG.TXT ├── HBI0309B │ ├── AN550 │ │ ├── AN550_v2.bit │ │ ├── an550_v2.txt │ │ └── images.txt │ ├── board.txt │ └── mbb_v210.ebf └── HBI0309C ├── AN550 │ ├── AN550_v2.bit │ ├── an550_v2.txt │ └── images.txt ├── board.txt └── mbb_v210.ebf SOFTWARE ├── an550_st.axf ├── bl1.bin ├── cs1000.bin └── ES0.bin To configure the board to boot automatically when powered on, edit ``./config.txt`` and change the value of ``AUTORUN`` from ``FALSE`` to ``TRUE``. Depending upon the MPS3 board version (printed on the MPS3 board HBI0309B or HBI0309C) you should update the ``./AN550/images.txt`` file so that the file points to the images under SOFTWARE directory. Here is an example .. code-block:: console ;************************************************ ; Preload port mapping * ;************************************************ ; PORT 0 & ADDRESS: 0x00_0000_0000 QSPI Flash (XNVM) (32MB) ; PORT 0 & ADDRESS: 0x00_8000_0000 OCVM (DDR4 2GB) ; PORT 1 Secure Enclave (M0+) ROM (64KB) ; PORT 2 External System 0 (M3) Code RAM (256KB) ; PORT 3 Secure Enclave OTP memory (8KB) ; PORT 4 CVM (4MB) ;************************************************ [IMAGES] TOTALIMAGES: 3 ;Number of Images (Max: 32) IMAGE0PORT: 1 IMAGE0ADDRESS: 0x00_0000_0000 IMAGE0UPDATE: RAM IMAGE0FILE: \SOFTWARE\bl1.bin IMAGE1PORT: 0 IMAGE1ADDRESS: 0x00_0000_0000 IMAGE1UPDATE: AUTOQSPI IMAGE1FILE: \SOFTWARE\cs1000.bin IMAGE2PORT: 2 IMAGE2ADDRESS: 0x00_0000_0000 IMAGE2UPDATE: RAM IMAGE2FILE: \SOFTWARE\es0.bin The binaries are present in OUTPUT_DIR = ``<_workspace>/build/tmp/deploy/images/corstone1000-mps3`` directory. 1. Copy ``bl1.bin`` from OUTPUT_DIR to SOFTWARE directory of the Micro SD card. 2. Copy ``corstone1000-flash-firmware-image-corstone1000-mps3.wic`` from OUTPUT_DIR directory to SOFTWARE directory of the Micro SD card and rename the wic image to ``cs1000.bin``. 3. Copy ``es_flashfw.bin`` from OUTPUT_DIR directory to SOFTWARE directory of the Micro SD card and rename to ``es0.bin``. **NOTE:** Renaming of the images are required because MCC firmware has limitation of 8 characters before .(dot) and 3 characters after .(dot). ********************************************* Prepare the distro image for FPGA (USB image) ********************************************* Use the ``lsblk`` command to determine USB drive and bmap tool to copy the cassini distro to it. .. code-block:: console lsblk sudo bmaptool copy --bmap cassini-image-base-corstone1000-mps3.wic.bmap cassini-image-base-corstone1000-mps3.wic.gz /dev/ .. note:: `bmaptool` may fail if the host auto-mounts partitions on the USB drive. If these issues are seen then, disable auto-mounting or use `parted` or `fdisk` to remove any existing partitions. **************************** Running the software on FPGA **************************** Insert SD card and USB drive before switching ON the device. On the host machine, connect the board via USB. If there are no other TTY USB devices, then the three ports from the MPS3 will be connected as follows: - ttyUSB0 for MCC, OP-TEE and Secure Partition - ttyUSB1 for Boot Processor (Cortex-M0+) - ttyUSB2 for Host Processor (Cortex-A35) The rest of this guide assumes there are no other TTY USB devices on the host machine. Connect to the serial console(s) using any terminal client (``picocom``, ``minicom``, or ``screen`` should all work). For example, run the following commands to open new picocom sessions for each port: .. code-block:: console sudo picocom -b 115200 /dev/ttyUSB0 sudo picocom -b 115200 /dev/ttyUSB1 sudo picocom -b 115200 /dev/ttyUSB2 .. note:: ``sudo`` should not be required if the current user is in the ``dialout`` group .. note:: See notes under :ref:`run-time_integration_tests_label` before running validation steps.