9
0
Fork 0

crypto: add CRC32 digest

CRC32 digest can be used to check CRC32 hashes in FIT images etc.

Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com>
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
This commit is contained in:
Yegor Yefremov 2016-05-25 09:51:13 +02:00 committed by Sascha Hauer
parent 57a648aabb
commit 61ddbd3520
5 changed files with 112 additions and 0 deletions

View File

@ -36,6 +36,10 @@ config SHA512
config DIGEST_HMAC
bool
config DIGEST_CRC32_GENERIC
bool "CRC32"
select CRC32
config DIGEST_MD5_GENERIC
bool "MD5"
select MD5

View File

@ -2,6 +2,7 @@ obj-$(CONFIG_CRC32) += crc32.o
obj-$(CONFIG_CRC16) += crc16.o
obj-$(CONFIG_CRC7) += crc7.o
obj-$(CONFIG_DIGEST) += digest.o
obj-$(CONFIG_DIGEST_CRC32_GENERIC) += crc32_digest.o
obj-$(CONFIG_DIGEST_HMAC_GENERIC) += hmac.o
obj-$(CONFIG_DIGEST_MD5_GENERIC) += md5.o
obj-$(CONFIG_DIGEST_SHA1_GENERIC) += sha1.o

90
crypto/crc32_digest.c Normal file
View File

@ -0,0 +1,90 @@
/*
* Cryptographic API.
*
* CRC32.
*
* Derived from cryptoapi implementation, adapted for in-place
* scatterlist interface.
*
* Copyright (c) Alan Smithee.
* Copyright (c) Andrew McDonald <andrew@mcdonald.org.uk>
* Copyright (c) Jean-Francois Dive <jef@linuxbe.org>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option)
* any later version.
*
*/
#include <common.h>
#include <digest.h>
#include <init.h>
#include <linux/string.h>
#include <crc.h>
#include <asm/unaligned.h>
#include <asm/byteorder.h>
#include <crypto/crc.h>
#include <crypto/internal.h>
static int crc32_init(struct digest *desc)
{
struct crc32_state *ctx = digest_ctx(desc);
ctx->crc = 0;
return 0;
}
static int crc32_update(struct digest *desc, const void *data,
unsigned long len)
{
struct crc32_state *ctx = digest_ctx(desc);
while (len) {
int now = min((ulong)4096, len);
ctx->crc = crc32(ctx->crc, data, now);
len -= now;
data += now;
}
return 0;
}
static int crc32_final(struct digest *desc, unsigned char *md)
{
struct crc32_state *ctx = digest_ctx(desc);
__be32 *dst = (__be32 *)md;
/* Store state in digest */
dst[0] = cpu_to_be32(ctx->crc);
/* Wipe context */
memset(ctx, 0, sizeof *ctx);
return 0;
}
static struct digest_algo m = {
.base = {
.name = "crc32",
.driver_name = "crc32-generic",
.priority = 0,
.algo = HASH_ALGO_CRC32,
},
.init = crc32_init,
.update = crc32_update,
.final = crc32_final,
.digest = digest_generic_digest,
.verify = digest_generic_verify,
.length = CRC32_DIGEST_SIZE,
.ctx_length = sizeof(struct crc32_state),
};
static int crc32_digest_register(void)
{
return digest_algo_register(&m);
}
device_initcall(crc32_digest_register);

16
include/crypto/crc.h Normal file
View File

@ -0,0 +1,16 @@
/*
* Common values for CRC algorithms
*/
#ifndef _CRYPTO_CRC_H
#define _CRYPTO_CRC_H
#include <linux/types.h>
#define CRC32_DIGEST_SIZE 4
struct crc32_state {
ulong crc;
};
#endif

View File

@ -41,6 +41,7 @@ enum hash_algo {
HASH_ALGO_TGR_128,
HASH_ALGO_TGR_160,
HASH_ALGO_TGR_192,
HASH_ALGO_CRC32,
HASH_ALGO__LAST
};