[RFC] digest: Add enum
Jean-Christophe PLAGNIOL-VILLARD
plagnioj at jcrosoft.com
Thu Mar 12 10:50:42 PDT 2015
On 15:51 Thu 12 Mar , Jan Luebbe wrote:
> From: Sascha Hauer <s.hauer at pengutronix.de>
>
> Signed-off-by: Sascha Hauer <s.hauer at pengutronix.de>
> ---
>
> This is also needed as the first patch for the FIT support series. It seems
> I can't count to 5.
>
> common/digest.c | 12 ++++++++++++
> crypto/md5.c | 1 +
> crypto/sha1.c | 1 +
> crypto/sha2.c | 2 ++
> include/digest.h | 24 ++++++++++++++++++++++++
do as in the kernel use the string as we may want to add hw IP
Best Regadrs,
J.
> 5 files changed, 40 insertions(+)
>
> diff --git a/common/digest.c b/common/digest.c
> index ae414ba5d599..51be2ca4148b 100644
> --- a/common/digest.c
> +++ b/common/digest.c
> @@ -75,6 +75,18 @@ struct digest* digest_get_by_name(char* name)
> }
> EXPORT_SYMBOL_GPL(digest_get_by_name);
>
> +struct digest *digest_get(enum hash_algo algo)
> +{
> + struct digest* d;
> +
> + list_for_each_entry(d, &digests, list)
> + if (d->algo == algo)
> + return d;
> + return NULL;
> +
> +}
> +EXPORT_SYMBOL_GPL(digest_get);
> +
> int digest_file_window(struct digest *d, char *filename,
> unsigned char *hash,
> ulong start, ulong size)
> diff --git a/crypto/md5.c b/crypto/md5.c
> index 6c4ca1dd59b8..87728338708e 100644
> --- a/crypto/md5.c
> +++ b/crypto/md5.c
> @@ -305,6 +305,7 @@ static struct md5 m = {
> .update = digest_md5_update,
> .final = digest_md5_final,
> .length = 16,
> + .algo = HASH_ALGO_MD5,
> }
> };
>
> diff --git a/crypto/sha1.c b/crypto/sha1.c
> index 58d14a8b3f39..29fcdbae59a7 100644
> --- a/crypto/sha1.c
> +++ b/crypto/sha1.c
> @@ -326,6 +326,7 @@ static struct sha1 m = {
> .update = digest_sha1_update,
> .final = digest_sha1_final,
> .length = SHA1_SUM_LEN,
> + .algo = HASH_ALGO_SHA1,
> }
> };
>
> diff --git a/crypto/sha2.c b/crypto/sha2.c
> index 00a1af3419c6..72d43015687c 100644
> --- a/crypto/sha2.c
> +++ b/crypto/sha2.c
> @@ -316,6 +316,7 @@ static struct sha2 m224 = {
> .update = digest_sha2_update,
> .final = digest_sha2_final,
> .length = SHA224_SUM_LEN,
> + .algo = HASH_ALGO_SHA224,
> }
> };
> #endif
> @@ -337,6 +338,7 @@ static struct sha2 m256 = {
> .update = digest_sha2_update,
> .final = digest_sha2_final,
> .length = SHA256_SUM_LEN,
> + .algo = HASH_ALGO_SHA256,
> }
> };
> #endif
> diff --git a/include/digest.h b/include/digest.h
> index 8563c10128fe..62f6248d0768 100644
> --- a/include/digest.h
> +++ b/include/digest.h
> @@ -21,6 +21,27 @@
>
> #include <linux/list.h>
>
> +enum hash_algo {
> + HASH_ALGO_MD4,
> + HASH_ALGO_MD5,
> + HASH_ALGO_SHA1,
> + HASH_ALGO_RIPE_MD_160,
> + HASH_ALGO_SHA256,
> + HASH_ALGO_SHA384,
> + HASH_ALGO_SHA512,
> + HASH_ALGO_SHA224,
> + HASH_ALGO_RIPE_MD_128,
> + HASH_ALGO_RIPE_MD_256,
> + HASH_ALGO_RIPE_MD_320,
> + HASH_ALGO_WP_256,
> + HASH_ALGO_WP_384,
> + HASH_ALGO_WP_512,
> + HASH_ALGO_TGR_128,
> + HASH_ALGO_TGR_160,
> + HASH_ALGO_TGR_192,
> + HASH_ALGO__LAST
> +};
> +
> struct digest
> {
> char *name;
> @@ -31,6 +52,8 @@ struct digest
>
> unsigned int length;
>
> + enum hash_algo algo;
> +
> struct list_head list;
> };
>
> @@ -41,6 +64,7 @@ int digest_register(struct digest *d);
> void digest_unregister(struct digest *d);
>
> struct digest* digest_get_by_name(char* name);
> +struct digest *digest_get(enum hash_algo);
>
> int digest_file_window(struct digest *d, char *filename,
> unsigned char *hash,
> --
> 2.1.4
>
>
> _______________________________________________
> barebox mailing list
> barebox at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/barebox
More information about the barebox
mailing list