]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
kbuild: Allow DTB overlays to built into .dtbo.S files
authorRasmus Villemoes <rasmus.villemoes@prevas.dk>
Wed, 10 Jul 2024 07:16:09 +0000 (09:16 +0200)
committerTom Rini <trini@konsulko.com>
Thu, 18 Jul 2024 19:51:06 +0000 (13:51 -0600)
[linux commit 941214a512d8, modified for U-Boot by removing the
include of vmlinux.lds.h and replacing STRUCT_ALIGNMENT by 16.]

DTB files can be built into the kernel by converting them to assembly
files then assembling them into object files. We extend this here
for DTB overlays with the .dtso extensions.

We change the start and end delimiting tag prefix to make it clear that
this data came from overlay files.

Signed-off-by: Rasmus Villemoes <rasmus.villemoes@prevas.dk>
scripts/Makefile.lib

index 3e68d5aa803ed9f6b6efe8aed619d2e3e60bccf8..549c3619472b86b9aeb855e2ad3f1c40b1e6c6e7 100644 (file)
@@ -305,7 +305,7 @@ endif
 DTC_FLAGS += $(DTC_FLAGS_$(basetarget))
 
 # Generate an assembly file to wrap the output of the device tree compiler
-quiet_cmd_dt_S_dtb= DTB     $@
+quiet_cmd_dt_S_dtb= DTBS    $@
 # Modified for U-Boot
 cmd_dt_S_dtb=                                          \
 (                                                      \
@@ -322,6 +322,24 @@ cmd_dt_S_dtb=                                              \
 $(obj)/%.dtb.S: $(obj)/%.dtb
        $(call cmd,dt_S_dtb)
 
+# Generate an assembly file to wrap the output of the device tree compiler
+quiet_cmd_dt_S_dtbo= DTBOS   $@
+# Modified for U-Boot
+cmd_dt_S_dtbo=                                         \
+{                                                      \
+       echo '.section .dtb.init.rodata,"a"';           \
+       echo '.balign 16';                              \
+       echo '.global __dtbo_$(subst -,_,$(*F))_begin'; \
+       echo '__dtbo_$(subst -,_,$(*F))_begin:';        \
+       echo '.incbin "$<" ';                           \
+       echo '__dtbo_$(subst -,_,$(*F))_end:';          \
+       echo '.global __dtbo_$(subst -,_,$(*F))_end';   \
+       echo '.balign 16';                              \
+} > $@
+
+$(obj)/%.dtbo.S: $(obj)/%.dtbo
+       $(call cmd,dt_S_dtbo)
+
 ifeq ($(CONFIG_OF_LIBFDT_OVERLAY),y)
 DTC_FLAGS += -@
 endif