* [PATCH 1/3] add efi booting support for rpi-arm64-v8
@ 2025-06-04 13:28 'Felix Moessbauer' via isar-users
2025-06-04 13:28 ` [PATCH 2/3] ci: add build test for rpi-arm64-v8-efi-bookworm 'Felix Moessbauer' via isar-users
2025-06-04 13:28 ` [PATCH 3/3] rpi4-efi: add target to kas menu 'Felix Moessbauer' via isar-users
0 siblings, 2 replies; 3+ messages in thread
From: 'Felix Moessbauer' via isar-users @ 2025-06-04 13:28 UTC (permalink / raw)
To: isar-users; +Cc: cedric.hombourger, clara.kowalsky, Felix Moessbauer
Booting the RPI via EFI makes it much easier to decouple the image
contents, firmware, boot config and kernel cmdline. For that, we add a
new target rpi-arm64-v8-efi that boots the RPI using u-boot efi. We
further switch that target to debian bookworm (instead of raspios
bookworm) and by that have a baseline that is closer to upstream.
The recipes are written in a way to make it easy to customize in
downstream layers and only carry a bare minimum of configuration.
Signed-off-by: Felix Moessbauer <felix.moessbauer@siemens.com>
---
meta-isar/conf/machine/rpi-arm64-v8-efi.conf | 6 +++++
meta-isar/conf/machine/rpi-arm64-v8-efi.inc | 22 +++++++++++++++++++
meta-isar/conf/mc.conf | 1 +
.../rpi-arm64-v8-efi-bookworm.conf | 5 +++++
.../bootconfig-rpi-efi/bootconfig-rpi-efi.bb | 19 ++++++++++++++++
.../bootconfig-rpi-efi/files/config.txt | 9 ++++++++
.../firmware-rpi/files/debian/install | 5 +++++
.../firmware-rpi/files/debian/rules | 7 ++++++
.../firmware-rpi/firmware-rpi_1.20250305.bb | 22 +++++++++++++++++++
.../lib/wic/canned-wks/rpi-arm64-v8-efi.wks | 4 ++++
10 files changed, 100 insertions(+)
create mode 100644 meta-isar/conf/machine/rpi-arm64-v8-efi.conf
create mode 100644 meta-isar/conf/machine/rpi-arm64-v8-efi.inc
create mode 100644 meta-isar/conf/multiconfig/rpi-arm64-v8-efi-bookworm.conf
create mode 100644 meta-isar/recipes-bsp/bootconfig-rpi-efi/bootconfig-rpi-efi.bb
create mode 100644 meta-isar/recipes-bsp/bootconfig-rpi-efi/files/config.txt
create mode 100644 meta-isar/recipes-bsp/firmware-rpi/files/debian/install
create mode 100644 meta-isar/recipes-bsp/firmware-rpi/files/debian/rules
create mode 100644 meta-isar/recipes-bsp/firmware-rpi/firmware-rpi_1.20250305.bb
create mode 100644 meta-isar/scripts/lib/wic/canned-wks/rpi-arm64-v8-efi.wks
diff --git a/meta-isar/conf/machine/rpi-arm64-v8-efi.conf b/meta-isar/conf/machine/rpi-arm64-v8-efi.conf
new file mode 100644
index 00000000..dfa93e67
--- /dev/null
+++ b/meta-isar/conf/machine/rpi-arm64-v8-efi.conf
@@ -0,0 +1,6 @@
+# This software is a part of ISAR.
+# Copyright (C) 2025 Siemens
+
+require conf/machine/rpi-arm64-v8-efi.inc
+
+IMAGER_INSTALL:wic += "${SYSTEMD_BOOTLOADER_INSTALL}"
diff --git a/meta-isar/conf/machine/rpi-arm64-v8-efi.inc b/meta-isar/conf/machine/rpi-arm64-v8-efi.inc
new file mode 100644
index 00000000..cca577ea
--- /dev/null
+++ b/meta-isar/conf/machine/rpi-arm64-v8-efi.inc
@@ -0,0 +1,22 @@
+# This software is a part of ISAR.
+# Copyright (C) 2025 Siemens
+
+DISTRO_ARCH ?= "arm64"
+KERNEL_NAME ?= "arm64"
+
+IMAGE_FSTYPES ?= "wic"
+WKS_FILE ?= "rpi-arm64-v8-efi.wks"
+
+IMAGER_BUILD_DEPS = "bootconfig-rpi-efi"
+IMAGER_INSTALL:wic += "${IMAGER_BUILD_DEPS}"
+
+IMAGE_EFI_BOOT_FILES = " \
+ /usr/lib/bootconfig-rpi-efi/config.txt;config.txt \
+ /usr/lib/u-boot/rpi_arm64/u-boot.bin;u-boot.bin \
+ /usr/lib/rpi-firmware/fixup4.dat;fixup4.dat \
+ /usr/lib/rpi-firmware/start4.elf;start4.elf \
+ /usr/lib/rpi-firmware/overlays/*;overlays/ \
+ ${IMAGE_ROOTFS}/usr/lib/linux-image-*/broadcom/bcm2711-rpi-4*.dtb \
+"
+
+IMAGE_PREINSTALL:append = " firmware-brcm80211"
diff --git a/meta-isar/conf/mc.conf b/meta-isar/conf/mc.conf
index 55969c7b..493d5ae2 100644
--- a/meta-isar/conf/mc.conf
+++ b/meta-isar/conf/mc.conf
@@ -61,6 +61,7 @@ BBMULTICONFIG = " \
rpi-arm-v7l-bookworm \
rpi-arm64-v8-bullseye \
rpi-arm64-v8-bookworm \
+ rpi-arm64-v8-efi-bookworm \
sifive-fu540-trixie \
starfive-visionfive2-trixie \
qemuarm64-focal \
diff --git a/meta-isar/conf/multiconfig/rpi-arm64-v8-efi-bookworm.conf b/meta-isar/conf/multiconfig/rpi-arm64-v8-efi-bookworm.conf
new file mode 100644
index 00000000..2fdde790
--- /dev/null
+++ b/meta-isar/conf/multiconfig/rpi-arm64-v8-efi-bookworm.conf
@@ -0,0 +1,5 @@
+# This software is a part of Isar.
+# Copyright (C) 2025 Siemens
+
+MACHINE ?= "rpi-arm64-v8-efi"
+DISTRO ?= "debian-bookworm"
diff --git a/meta-isar/recipes-bsp/bootconfig-rpi-efi/bootconfig-rpi-efi.bb b/meta-isar/recipes-bsp/bootconfig-rpi-efi/bootconfig-rpi-efi.bb
new file mode 100644
index 00000000..5c80721f
--- /dev/null
+++ b/meta-isar/recipes-bsp/bootconfig-rpi-efi/bootconfig-rpi-efi.bb
@@ -0,0 +1,19 @@
+# This software is a part of ISAR.
+# Copyright (C) 2025 Siemens
+
+inherit dpkg-raw
+
+SRC_URI = "file://config.txt"
+
+DESCRIPTION = "Raspberry Pi config to boot using U-Boot EFI"
+MAINTAINER = "isar-users <isar-users@googlegroups.com>"
+
+DPKG_ARCH = "arm64"
+DEBIAN_DEPENDS = "firmware-rpi, u-boot-rpi"
+RDEPENDS:${PN} += "firmware-rpi"
+
+do_install[cleandirs] += "${D}/usr/lib/${BPN}"
+do_install() {
+ DST=${D}/usr/lib/${BPN}
+ install -m 0644 ${WORKDIR}/config.txt $DST
+}
diff --git a/meta-isar/recipes-bsp/bootconfig-rpi-efi/files/config.txt b/meta-isar/recipes-bsp/bootconfig-rpi-efi/files/config.txt
new file mode 100644
index 00000000..1748bfcf
--- /dev/null
+++ b/meta-isar/recipes-bsp/bootconfig-rpi-efi/files/config.txt
@@ -0,0 +1,9 @@
+arm_64bit=1
+arm_boost=1
+enable_uart=1
+uart_2ndstage=1
+disable_commandline_tags=1
+kernel=u-boot.bin
+
+[pi4]
+max_framebuffers=2
diff --git a/meta-isar/recipes-bsp/firmware-rpi/files/debian/install b/meta-isar/recipes-bsp/firmware-rpi/files/debian/install
new file mode 100644
index 00000000..96265f9f
--- /dev/null
+++ b/meta-isar/recipes-bsp/firmware-rpi/files/debian/install
@@ -0,0 +1,5 @@
+boot/bootcode.bin usr/lib/rpi-firmware
+boot/LICENCE.broadcom usr/lib/rpi-firmware
+boot/*.dat usr/lib/rpi-firmware
+boot/*.dtb usr/lib/rpi-firmware
+boot/*.elf usr/lib/rpi-firmware
diff --git a/meta-isar/recipes-bsp/firmware-rpi/files/debian/rules b/meta-isar/recipes-bsp/firmware-rpi/files/debian/rules
new file mode 100644
index 00000000..5ed0ca99
--- /dev/null
+++ b/meta-isar/recipes-bsp/firmware-rpi/files/debian/rules
@@ -0,0 +1,7 @@
+#!/usr/bin/make -f
+
+%:
+ dh $@
+
+override_dh_strip:
+override_dh_dwz:
diff --git a/meta-isar/recipes-bsp/firmware-rpi/firmware-rpi_1.20250305.bb b/meta-isar/recipes-bsp/firmware-rpi/firmware-rpi_1.20250305.bb
new file mode 100644
index 00000000..e88b08e7
--- /dev/null
+++ b/meta-isar/recipes-bsp/firmware-rpi/firmware-rpi_1.20250305.bb
@@ -0,0 +1,22 @@
+# This software is a part of ISAR.
+# Copyright (C) 2025 Siemens
+
+inherit dpkg
+
+DESCRIPTION = "Raspberry Pi firmware blobs"
+MAINTAINER = "isar-users <isar-users@googlegroups.com>"
+
+SRC_URI = " \
+ https://github.com/raspberrypi/firmware/archive/${PV}.tar.gz;downloadfilename=${PN}-${PV}.tar.gz \
+ file://debian/install \
+ file://debian/rules \
+"
+SRC_URI[sha256sum] = "4981021b82f600f450d64d9b82034dc603bf5429889a3947b2863e01992a343c"
+
+S = "${WORKDIR}/firmware-${PV}"
+
+do_prepare_build[cleandirs] += "${S}/debian"
+do_prepare_build() {
+ deb_debianize
+ cp -r ${WORKDIR}/debian ${S}
+}
diff --git a/meta-isar/scripts/lib/wic/canned-wks/rpi-arm64-v8-efi.wks b/meta-isar/scripts/lib/wic/canned-wks/rpi-arm64-v8-efi.wks
new file mode 100644
index 00000000..560e38b0
--- /dev/null
+++ b/meta-isar/scripts/lib/wic/canned-wks/rpi-arm64-v8-efi.wks
@@ -0,0 +1,4 @@
+part /boot --source bootimg-efi-isar --use-uuid --sourceparams "loader=systemd-boot" --label efi --part-type EF00 --align 8192 --size 256M
+part / --source rootfs --use-uuid --fstype ext4 --mkfs-extraopts "-T default" --label platform --align 8192 --exclude-path boot/ --extra-space 1G
+
+bootloader --ptable gpt --timeout 3 --append "rootwait console=ttyS1,115200 module_blacklist=vc4"
--
2.49.0
--
You received this message because you are subscribed to the Google Groups "isar-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to isar-users+unsubscribe@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/isar-users/20250604132849.411641-1-felix.moessbauer%40siemens.com.
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH 2/3] ci: add build test for rpi-arm64-v8-efi-bookworm
2025-06-04 13:28 [PATCH 1/3] add efi booting support for rpi-arm64-v8 'Felix Moessbauer' via isar-users
@ 2025-06-04 13:28 ` 'Felix Moessbauer' via isar-users
2025-06-04 13:28 ` [PATCH 3/3] rpi4-efi: add target to kas menu 'Felix Moessbauer' via isar-users
1 sibling, 0 replies; 3+ messages in thread
From: 'Felix Moessbauer' via isar-users @ 2025-06-04 13:28 UTC (permalink / raw)
To: isar-users; +Cc: cedric.hombourger, clara.kowalsky, Felix Moessbauer
Signed-off-by: Felix Moessbauer <felix.moessbauer@siemens.com>
---
testsuite/citest.py | 1 +
1 file changed, 1 insertion(+)
diff --git a/testsuite/citest.py b/testsuite/citest.py
index 9f18a51f..36849632 100755
--- a/testsuite/citest.py
+++ b/testsuite/citest.py
@@ -199,6 +199,7 @@ class CrossTest(CIBaseTest):
def test_cross_rpi(self):
targets = [
'mc:rpi-arm-v7-bullseye:isar-image-base',
+ 'mc:rpi-arm64-v8-efi-bookworm:isar-image-base',
]
self.init()
--
2.49.0
--
You received this message because you are subscribed to the Google Groups "isar-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to isar-users+unsubscribe@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/isar-users/20250604132849.411641-2-felix.moessbauer%40siemens.com.
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH 3/3] rpi4-efi: add target to kas menu
2025-06-04 13:28 [PATCH 1/3] add efi booting support for rpi-arm64-v8 'Felix Moessbauer' via isar-users
2025-06-04 13:28 ` [PATCH 2/3] ci: add build test for rpi-arm64-v8-efi-bookworm 'Felix Moessbauer' via isar-users
@ 2025-06-04 13:28 ` 'Felix Moessbauer' via isar-users
1 sibling, 0 replies; 3+ messages in thread
From: 'Felix Moessbauer' via isar-users @ 2025-06-04 13:28 UTC (permalink / raw)
To: isar-users; +Cc: cedric.hombourger, clara.kowalsky, Felix Moessbauer
This target works from debian bookworm on (not raspbios). We add the
corresponding kas menu entries to also select it from the menu.
Signed-off-by: Felix Moessbauer <felix.moessbauer@siemens.com>
---
kas/machine/Kconfig | 7 +++++++
kas/machine/rpi-arm64-v8-efi.yaml | 7 +++++++
2 files changed, 14 insertions(+)
create mode 100644 kas/machine/rpi-arm64-v8-efi.yaml
diff --git a/kas/machine/Kconfig b/kas/machine/Kconfig
index 8c334a8f..e09304c0 100644
--- a/kas/machine/Kconfig
+++ b/kas/machine/Kconfig
@@ -198,6 +198,12 @@ config MACHINE_RPI_ARM64_V8
select CODENAME_BOOKWORM
select ARCH_ARM64
+config MACHINE_RPI_ARM64_V8_EFI
+ bool "rpi-arm64-v8-efi"
+ select DISTRO_DEBIAN
+ select CODENAME_BOOKWORM
+ select ARCH_ARM64
+
config MACHINE_SIFIVE_FU540
bool "sifive-fu540"
select DISTRO_DEBIAN
@@ -269,6 +275,7 @@ config KAS_INCLUDE_MACHINE
default "kas/machine/rpi-arm-v7l.yaml" if MACHINE_RPI_ARM_V7L
default "kas/machine/rpi-arm.yaml" if MACHINE_RPI_ARM
default "kas/machine/rpi-arm64-v8.yaml" if MACHINE_RPI_ARM64_V8
+ default "kas/machine/rpi-arm64-v8-efi.yaml" if MACHINE_RPI_ARM64_V8_EFI
default "kas/machine/sifive-fu540.yaml" if MACHINE_SIFIVE_FU540
default "kas/machine/starfive-visionfive2.yaml" if MACHINE_STARFIVE_VISIONFIVE2
default "kas/machine/stm32mp15x.yaml" if MACHINE_STM32MP15X
diff --git a/kas/machine/rpi-arm64-v8-efi.yaml b/kas/machine/rpi-arm64-v8-efi.yaml
new file mode 100644
index 00000000..e77891a9
--- /dev/null
+++ b/kas/machine/rpi-arm64-v8-efi.yaml
@@ -0,0 +1,7 @@
+# This software is a part of ISAR.
+# Copyright (C) 2025 Siemens
+
+header:
+ version: 14
+
+machine: rpi-arm64-v8-efi
--
2.49.0
--
You received this message because you are subscribed to the Google Groups "isar-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to isar-users+unsubscribe@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/isar-users/20250604132849.411641-3-felix.moessbauer%40siemens.com.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2025-06-04 13:29 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-06-04 13:28 [PATCH 1/3] add efi booting support for rpi-arm64-v8 'Felix Moessbauer' via isar-users
2025-06-04 13:28 ` [PATCH 2/3] ci: add build test for rpi-arm64-v8-efi-bookworm 'Felix Moessbauer' via isar-users
2025-06-04 13:28 ` [PATCH 3/3] rpi4-efi: add target to kas menu 'Felix Moessbauer' via isar-users
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox