562 lines
28 KiB
PHP
562 lines
28 KiB
PHP
#@DESCRIPTION: Common Machine configuration for STM32 systems
|
|
|
|
require conf/machine/include/st-machine-extlinux-config-stm32mp.inc
|
|
require conf/machine/include/st-machine-features-stm32mp.inc
|
|
require conf/machine/include/st-machine-flashlayout-stm32mp.inc
|
|
require conf/machine/include/st-machine-flashlayout-deleteall-stm32mp.inc
|
|
require conf/machine/include/st-machine-flashlayout-extensible-stm32mp.inc
|
|
require conf/machine/include/st-machine-storage-device-stm32mp.inc
|
|
|
|
# Define specific common machine name
|
|
MACHINEOVERRIDES .= ":stcommon"
|
|
|
|
# Define specific common layer name
|
|
MACHINEOVERRIDES .= ":stm32mpcommon"
|
|
|
|
# =========================================================================
|
|
# boot scheme
|
|
# =========================================================================
|
|
# List of supported boot schemes
|
|
BOOTSCHEME_LABELS ??= "trusted optee"
|
|
|
|
# =========================================================================
|
|
# boot device
|
|
# =========================================================================
|
|
# List of supported boot devices
|
|
BOOTDEVICE_LABELS ??= "emmc nand-4-256 nor-sdcard sdcard"
|
|
|
|
# =========================================================================
|
|
# Machine settings
|
|
# =========================================================================
|
|
# Default machine feature
|
|
MACHINE_FEATURES = "usbhost usbgadget alsa screen ext2"
|
|
MACHINE_FEATURES_append = " ${@bb.utils.contains('BOOTSCHEME_LABELS', 'optee', 'optee', '', d)} "
|
|
MACHINE_FEATURES_append = " tpm2 "
|
|
|
|
# Remove autoresize package from DISTRO_EXTRA_RRECOMMENDS to add it explicitly
|
|
# in our bootfs image instead of rootfs
|
|
DISTRO_EXTRA_RRECOMMENDS_remove = "${@bb.utils.contains('COMBINED_FEATURES', 'autoresize', '${AUTORESIZE}', '', d)}"
|
|
|
|
# Use Little Kernel loader to program storage device
|
|
MACHINE_FEATURES += "kloader"
|
|
|
|
# Use FIP image for boot loaders
|
|
MACHINE_FEATURES += "fip"
|
|
|
|
# Default serial consoles (TTYs) to enable using getty
|
|
# Before kernel 4.18, serial console are ttyS3 but after is ttySTM0
|
|
SERIAL_CONSOLES = "115200;ttySTM0"
|
|
SERIAL_CONSOLE = "115200 ttySTM0"
|
|
|
|
# Don't include kernels in standard images
|
|
RDEPENDS_${KERNEL_PACKAGE_NAME}-base = ""
|
|
|
|
# Ship all kernel modules by default
|
|
MACHINE_EXTRA_RRECOMMENDS = " kernel-modules"
|
|
|
|
# Default device tree list supported per board
|
|
STM32MP_DT_FILES_DK ??= ""
|
|
STM32MP_DT_FILES_ED ??= ""
|
|
STM32MP_DT_FILES_EV ??= ""
|
|
# Set default supported device tree list
|
|
STM32MP_DEVICETREE_append = " ${STM32MP_DT_FILES_DK} "
|
|
STM32MP_DEVICETREE_append = " ${STM32MP_DT_FILES_ED} "
|
|
STM32MP_DEVICETREE_append = " ${STM32MP_DT_FILES_EV} "
|
|
|
|
# =========================================================================
|
|
# Machine specific packages
|
|
# =========================================================================
|
|
# Enable Software watchdog when sysvinit
|
|
MACHINE_EXTRA_RRECOMMENDS_append = " ${@bb.utils.contains('DISTRO_FEATURES','sysvinit',' watchdog ','',d)} "
|
|
|
|
# =========================================================================
|
|
# Bootloader raw partition configuration : data, label, size (Kbytes)
|
|
# =========================================================================
|
|
# -----------------------------------------------------------------------------
|
|
# NOTE: There are few restrictions to follow:
|
|
# - The partition for the first boot loader should follow the naming
|
|
# rule: fsbl*
|
|
# - The partition for the secondary boot loader should follow the naming
|
|
# rule: ssbl or fip
|
|
# -----------------------------------------------------------------------------
|
|
STM32MP_FSBL1_DATA ?= "${@bb.utils.contains('MACHINE_FEATURES', 'fip', 'arm-trusted-firmware/tf-a-<TYPE>-<DEVICE>.stm32', 'arm-trusted-firmware/tf-a-<TYPE>-<BOOTSCHEME>.stm32', d)}"
|
|
STM32MP_FSBL1_NAME ?= "fsbl1"
|
|
STM32MP_FSBL1_SIZE ?= "256"
|
|
STM32MP_FSBL2_DATA ?= "${STM32MP_FSBL1_DATA}"
|
|
STM32MP_FSBL2_NAME ?= "fsbl2"
|
|
STM32MP_FSBL2_SIZE ?= "${STM32MP_FSBL1_SIZE}"
|
|
STM32MP_SSBL1_DATA ?= "${@bb.utils.contains('MACHINE_FEATURES', 'fip', 'fip/fip-<TYPE>-<BOOTSCHEME>${FIP_SIGN_SUFFIX}.bin', 'u-boot/u-boot-<TYPE>-trusted.stm32', d)}"
|
|
STM32MP_SSBL1_NAME ?= "${@bb.utils.contains('MACHINE_FEATURES', 'fip', 'fip', 'ssbl', d)}"
|
|
STM32MP_SSBL1_SIZE ?= "${@bb.utils.contains('MACHINE_FEATURES', 'fip', '4096', '2048', d)}"
|
|
STM32MP_SSBL2_DATA ?= "${STM32MP_SSBL1_DATA}"
|
|
STM32MP_SSBL2_NAME ?= "${@bb.utils.contains('MACHINE_FEATURES', 'fip', 'fip2', 'ssbl2', d)}"
|
|
STM32MP_SSBL2_SIZE ?= "${STM32MP_SSBL1_SIZE}"
|
|
STM32MP_UENV_DATA ?= ""
|
|
STM32MP_UENV_NAME ?= "env"
|
|
STM32MP_UENV_SIZE ?= "512"
|
|
STM32MP_TEEH_DATA ?= "optee/tee-header_v2-<TYPE>.stm32"
|
|
STM32MP_TEEH_NAME ?= "teeh"
|
|
STM32MP_TEEH_SIZE ?= "256"
|
|
STM32MP_TEED_DATA ?= "optee/tee-pageable_v2-<TYPE>.stm32"
|
|
STM32MP_TEED_NAME ?= "teed"
|
|
STM32MP_TEED_SIZE ?= "512"
|
|
STM32MP_TEEX_DATA ?= "optee/tee-pager_v2-<TYPE>.stm32"
|
|
STM32MP_TEEX_NAME ?= "teex"
|
|
STM32MP_TEEX_SIZE ?= "256"
|
|
|
|
# Specific override for NAND device type regarding partition sizes to follow
|
|
# the hard coded configuration on U-Boot source code
|
|
STM32MP_FSBL1_SIZE_UBOOT ?= "1024"
|
|
STM32MP_TEEH_SIZE_UBOOT ?= "512"
|
|
STM32MP_TEEX_SIZE_UBOOT ?= "512"
|
|
|
|
# Bootloader Partitions configuration
|
|
PARTITIONS_BOOTLOADER_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'emmc', 'emmc', '', d)}"
|
|
PARTITIONS_BOOTLOADER_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', 'nand-4-256', '', d)}"
|
|
PARTITIONS_BOOTLOADER_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nor-sdcard', 'nor-sdcard', '', d)}"
|
|
PARTITIONS_BOOTLOADER_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'sdcard', 'sdcard', '', d)}"
|
|
PARTITIONS_BOOTLOADER_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'spinand-2-128', 'spinand-2-128', '', d)}"
|
|
|
|
# <binary_name>,<partlabel>,<size>,<type>,<copy>
|
|
PARTITIONS_BOOTLOADER_CONFIG[emmc] ?= "\
|
|
${@ '${STM32MP_FSBL1_DATA},${STM32MP_FSBL1_NAME},${STM32MP_FSBL1_SIZE},Binary,1' if '${STM32MP_FSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_FSBL2_DATA},${STM32MP_FSBL2_NAME},${STM32MP_FSBL2_SIZE},Binary,1' if '${STM32MP_FSBL2_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL1_DATA},${STM32MP_SSBL1_NAME},${STM32MP_SSBL1_SIZE},Binary,1' if '${STM32MP_SSBL1_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_BOOTLOADER_CONFIG[nand-4-256] ?= "\
|
|
${@ '${STM32MP_FSBL1_DATA},${STM32MP_FSBL1_NAME},${STM32MP_FSBL1_SIZE_UBOOT},Binary,2' if '${STM32MP_FSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL1_DATA},${STM32MP_SSBL1_NAME},${STM32MP_SSBL1_SIZE},Binary,1' if '${STM32MP_SSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL2_DATA},${STM32MP_SSBL2_NAME},${STM32MP_SSBL2_SIZE},Binary,1' if '${STM32MP_SSBL2_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_BOOTLOADER_CONFIG[nor-sdcard] ?= "\
|
|
${@ '${STM32MP_FSBL1_DATA},${STM32MP_FSBL1_NAME},${STM32MP_FSBL1_SIZE},Binary,1' if '${STM32MP_FSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_FSBL2_DATA},${STM32MP_FSBL2_NAME},${STM32MP_FSBL2_SIZE},Binary,1' if '${STM32MP_FSBL2_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL1_DATA},${STM32MP_SSBL1_NAME},${STM32MP_SSBL1_SIZE},Binary,1' if '${STM32MP_SSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_UENV_DATA},${STM32MP_UENV_NAME},${STM32MP_UENV_SIZE},Binary,1' if '${STM32MP_UENV_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_BOOTLOADER_CONFIG[sdcard] ?= "\
|
|
${@ '${STM32MP_FSBL1_DATA},${STM32MP_FSBL1_NAME},${STM32MP_FSBL1_SIZE},Binary,1' if '${STM32MP_FSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_FSBL2_DATA},${STM32MP_FSBL2_NAME},${STM32MP_FSBL2_SIZE},Binary,1' if '${STM32MP_FSBL2_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL1_DATA},${STM32MP_SSBL1_NAME},${STM32MP_SSBL1_SIZE},Binary,1' if '${STM32MP_SSBL1_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_BOOTLOADER_CONFIG[spinand-2-128] ?= "\
|
|
${@ '${STM32MP_FSBL1_DATA},${STM32MP_FSBL1_NAME},${STM32MP_FSBL1_SIZE_UBOOT},Binary,2' if '${STM32MP_FSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL1_DATA},${STM32MP_SSBL1_NAME},${STM32MP_SSBL1_SIZE},Binary,1' if '${STM32MP_SSBL1_NAME}' else ''} \
|
|
${@ '${STM32MP_SSBL2_DATA},${STM32MP_SSBL2_NAME},${STM32MP_SSBL2_SIZE},Binary,1' if '${STM32MP_SSBL2_NAME}' else ''} \
|
|
"
|
|
|
|
# Optee Partitions configuration
|
|
PARTITIONS_OPTEE_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'emmc', 'emmc', '', d)}"
|
|
PARTITIONS_OPTEE_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', 'nand-4-256', '', d)}"
|
|
PARTITIONS_OPTEE_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nor-sdcard', 'nor-sdcard', '', d)}"
|
|
PARTITIONS_OPTEE_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'sdcard', 'sdcard', '', d)}"
|
|
PARTITIONS_OPTEE_CONFIG += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'spinand-2-128', 'spinand-2-128', '', d)}"
|
|
|
|
# <binary_name>,<partlabel>,<size>,<type>,<copy>
|
|
PARTITIONS_OPTEE_CONFIG[emmc] ?= "\
|
|
${@ '${STM32MP_TEEH_DATA},${STM32MP_TEEH_NAME},${STM32MP_TEEH_SIZE},Binary,1' if '${STM32MP_TEEH_NAME}' else ''} \
|
|
${@ '${STM32MP_TEED_DATA},${STM32MP_TEED_NAME},${STM32MP_TEED_SIZE},Binary,1' if '${STM32MP_TEED_NAME}' else ''} \
|
|
${@ '${STM32MP_TEEX_DATA},${STM32MP_TEEX_NAME},${STM32MP_TEEX_SIZE},Binary,1' if '${STM32MP_TEEX_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_OPTEE_CONFIG[nand-4-256] ?= "\
|
|
${@ '${STM32MP_TEEH_DATA},${STM32MP_TEEH_NAME},${STM32MP_TEEH_SIZE_UBOOT},Binary,1' if '${STM32MP_TEEH_NAME}' else ''} \
|
|
${@ '${STM32MP_TEED_DATA},${STM32MP_TEED_NAME},${STM32MP_TEED_SIZE},Binary,1' if '${STM32MP_TEED_NAME}' else ''} \
|
|
${@ '${STM32MP_TEEX_DATA},${STM32MP_TEEX_NAME},${STM32MP_TEEX_SIZE_UBOOT},Binary,1' if '${STM32MP_TEEX_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_OPTEE_CONFIG[nor-sdcard] ?= "\
|
|
${@ '${STM32MP_TEEH_DATA},${STM32MP_TEEH_NAME},${STM32MP_TEEH_SIZE},Binary,1' if '${STM32MP_TEEH_NAME}' else ''} \
|
|
${@ '${STM32MP_TEED_DATA},${STM32MP_TEED_NAME},${STM32MP_TEED_SIZE},Binary,1' if '${STM32MP_TEED_NAME}' else ''} \
|
|
${@ '${STM32MP_TEEX_DATA},${STM32MP_TEEX_NAME},${STM32MP_TEEX_SIZE},Binary,1' if '${STM32MP_TEEX_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_OPTEE_CONFIG[sdcard] ?= "\
|
|
${@ '${STM32MP_TEEH_DATA},${STM32MP_TEEH_NAME},${STM32MP_TEEH_SIZE},Binary,1' if '${STM32MP_TEEH_NAME}' else ''} \
|
|
${@ '${STM32MP_TEED_DATA},${STM32MP_TEED_NAME},${STM32MP_TEED_SIZE},Binary,1' if '${STM32MP_TEED_NAME}' else ''} \
|
|
${@ '${STM32MP_TEEX_DATA},${STM32MP_TEEX_NAME},${STM32MP_TEEX_SIZE},Binary,1' if '${STM32MP_TEEX_NAME}' else ''} \
|
|
"
|
|
PARTITIONS_OPTEE_CONFIG[spinand-2-128] ?= "\
|
|
${@ '${STM32MP_TEEH_DATA},${STM32MP_TEEH_NAME},${STM32MP_TEEH_SIZE_UBOOT},Binary,1' if '${STM32MP_TEEH_NAME}' else ''} \
|
|
${@ '${STM32MP_TEED_DATA},${STM32MP_TEED_NAME},${STM32MP_TEED_SIZE},Binary,1' if '${STM32MP_TEED_NAME}' else ''} \
|
|
${@ '${STM32MP_TEEX_DATA},${STM32MP_TEEX_NAME},${STM32MP_TEEX_SIZE_UBOOT},Binary,1' if '${STM32MP_TEEX_NAME}' else ''} \
|
|
"
|
|
|
|
# =========================================================================
|
|
# Image
|
|
# =========================================================================
|
|
# For sparse, align on 4096b
|
|
IMAGE_ROOTFS_ALIGNMENT ?= "4"
|
|
|
|
# Enable licence summary and configure License content generation
|
|
ENABLE_IMAGE_LICENSE_SUMMARY ?= "1"
|
|
|
|
# Partitions configuration
|
|
IMAGE_CLASSES += "st-partitions-image"
|
|
|
|
# Define image to use for extra partitions
|
|
STM32MP_BOOTFS_IMAGE ?= "st-image-bootfs"
|
|
STM32MP_BOOTFS_LABEL ?= "boot"
|
|
STM32MP_BOOTFS_MOUNTPOINT ?= "/boot"
|
|
STM32MP_USERFS_IMAGE ?= "st-image-userfs"
|
|
STM32MP_USERFS_LABEL ?= "userfs"
|
|
STM32MP_USERFS_MOUNTPOINT ?= "/usr/local"
|
|
STM32MP_VENDORFS_IMAGE ?= "st-image-vendorfs"
|
|
STM32MP_VENDORFS_LABEL ?= "vendorfs"
|
|
STM32MP_VENDORFS_MOUNTPOINT ?= "/vendor"
|
|
|
|
# Define image partition size (supposed to be set as max size in image recipe)
|
|
# Proposed value for bootfs is 64MB
|
|
BOOTFS_PARTITION_SIZE ?= "65536"
|
|
# Proposed value for rootfs should fit our highest constraint: NAND size (1GiB)
|
|
# For optee bootscheme we have the maximum partitions:
|
|
# FSBL1 + SSBL + SSBL2 + TEEH + TEED + TEEX + Multivolume UBI = NAND size
|
|
# Multivolume UBI = 1GiB - (2MiB + 2MiB + 2MiB + 512KiB + 512KiB + 512KiB) = 1016.5MiB
|
|
# With multivolume UBI split:
|
|
# Multivolume UBI > uboot_config + uboot_config_r + bootfs + vendorfs + rootfs + userfs + UBI Overhead
|
|
# From http://www.linux-mtd.infradead.org/doc/ubi.html#L_overhead, we compute
|
|
# the UBI overhead for our NAND:
|
|
# (20*4096/1024 + 4) * 256KiB + (256KiB - 248KiB) * (1016.5MiB/256KiB - 20*4096/1024 - 4) = 53360KiB
|
|
# In addition, for each UBIFS, our NAND consummed 9 extra eraseblocks
|
|
# So:
|
|
# rootfs < Multivolume UBI - (uboot_config + uboot_config_r + bootfs + vendorfs + userfs + UBI Overhead + 4 * 9*eraseblocks)
|
|
# rootfs < 1016.5MiB - (256KiB + 256KiB + 64MiB + 16MiB + 128MiB + 53360KiB + 4 * 9 * 256KiB)
|
|
# rootfs < 746.8MiB
|
|
# Proposed value for rootfs is 746MiB
|
|
# Define max size for ROOTFS image being built to this value
|
|
IMAGE_ROOTFS_MAXSIZE ?= "763904"
|
|
# And configure the ROOTFS_PARTITION_SIZE variable accordingly
|
|
ROOTFS_PARTITION_SIZE ?= "${IMAGE_ROOTFS_MAXSIZE}"
|
|
# Proposed value for userfs is 128MB (4*32MB)
|
|
USERFS_PARTITION_SIZE ?= "131072"
|
|
# Proposed value for vendorfs is 16MB
|
|
VENDORFS_PARTITION_SIZE ?= "16384"
|
|
|
|
# Enable use of extra partition(s)
|
|
ST_BOOTFS ?= "1"
|
|
ST_VENDORFS ?= "1"
|
|
ST_USERFS ?= "1"
|
|
|
|
# Partitions configuration
|
|
PARTITIONS_CONFIG += "${@bb.utils.contains('ST_BOOTFS', '1', 'bootfs', '', d)}"
|
|
PARTITIONS_CONFIG += "${@bb.utils.contains('ST_VENDORFS', '1', 'vendorfs', '', d)}"
|
|
PARTITIONS_CONFIG += "rootfs"
|
|
PARTITIONS_CONFIG += "${@bb.utils.contains('ST_USERFS', '1', 'userfs', '', d)}"
|
|
|
|
PARTITIONS_CONFIG[bootfs] ?= "${STM32MP_BOOTFS_IMAGE},${STM32MP_BOOTFS_LABEL},${STM32MP_BOOTFS_MOUNTPOINT},${BOOTFS_PARTITION_SIZE},System"
|
|
PARTITIONS_CONFIG[vendorfs] ?= "${STM32MP_VENDORFS_IMAGE},${STM32MP_VENDORFS_LABEL},${STM32MP_VENDORFS_MOUNTPOINT},${VENDORFS_PARTITION_SIZE},FileSystem"
|
|
PARTITIONS_CONFIG[rootfs] ?= "${IMAGE_BASENAME},rootfs,,${ROOTFS_PARTITION_SIZE},FileSystem"
|
|
PARTITIONS_CONFIG[userfs] ?= "${STM32MP_USERFS_IMAGE},${STM32MP_USERFS_LABEL},${STM32MP_USERFS_MOUNTPOINT},${USERFS_PARTITION_SIZE},FileSystem"
|
|
|
|
# UBI Configuration
|
|
IMAGE_CLASSES += "image_types-stubi"
|
|
|
|
# Define two empty volumes to manage U-Boot config beginning of multivolume UBIFS
|
|
STM32MP_UBI_VOLUME_prepend = "uboot_config:256:empty uboot_config_r:256:empty "
|
|
|
|
# Define UBI volume label to use in kernel command line to mount UBI file system
|
|
UBI_VOLNAME ?= "rootfs"
|
|
|
|
# Define UBI labels to build
|
|
# Naming rules for UBI partitions:
|
|
# nand_<PageSize>_<BlockSize>
|
|
# nor_<BlockSize>
|
|
# Like that a same UBI partition can be used for severals NAND/NOR providers
|
|
MULTIUBI_BUILD += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', 'nand_4_256', '', d)}"
|
|
|
|
# UBI Args for NAND by default on MB1262 (Micron MT29F8G16ABACAH4)
|
|
# LEB = BLOCK_SIZE - (2 * page size): 256*1024 - (2*4096)
|
|
MKUBIFS_ARGS_nand_4_256 = "--min-io-size 4096 --leb-size 253952 --max-leb-cnt 4096 --space-fixup"
|
|
UBINIZE_ARGS_nand_4_256 = "--min-io-size 4096 --peb-size 256KiB"
|
|
# Set extra size required for UBIFS volume size (KiB)
|
|
EXTRA_UBIFS_SIZE_nand_4_256 = "2304"
|
|
|
|
# Default FSTYPES requested
|
|
WKS_IMAGE_FSTYPES ?= ""
|
|
IMAGE_FSTYPES ?= "${WKS_IMAGE_FSTYPES} tar.xz ext4"
|
|
# Append ubi FSTYPES to default ones for nand volumes
|
|
IMAGE_FSTYPES += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', 'stmultiubi', '', d)}"
|
|
|
|
# Define specific EXT4 command line:
|
|
# - Create minimal inode number (as it is done by default in image_types.bbclass)
|
|
# - Add label name (maximum length of the volume label is 16 bytes)
|
|
# So use IMAGE_NAME_SUFFIX name by removing the '.' and truncing to 16 caracters
|
|
# - Deactivate metadata_csum and dir_index (hashed b-trees): update not supported
|
|
# by U-Boot
|
|
EXTRA_IMAGECMD_ext4 = "-i 4096 -L ${@d.getVar('IMAGE_NAME_SUFFIX').replace('.', '', 1)[:16]} -O ^metadata_csum,^dir_index"
|
|
|
|
# Allow debug on the platform with gdb and openocd tools
|
|
EXTRA_IMAGEDEPENDS_append = " \
|
|
gdb-cross-${TARGET_ARCH} \
|
|
openocd-stm32mp-native \
|
|
stm32wrapper4dbg-native \
|
|
sdcard-raw-tools-native \
|
|
"
|
|
|
|
# Make sure to provide all expected tools in SDK
|
|
ST_TOOLS_FOR_SDK = " \
|
|
nativesdk-gcc-arm-none-eabi \
|
|
nativesdk-binutils \
|
|
nativesdk-openocd-stm32mp \
|
|
nativesdk-stm32wrapper4dbg \
|
|
nativesdk-sdcard-raw-tools \
|
|
nativesdk-ncurses-libncursesw \
|
|
"
|
|
|
|
# For support of perl ansicolor
|
|
ST_TOOLS_FOR_SDK_PERL = " \
|
|
nativesdk-perl-module-term-ansicolor \
|
|
nativesdk-perl-module-encode \
|
|
nativesdk-perl-module-encode-mime-header \
|
|
"
|
|
|
|
# For some scripts in kernel source code
|
|
ST_TOOLS_FOR_SDK_PERL = " \
|
|
nativesdk-perl-module-file-spec-functions \
|
|
"
|
|
|
|
ST_TOOLS_FOR_SDK_append = " ${ST_TOOLS_FOR_SDK_PERL} "
|
|
|
|
# For support of python module for optee-os
|
|
ST_TOOLS_FOR_SDK_append = " \
|
|
nativesdk-python3-pyelftools \
|
|
nativesdk-python3-pycryptodomex \
|
|
nativesdk-python3-pycrypto \
|
|
"
|
|
|
|
# For support of string convertion (iconv) in SDK
|
|
ST_TOOLS_FOR_SDK_append = " \
|
|
nativesdk-glibc-gconv-utf-16 \
|
|
nativesdk-glibc-gconv-utf-32 \
|
|
"
|
|
# For support wayland-scanner in SDK
|
|
ST_TOOLS_FOR_SDK_append = " \
|
|
nativesdk-wayland \
|
|
"
|
|
|
|
# For Kernel yaml dependency
|
|
ST_TOOLS_FOR_SDK_remove = " \
|
|
nativesdk-libyaml \
|
|
nativesdk-libyaml-dev \
|
|
"
|
|
|
|
# For CMSIS-SVD file parser with GDB
|
|
ST_TOOLS_FOR_SDK_append = " \
|
|
nativesdk-svd-tools \
|
|
"
|
|
|
|
# Fip tool
|
|
ST_TOOLS_FOR_SDK_append = " \
|
|
${@bb.utils.contains('MACHINE_FEATURES', 'fip', 'nativesdk-${FIPTOOL_WRAPPER}', '', d)} \
|
|
"
|
|
|
|
# Make sure to append mkimage to SDK for kernel uImage build
|
|
ST_DEPENDENCIES_BUILD_FOR_SDK = " \
|
|
${@bb.utils.contains('KERNEL_IMAGETYPE', 'uImage', 'nativesdk-u-boot-mkimage', '', d)} \
|
|
${@bb.utils.contains('KERNEL_ALT_IMAGETYPE', 'uImage', 'nativesdk-u-boot-mkimage', '', d)} \
|
|
"
|
|
# Make sure to append openssl to SDK for kernel-module and scripts build
|
|
ST_DEPENDENCIES_BUILD_FOR_SDK_append = " nativesdk-openssl-dev "
|
|
|
|
# Make sure to append bison to SDK for u-boot build
|
|
ST_DEPENDENCIES_BUILD_FOR_SDK_append = " \
|
|
${@bb.utils.contains('EXTRA_IMAGEDEPENDS', 'u-boot-stm32mp', 'nativesdk-bison', '', d)} \
|
|
"
|
|
|
|
# for populate_sdk, we will have all the tools
|
|
TOOLCHAIN_HOST_TASK_append = " ${ST_TOOLS_FOR_SDK} "
|
|
TOOLCHAIN_HOST_TASK_append = " ${ST_DEPENDENCIES_BUILD_FOR_SDK} "
|
|
# for populate_sdk_ext, the tools are not desired as mandatory tools (aka basic
|
|
# tools for devtool)
|
|
TOOLCHAIN_HOST_TASK_remove_task-populate-sdk-ext = " ${ST_TOOLS_FOR_SDK} "
|
|
TOOLCHAIN_HOST_TASK_remove_task-populate-sdk-ext = " ${ST_DEPENDENCIES_BUILD_FOR_SDK} "
|
|
# buildtools is used only by populate_sdk_ext
|
|
# populate_sdk_ext = buildtools + uninative + layer
|
|
# buildtools: sdk part of esdk (like sdk generated by populate_sdk)
|
|
# uninative: basic tools for devtool
|
|
TOOLCHAIN_HOST_TASK_remove_pn-buildtools-tarball = " ${ST_TOOLS_FOR_SDK_PERL} "
|
|
|
|
TOOLCHAIN_TARGET_TASK += " bash-dev libgomp-dev"
|
|
TOOLCHAIN_TARGET_TASK_remove_pn-buildtools-tarball = " bash-dev libgomp-dev"
|
|
|
|
# =========================================================================
|
|
# Kernel
|
|
# =========================================================================
|
|
# Kernel image type
|
|
KERNEL_IMAGETYPE = "${@bb.utils.contains('MACHINE_FEATURES', 'fit', 'fitImage', 'uImage', d)}"
|
|
KERNEL_ALT_IMAGETYPE = " Image "
|
|
KERNEL_ALT_IMAGETYPE =+ " vmlinux "
|
|
KERNEL_ALT_IMAGETYPE =+ " ${@bb.utils.contains('MACHINE_FEATURES', 'fit', 'uImage', 'zImage', d)} "
|
|
|
|
# Maxsize authorized for uncompressed kernel binary
|
|
# Define to null to skip kernel image size check
|
|
KERNEL_IMAGE_MAXSIZE ?= ""
|
|
|
|
# For fit usage
|
|
UBOOT_ENTRYPOINT = "0xC0800000"
|
|
|
|
# List of device tree to install
|
|
KERNEL_DEVICETREE ?= "${STM32MP_KERNEL_DEVICETREE}"
|
|
STM32MP_KERNEL_DEVICETREE += "${@' '.join('%s.dtb' % d for d in '${STM32MP_DEVICETREE}'.split())}"
|
|
STM32MP_KERNEL_DEVICETREE += "${@' '.join('%s.dtb' % d for d in '${CUBE_M4_EXAMPLES_DT}'.split())}"
|
|
STM32MP_KERNEL_DEVICETREE += "${@' '.join('%s.dtb' % d for d in '${LINUX_A7_EXAMPLES_DT}'.split())}"
|
|
|
|
# Set LOADADDR
|
|
# Set this address to 0xC2000040, which is 0xC2000000 + 0x40.
|
|
# 0xC2000000 is the memory address where U-Boot will copy from flash the file uImage and 0x40 is uImage header size (64Bytes).
|
|
# With this value, U-Boot will be able to execute in place the zImage contained in uImage.
|
|
ST_KERNEL_LOADADDR ?= "0xC2000040"
|
|
|
|
# Define the devicetree for Linux A7 examples
|
|
LINUX_A7_EXAMPLES_DT ?= ""
|
|
|
|
# =========================================================================
|
|
# u-boot
|
|
# =========================================================================
|
|
EXTRA_IMAGEDEPENDS += "virtual/bootloader"
|
|
|
|
# Define default U-Boot config
|
|
UBOOT_CONFIG += "${@bb.utils.contains_any('BOOTSCHEME_LABELS', 'optee trusted', 'trusted', '', d)}"
|
|
# The 'basic' config is only available for stm32mp1 machines
|
|
UBOOT_CONFIG_append_stm32mp1common = " basic "
|
|
|
|
# Select u-boot binary that needs specific devicetree suffix (from UBOOT_DEVICETREE)
|
|
# For legacy mode keep the 'u-boot.stm32' but for FIP feature we need both
|
|
# 'u-boot-nodtb.bin' and 'u-boot.dtb' : prefer 'u-boot.dtb' binary as 'u-boot-nodtb.bin'
|
|
# doesn't need any devicetree suffix (specific case for 'u-boot-nodtb' binary
|
|
# implemented on u-boot-stm32mp recipe)
|
|
BINARY_NAME = "${@bb.utils.contains('MACHINE_FEATURES', 'fip', 'u-boot.dtb', 'u-boot.stm32', d)}"
|
|
# Define u-boot defconfig and binary to use for each UBOOT_CONFIG
|
|
UBOOT_CONFIG[basic] = "stm32mp15_basic_defconfig,,u-boot.img"
|
|
UBOOT_CONFIG[trusted] = "stm32mp15_trusted_defconfig,,${BINARY_NAME}"
|
|
|
|
# List of U-Boot device tree to use
|
|
UBOOT_DEVICETREE = "${STM32MP_DEVICETREE}"
|
|
|
|
# Define U-boot splashscreen file naming
|
|
UBOOT_SPLASH_IMAGE = "splash"
|
|
|
|
# Enable MTDPART check for UBOOT_CONFIG
|
|
UBOOT_MTDPART_CHECK_ENABLE ?= "${@bb.utils.contains_any('BOOTSCHEME_LABELS', 'optee trusted', d.getVarFlag('UBOOT_CONFIG', 'trusted').split(',')[0], '', d)}"
|
|
# Set U-Boot MTD partition configurations
|
|
UBOOT_MTDPART_NAND_BOOT ?= "${@','.join(['%sk(%s)' % (align_size(d, 'NAND', l.split(',')[2], l.split(',')[4]), l.split(',')[1]) for l in d.getVarFlag('PARTITIONS_BOOTLOADER_CONFIG', 'nand-4-256').split()])}"
|
|
UBOOT_MTDPART_NAND_TEE ?= "${@','.join(['%sk(%s)' % (align_size(d, 'NAND', l.split(',')[2], l.split(',')[4]), l.split(',')[1]) for l in d.getVarFlag('PARTITIONS_OPTEE_CONFIG', 'nand-4-256').split()])}"
|
|
UBOOT_MTDPART_NOR_BOOT ?= "${@','.join(['%sk(%s)' % (align_size(d, 'NOR', l.split(',')[2], l.split(',')[4]), l.split(',')[1]) for l in d.getVarFlag('PARTITIONS_BOOTLOADER_CONFIG', 'nor-sdcard').split()])}"
|
|
UBOOT_MTDPART_NOR_TEE ?= "${@','.join(['%sk(%s)' % (align_size(d, 'NOR', l.split(',')[2], l.split(',')[4]), l.split(',')[1]) for l in d.getVarFlag('PARTITIONS_OPTEE_CONFIG', 'nor-sdcard').split()])}"
|
|
UBOOT_MTDPART_SPINAND_BOOT ?= "${@','.join(['%sk(%s)' % (align_size(d, 'SPINAND', l.split(',')[2], l.split(',')[4]), l.split(',')[1]) for l in d.getVarFlag('PARTITIONS_BOOTLOADER_CONFIG', 'spinand-2-128').split()])}"
|
|
UBOOT_MTDPART_SPINAND_TEE ?= "${@','.join(['%sk(%s)' % (align_size(d, 'SPINAND', l.split(',')[2], l.split(',')[4]), l.split(',')[1]) for l in d.getVarFlag('PARTITIONS_OPTEE_CONFIG', 'spinand-2-128').split()])}"
|
|
|
|
UBOOT_MTDPART_4LEGACY += "${@'CONFIG_MTDPARTS_NAND0_TEE=${UBOOT_MTDPART_NAND_TEE}' if bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', True, False, d) and bb.utils.contains('BOOTSCHEME_LABELS', 'optee', True, False, d) else ''}"
|
|
UBOOT_MTDPART_4LEGACY += "${@'CONFIG_MTDPARTS_NOR0_TEE=${UBOOT_MTDPART_NOR_TEE}' if bb.utils.contains('BOOTDEVICE_LABELS', 'nor-sdcard', True, False, d) and bb.utils.contains('BOOTSCHEME_LABELS', 'optee', True, False, d) else ''}"
|
|
UBOOT_MTDPART_4LEGACY += "${@'CONFIG_MTDPARTS_SPINAND0_TEE=${UBOOT_MTDPART_SPINAND_TEE}' if bb.utils.contains('BOOTDEVICE_LABELS', 'spinand-2-128', True, False, d) and bb.utils.contains('BOOTSCHEME_LABELS', 'optee', True, False, d) else ''}"
|
|
|
|
UBOOT_MTDPART_CHECK ?= "\
|
|
${@bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', 'CONFIG_MTDPARTS_NAND0_BOOT=${UBOOT_MTDPART_NAND_BOOT}', '', d)} \
|
|
${@bb.utils.contains('BOOTDEVICE_LABELS', 'nor-sdcard', 'CONFIG_MTDPARTS_NOR0_BOOT=${UBOOT_MTDPART_NOR_BOOT}', '', d)} \
|
|
${@bb.utils.contains('BOOTDEVICE_LABELS', 'spinand-2-128', 'CONFIG_MTDPARTS_SPINAND0_BOOT=${UBOOT_MTDPART_SPINAND_BOOT}', '', d)} \
|
|
${@bb.utils.contains('MACHINE_FEATURES', 'fip', '', '${UBOOT_MTDPART_4LEGACY}', d)} \
|
|
"
|
|
|
|
PREFERRED_PROVIDER_u-boot-fw-utils_stm32mp1common = "libubootenv"
|
|
|
|
MACHINE_EXTRA_RRECOMMENDS_append_stm32mp1common = " \
|
|
u-boot-fw-config-stm32mp \
|
|
"
|
|
|
|
# =========================================================================
|
|
# trusted-firmware-a
|
|
# =========================================================================
|
|
# Add optionnaly trusted-firmware-a
|
|
EXTRA_IMAGEDEPENDS += "${@bb.utils.contains_any('BOOTSCHEME_LABELS', 'optee trusted', 'virtual/trusted-firmware-a', '', d)}"
|
|
|
|
# Configure trusted-firmware-a build
|
|
TF_A_CONFIG += "${@bb.utils.contains('BOOTSCHEME_LABELS', 'optee', 'optee', '', d)}"
|
|
TF_A_CONFIG += "${@bb.utils.contains('BOOTSCHEME_LABELS', 'trusted', 'trusted', '', d)}"
|
|
# Manage specific config settings
|
|
TF_A_CONFIG_4LEGACY += "serialboot"
|
|
TF_A_CONFIG_4FIP += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'emmc', 'emmc', '', d)}"
|
|
TF_A_CONFIG_4FIP += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nand-4-256', 'nand', '', d)}"
|
|
TF_A_CONFIG_4FIP += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'nor-sdcard', 'nor', '', d)}"
|
|
TF_A_CONFIG_4FIP += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'sdcard', 'sdcard', '', d)}"
|
|
TF_A_CONFIG_4FIP += "${@bb.utils.contains('BOOTDEVICE_LABELS', 'spinand-2-128', 'spinand', '', d)}"
|
|
TF_A_CONFIG_4FIP += "uart"
|
|
TF_A_CONFIG_4FIP += "usb"
|
|
TF_A_CONFIG += "${@bb.utils.contains('MACHINE_FEATURES', 'fip', '${TF_A_CONFIG_4FIP}', '${TF_A_CONFIG_4LEGACY}', d)}"
|
|
|
|
# Append SSP config to TF_A_CONFIG
|
|
TF_A_SSP_ENABLE ?= "0"
|
|
TF_A_CONFIG += "${@bb.utils.contains('TF_A_SSP_ENABLE', '1', 'uart-ssp usb-ssp', '', d)}"
|
|
|
|
# Default configuration for signing trusted-firmware-a binary
|
|
TF_A_SIGN_ENABLE ?= "0"
|
|
|
|
# Configure the default MTD_START_OFFSET
|
|
TF_A_MTD_START_OFFSET_NAND ?= "0x00200000"
|
|
TF_A_MTD_START_OFFSET_NOR ?= "0x00080000"
|
|
TF_A_MTD_START_OFFSET_SPINAND ?= "0x00200000"
|
|
|
|
# =========================================================================
|
|
# optee
|
|
# =========================================================================
|
|
# Map OPTEE configuration to device tree list
|
|
OPTEE_CONF = "${STM32MP_DEVICETREE}"
|
|
|
|
# =========================================================================
|
|
# fip
|
|
# =========================================================================
|
|
# Configure fip build
|
|
FIP_CONFIG += "${@bb.utils.contains('BOOTSCHEME_LABELS', 'optee', 'optee', '', d)}"
|
|
FIP_CONFIG += "${@bb.utils.contains('BOOTSCHEME_LABELS', 'trusted', 'trusted', '', d)}"
|
|
|
|
# Define config for each FIP_CONFIG
|
|
FIP_CONFIG[optee] ?= "optee"
|
|
FIP_CONFIG[trusted] ?= "tfa"
|
|
|
|
# List of device tree to use for fip binary creation
|
|
FIP_DEVICETREE ?= "${STM32MP_DEVICETREE}"
|
|
|
|
# Define fiptool wrapper name
|
|
FIPTOOL_WRAPPER ?= "fiptool-stm32mp"
|
|
|
|
# Manage specific config to sign FIP
|
|
FIP_SIGN_ENABLE ?= "${@bb.utils.contains('TF_A_SIGN_ENABLE', '1', '1', '', d)}"
|
|
FIP_SIGN_SUFFIX ?= "${@bb.utils.contains('FIP_SIGN_ENABLE', '1', '_Signed', '', d)}"
|
|
|
|
# =========================================================================
|
|
# Xserver
|
|
# =========================================================================
|
|
XSERVER ?= " \
|
|
xserver-xorg \
|
|
xserver-xorg-module-libint10 \
|
|
xf86-input-evdev \
|
|
xf86-video-modesetting \
|
|
"
|
|
|
|
# =========================================================================
|
|
# Enable deploy of bootloader elf files
|
|
# =========================================================================
|
|
ELF_DEBUG_ENABLE = "1"
|
|
|
|
# =========================================================================
|
|
# sysdig
|
|
# =========================================================================
|
|
PREFERRED_PROVIDER_sysdig = "sysdig-stm32mp"
|
|
|
|
# =========================================================================
|
|
# M4 copro
|
|
# =========================================================================
|
|
# Define the devicetree for M4 examples
|
|
CUBE_M4_EXAMPLES_DT ?= ""
|
|
|
|
# Define the name of default copro firmware executed @boot time
|
|
# This name is cherry picked from list defined in m4projects-stm32mp1.bb
|
|
DEFAULT_COPRO_FIRMWARE = "OpenAMP_TTY_echo"
|
|
|
|
# Define M4 example installation dir
|
|
M4_INSTALLDIR = "${STM32MP_USERFS_MOUNTPOINT}"
|
|
M4_PACKAGE_4USERFS = "${@bb.utils.contains('ST_USERFS','1','1','0',d)}"
|
|
|
|
# =========================================================================
|
|
# GCNANO userland configuration
|
|
# =========================================================================
|
|
# Variable for using vendor directory instead of usr
|
|
GCNANO_USERLAND_USE_VENDOR_DIR = "${@bb.utils.contains('ST_VENDORFS','1','1','0',d)}"
|
|
GCNANO_USERLAND_VENDOR_DIR = "${STM32MP_VENDORFS_MOUNTPOINT}"
|