diff mbox series

[4/4] fit: Use DM hash driver if supported

Message ID 20210730010805.17845-5-chiawei_wang@aspeedtech.com
State Accepted
Commit ca47955a66161adf5d6e8f8e1de852ccda6626c0
Delegated to: Tom Rini
Headers show
Series crypto: Add new UCLASS_HASH | expand

Commit Message

ChiaWei Wang July 30, 2021, 1:08 a.m. UTC
Calculate hash using DM driver if supported.
For backward compatibility, the call to legacy
hash functions is reserved.

Signed-off-by: Chia-Wei Wang <chiawei_wang@aspeedtech.com>
---
 common/image-fit.c | 30 ++++++++++++++++++++++++++++++
 1 file changed, 30 insertions(+)

Comments

Tom Rini Sept. 2, 2021, 1:28 p.m. UTC | #1
On Fri, Jul 30, 2021 at 09:08:05AM +0800, Chia-Wei Wang wrote:

> Calculate hash using DM driver if supported.
> For backward compatibility, the call to legacy
> hash functions is reserved.
> 
> Signed-off-by: Chia-Wei Wang <chiawei_wang@aspeedtech.com>

Applied to u-boot/next, thanks!
Alex G. Sept. 16, 2021, 3:59 p.m. UTC | #2
On 7/29/21 8:08 PM, Chia-Wei Wang wrote:
> Calculate hash using DM driver if supported.
> For backward compatibility, the call to legacy
> hash functions is reserved.
> 
> Signed-off-by: Chia-Wei Wang <chiawei_wang@aspeedtech.com>
> ---
>   common/image-fit.c | 30 ++++++++++++++++++++++++++++++
>   1 file changed, 30 insertions(+)
> 
> diff --git a/common/image-fit.c b/common/image-fit.c
> index d6b2c3c7ec..ec2e526356 100644
> --- a/common/image-fit.c
> +++ b/common/image-fit.c
> @@ -25,6 +25,10 @@
>   #include <asm/io.h>
>   #include <malloc.h>
>   #include <asm/global_data.h>
> +#ifdef CONFIG_DM_HASH
> +#include <dm.h>
> +#include <u-boot/hash.h>
> +#endif
>   DECLARE_GLOBAL_DATA_PTR;
>   #endif /* !USE_HOSTCC*/
>   
> @@ -1214,6 +1218,31 @@ int fit_set_timestamp(void *fit, int noffset, time_t timestamp)
>   int calculate_hash(const void *data, int data_len, const char *algo,
>   			uint8_t *value, int *value_len)
>   {
> +#if !defined(USE_HOSTCC) && defined(CONFIG_DM_HASH)

This file is shared in its entirety with host tools. There isn't a huge 
opportunity for using a DM-type approach here without #ifndef USE_HOSTCC.

Alex



> +	int rc;
> +	enum HASH_ALGO hash_algo;
> +	struct udevice *dev;
> +
> +	rc = uclass_get_device(UCLASS_HASH, 0, &dev);
> +	if (rc) {
> +		debug("failed to get hash device, rc=%d\n", rc);
> +		return -1;
> +	}
> +
> +	hash_algo = hash_algo_lookup_by_name(algo);
> +	if (hash_algo == HASH_ALGO_INVALID) {
> +		debug("Unsupported hash algorithm\n");
> +		return -1;
> +	};
> +
> +	rc = hash_digest_wd(dev, hash_algo, data, data_len, value, CHUNKSZ);
> +	if (rc) {
> +		debug("failed to get hash value, rc=%d\n", rc);
> +		return -1;
> +	}
> +
> +	*value_len = hash_algo_digest_size(hash_algo);
> +#else
>   	if (IMAGE_ENABLE_CRC32 && strcmp(algo, "crc32") == 0) {
>   		*((uint32_t *)value) = crc32_wd(0, data, data_len,
>   							CHUNKSZ_CRC32);
> @@ -1242,6 +1271,7 @@ int calculate_hash(const void *data, int data_len, const char *algo,
>   		debug("Unsupported hash alogrithm\n");
>   		return -1;
>   	}
> +#endif
>   	return 0;
>   }
>   
>
ChiaWei Wang Sept. 22, 2021, 3:18 a.m. UTC | #3
Hi Alex,

> From: Alex G. <mr.nuke.me@gmail.com>
> Sent: Friday, September 17, 2021 12:00 AM
> 
> On 7/29/21 8:08 PM, Chia-Wei Wang wrote:
> > Calculate hash using DM driver if supported.
> > For backward compatibility, the call to legacy hash functions is
> > reserved.
> >
> > Signed-off-by: Chia-Wei Wang <chiawei_wang@aspeedtech.com>
> > ---
> >   common/image-fit.c | 30 ++++++++++++++++++++++++++++++
> >   1 file changed, 30 insertions(+)
> >
> > diff --git a/common/image-fit.c b/common/image-fit.c index
> > d6b2c3c7ec..ec2e526356 100644
> > --- a/common/image-fit.c
> > +++ b/common/image-fit.c
> > @@ -25,6 +25,10 @@
> >   #include <asm/io.h>
> >   #include <malloc.h>
> >   #include <asm/global_data.h>
> > +#ifdef CONFIG_DM_HASH
> > +#include <dm.h>
> > +#include <u-boot/hash.h>
> > +#endif
> >   DECLARE_GLOBAL_DATA_PTR;
> >   #endif /* !USE_HOSTCC*/
> >
> > @@ -1214,6 +1218,31 @@ int fit_set_timestamp(void *fit, int noffset,
> time_t timestamp)
> >   int calculate_hash(const void *data, int data_len, const char *algo,
> >   			uint8_t *value, int *value_len)
> >   {
> > +#if !defined(USE_HOSTCC) && defined(CONFIG_DM_HASH)
> 
> This file is shared in its entirety with host tools. There isn't a huge opportunity
> for using a DM-type approach here without #ifndef USE_HOSTCC.
> 

There are still clean up missions to make U-boot bootloader to move on to the DM-based approach.

For instance, when a FIT image is verified by a hash digest, the hash is calculated by calculate_hash() in image-fit.c.
However, when a FIT image is verified by a signature, the hash comes from hash_calculate() in hash-checksum.c.
In my personal opinion, a consistent way to calculate hash for U-Boot bootloader would be better for maintenance.

To make this transition more smoothly, currently the USE_HOSTCC and CONFIG_DM_HASH are added in an ad-hoc way.

Chiawei

> > +	int rc;
> > +	enum HASH_ALGO hash_algo;
> > +	struct udevice *dev;
> > +
> > +	rc = uclass_get_device(UCLASS_HASH, 0, &dev);
> > +	if (rc) {
> > +		debug("failed to get hash device, rc=%d\n", rc);
> > +		return -1;
> > +	}
> > +
> > +	hash_algo = hash_algo_lookup_by_name(algo);
> > +	if (hash_algo == HASH_ALGO_INVALID) {
> > +		debug("Unsupported hash algorithm\n");
> > +		return -1;
> > +	};
> > +
> > +	rc = hash_digest_wd(dev, hash_algo, data, data_len, value, CHUNKSZ);
> > +	if (rc) {
> > +		debug("failed to get hash value, rc=%d\n", rc);
> > +		return -1;
> > +	}
> > +
> > +	*value_len = hash_algo_digest_size(hash_algo); #else
> >   	if (IMAGE_ENABLE_CRC32 && strcmp(algo, "crc32") == 0) {
> >   		*((uint32_t *)value) = crc32_wd(0, data, data_len,
> >   							CHUNKSZ_CRC32);
> > @@ -1242,6 +1271,7 @@ int calculate_hash(const void *data, int data_len,
> const char *algo,
> >   		debug("Unsupported hash alogrithm\n");
> >   		return -1;
> >   	}
> > +#endif
> >   	return 0;
> >   }
> >
> >
diff mbox series

Patch

diff --git a/common/image-fit.c b/common/image-fit.c
index d6b2c3c7ec..ec2e526356 100644
--- a/common/image-fit.c
+++ b/common/image-fit.c
@@ -25,6 +25,10 @@ 
 #include <asm/io.h>
 #include <malloc.h>
 #include <asm/global_data.h>
+#ifdef CONFIG_DM_HASH
+#include <dm.h>
+#include <u-boot/hash.h>
+#endif
 DECLARE_GLOBAL_DATA_PTR;
 #endif /* !USE_HOSTCC*/
 
@@ -1214,6 +1218,31 @@  int fit_set_timestamp(void *fit, int noffset, time_t timestamp)
 int calculate_hash(const void *data, int data_len, const char *algo,
 			uint8_t *value, int *value_len)
 {
+#if !defined(USE_HOSTCC) && defined(CONFIG_DM_HASH)
+	int rc;
+	enum HASH_ALGO hash_algo;
+	struct udevice *dev;
+
+	rc = uclass_get_device(UCLASS_HASH, 0, &dev);
+	if (rc) {
+		debug("failed to get hash device, rc=%d\n", rc);
+		return -1;
+	}
+
+	hash_algo = hash_algo_lookup_by_name(algo);
+	if (hash_algo == HASH_ALGO_INVALID) {
+		debug("Unsupported hash algorithm\n");
+		return -1;
+	};
+
+	rc = hash_digest_wd(dev, hash_algo, data, data_len, value, CHUNKSZ);
+	if (rc) {
+		debug("failed to get hash value, rc=%d\n", rc);
+		return -1;
+	}
+
+	*value_len = hash_algo_digest_size(hash_algo);
+#else
 	if (IMAGE_ENABLE_CRC32 && strcmp(algo, "crc32") == 0) {
 		*((uint32_t *)value) = crc32_wd(0, data, data_len,
 							CHUNKSZ_CRC32);
@@ -1242,6 +1271,7 @@  int calculate_hash(const void *data, int data_len, const char *algo,
 		debug("Unsupported hash alogrithm\n");
 		return -1;
 	}
+#endif
 	return 0;
 }