blob: d732ecc38fd7561271b5d0bce2e43b58e837afc3 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Heiko Schocher646257d2014-03-03 12:19:26 +01002/*
3 * Copyright (c) 2013, Andreas Oetken.
Heiko Schocher646257d2014-03-03 12:19:26 +01004 */
5
Heiko Schocher29a23f92014-03-03 12:19:30 +01006#ifndef USE_HOSTCC
Heiko Schocher646257d2014-03-03 12:19:26 +01007#include <common.h>
8#include <fdtdec.h>
Heiko Schocher646257d2014-03-03 12:19:26 +01009#include <asm/byteorder.h>
Masahiro Yamada1221ce42016-09-21 11:28:55 +090010#include <linux/errno.h>
Heiko Schocher646257d2014-03-03 12:19:26 +010011#include <asm/unaligned.h>
Ruchika Guptab37b46f2015-01-23 16:01:59 +053012#include <hash.h>
Heiko Schocher29a23f92014-03-03 12:19:30 +010013#else
14#include "fdt_host.h"
Ruchika Guptab37b46f2015-01-23 16:01:59 +053015#endif
Alexandru Gagniuc0bcb28d2021-02-19 12:45:10 -060016#include <hash.h>
17#include <image.h>
Heiko Schocher646257d2014-03-03 12:19:26 +010018
Ruchika Guptab37b46f2015-01-23 16:01:59 +053019int hash_calculate(const char *name,
20 const struct image_region region[],
21 int region_count, uint8_t *checksum)
Heiko Schocher646257d2014-03-03 12:19:26 +010022{
Ruchika Guptab37b46f2015-01-23 16:01:59 +053023 struct hash_algo *algo;
24 int ret = 0;
25 void *ctx;
Heiko Schocher646257d2014-03-03 12:19:26 +010026 uint32_t i;
27 i = 0;
28
Ruchika Guptab37b46f2015-01-23 16:01:59 +053029 ret = hash_progressive_lookup_algo(name, &algo);
30 if (ret)
31 return ret;
Heiko Schocher646257d2014-03-03 12:19:26 +010032
Ruchika Guptab37b46f2015-01-23 16:01:59 +053033 ret = algo->hash_init(algo, &ctx);
34 if (ret)
35 return ret;
Heiko Schocher646257d2014-03-03 12:19:26 +010036
Ruchika Guptab37b46f2015-01-23 16:01:59 +053037 for (i = 0; i < region_count - 1; i++) {
38 ret = algo->hash_update(algo, ctx, region[i].data,
39 region[i].size, 0);
40 if (ret)
41 return ret;
42 }
43
44 ret = algo->hash_update(algo, ctx, region[i].data, region[i].size, 1);
45 if (ret)
46 return ret;
47 ret = algo->hash_finish(algo, ctx, checksum, algo->digest_size);
48 if (ret)
49 return ret;
50
51 return 0;
Heiko Schocher646257d2014-03-03 12:19:26 +010052}