[PATCH v4 09/10] rockchip: binman: Support use of crc32 for SPL_FIT_SIGNATURE
Jonas Karlman
jonas at kwiboo.se
Sat Mar 29 16:06:12 CET 2025
Use of SHA256 checksum validation on ARMv7 SoCs can be very time
consuming compared to ARMv8 SoCs with Crypto Extensions.
Add support for use of the crc32 hash algo when SHA256 is not supported.
Also use a HAS_HASH to simplify the ifdefs when no known hash algo is
compiled.
Signed-off-by: Jonas Karlman <jonas at kwiboo.se>
---
Changes in v4:
- New patch
---
arch/arm/dts/rockchip-u-boot.dtsi | 30 ++++++++++++++++++++----------
1 file changed, 20 insertions(+), 10 deletions(-)
diff --git a/arch/arm/dts/rockchip-u-boot.dtsi b/arch/arm/dts/rockchip-u-boot.dtsi
index 65b81bf58626..0dfd45bb9bed 100644
--- a/arch/arm/dts/rockchip-u-boot.dtsi
+++ b/arch/arm/dts/rockchip-u-boot.dtsi
@@ -19,10 +19,20 @@
#define COMP "none"
#endif
+#if defined(CONFIG_SPL_SHA256)
+#define HASH "sha256"
+#elif defined(CONFIG_SPL_CRC32)
+#define HASH "crc32"
+#endif
+
#if defined(CONFIG_SPL_FIT) && (defined(CONFIG_ARM64) || defined(CONFIG_SPL_OPTEE_IMAGE))
#define HAS_FIT
#endif
+#if defined(CONFIG_SPL_FIT_SIGNATURE) && defined(HASH)
+#define HAS_HASH
+#endif
+
/ {
binman: binman {
multiple-images;
@@ -55,9 +65,9 @@
u-boot-nodtb {
compress = COMP;
};
-#ifdef CONFIG_SPL_FIT_SIGNATURE
+#ifdef HAS_HASH
hash {
- algo = "sha256";
+ algo = HASH;
};
#endif
};
@@ -76,9 +86,9 @@
atf-bl31 {
};
-#ifdef CONFIG_SPL_FIT_SIGNATURE
+#ifdef HAS_HASH
hash {
- algo = "sha256";
+ algo = HASH;
};
#endif
};
@@ -96,9 +106,9 @@
tee-os {
optional;
};
-#ifdef CONFIG_SPL_FIT_SIGNATURE
+#ifdef HAS_HASH
hash {
- algo = "sha256";
+ algo = HASH;
};
#endif
};
@@ -114,9 +124,9 @@
tee-os {
};
-#ifdef CONFIG_SPL_FIT_SIGNATURE
+#ifdef HAS_HASH
hash {
- algo = "sha256";
+ algo = HASH;
};
#endif
};
@@ -126,9 +136,9 @@
description = "fdt-NAME";
compression = "none";
type = "flat_dt";
-#ifdef CONFIG_SPL_FIT_SIGNATURE
+#ifdef HAS_HASH
hash {
- algo = "sha256";
+ algo = HASH;
};
#endif
};
--
2.49.0
More information about the U-Boot
mailing list