]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
rockchip: Support building the all output files in binman
authorSimon Glass <sjg@chromium.org>
Sat, 7 Jan 2023 21:07:18 +0000 (14:07 -0700)
committerSimon Glass <sjg@chromium.org>
Wed, 18 Jan 2023 21:55:39 +0000 (14:55 -0700)
Add the required binman images to replace the Makefile rules which are
currently used. This includes subsuming:

   - tpl/u-boot-tpl-rockchip.bin if TPL is enabled
   - idbloader.img if either or both of SPL and TPL are enabled
   - u-boot.itb if SPL_FIT is enabled
   - u-boot-rockchip.bin if SPL is used, either using u-boot.itb when
     SPL_FIT is enabled or u-boot.img when it isn't

Note that the intermediate files are dropped with binman, since it
producing everything in one pass. This means that
tpl/u-boot-tpl-rockchip.bin is not created, for example.

Note that for some 32-bit rk3288 boards, rockchip-optee.dtsi is included.

Signed-off-by: Simon Glass <sjg@chromium.org>
arch/arm/dts/px30-ringneck-haikou-u-boot.dtsi
arch/arm/dts/rk3399-puma-haikou-u-boot.dtsi
arch/arm/dts/rockchip-u-boot.dtsi

index e8a34c7c1eb85b1d09ffa4fcac40a259cdd1fc88..1325e0cb055046b7c40ae0b6533175a2db93a70e 100644 (file)
@@ -17,7 +17,7 @@
 
 &binman {
        simple-bin {
-               blob {
+               fit {
                        offset = <((CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR - 64) * 512)>;
                };
        };
index d2349ae90e293db93e060e3b21b781a3b19e0db4..088861dbf6d19d8c8ac1a28aca243c0fecc43b5b 100644 (file)
 
 &binman {
        simple-bin {
-               blob {
+               fit {
                        offset = <((CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR - 64) * 512)>;
                };
        };
 
 #ifdef CONFIG_ROCKCHIP_SPI_IMAGE
        simple-bin-spi {
-               blob {
+               fit {
                        /* same as u-boot,spl-payload-offset */
                        offset = <0x80000>;
                };
index fa094b00392ddab33def61d96435bbbd5a88a7ce..234fc5df433226dc5c1f979853c983745820195b 100644 (file)
                        };
                };
 
-#ifdef CONFIG_ARM64
-               blob {
+#if defined(CONFIG_SPL_FIT) && defined(CONFIG_ARM64)
+               fit: fit {
+                       description = "FIT image for U-Boot with bl31 (TF-A)";
+                       #address-cells = <1>;
+                       fit,fdt-list = "of-list";
                        filename = "u-boot.itb";
+                       fit,external-offset = <CONFIG_FIT_EXTERNAL_OFFSET>;
+                       offset = <CONFIG_SPL_PAD_TO>;
+                       images {
+                               u-boot {
+                                       description = "U-Boot (64-bit)";
+                                       type = "standalone";
+                                       os = "U-Boot";
+                                       arch = "arm64";
+                                       compression = "none";
+                                       load = <CONFIG_TEXT_BASE>;
+                                       entry = <CONFIG_TEXT_BASE>;
+                                       u-boot-nodtb {
+                                       };
+                               };
+
+                               @atf-SEQ {
+                                       fit,operation = "split-elf";
+                                       description = "ARM Trusted Firmware";
+                                       type = "firmware";
+                                       arch = "arm64";
+                                       os = "arm-trusted-firmware";
+                                       compression = "none";
+                                       fit,load;
+                                       fit,entry;
+                                       fit,data;
+
+                                       atf-bl31 {
+                                       };
+                               };
+                               @tee-SEQ {
+                                       fit,operation = "split-elf";
+                                       description = "TEE";
+                                       type = "tee";
+                                       arch = "arm64";
+                                       os = "tee";
+                                       compression = "none";
+                                       fit,load;
+                                       fit,entry;
+                                       fit,data;
+
+                                       tee-os {
+                                               optional;
+                                       };
+                               };
+
+                               @fdt-SEQ {
+                                       description = "fdt-NAME";
+                                       compression = "none";
+                                       type = "flat_dt";
+                               };
+                       };
+
+                       configurations {
+                               default = "@config-DEFAULT-SEQ";
+                               @config-SEQ {
+                                       description = "NAME.dtb";
+                                       fdt = "fdt-SEQ";
+                                       firmware = "u-boot";
+                                       fit,loadables;
+                               };
+                       };
+               };
 #else
                u-boot-img {
-#endif
                        offset = <CONFIG_SPL_PAD_TO>;
                };
+#endif
        };
 
 #ifdef CONFIG_ROCKCHIP_SPI_IMAGE
                };
 
 #ifdef CONFIG_ARM64
-               blob {
+               fit {
+                       type = "blob";
                        filename = "u-boot.itb";
 #else
                u-boot-img {
                        offset = <CONFIG_SYS_SPI_U_BOOT_OFFS>;
                };
        };
-#endif
+#endif /* CONFIG_ROCKCHIP_SPI_IMAGE */
 };
-#endif
+#endif /* CONFIG_SPL */