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

ChiaWei Wang chiawei_wang at aspeedtech.com
Wed Sep 22 05:18:20 CEST 2021


Hi Alex,

> From: Alex G. <mr.nuke.me at 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 at 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;
> >   }
> >
> >


More information about the U-Boot mailing list