#include <linux/unaligned.h>
#include <crypto/internal/hash.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/string.h>
#include <linux/kernel.h>
#include <linux/crc32.h>
#define CHKSUM_BLOCK_SIZE …
#define CHKSUM_DIGEST_SIZE …
struct chksum_ctx { … };
struct chksum_desc_ctx { … };
static int chksum_init(struct shash_desc *desc)
{ … }
static int chksum_setkey(struct crypto_shash *tfm, const u8 *key,
unsigned int keylen)
{ … }
static int chksum_update(struct shash_desc *desc, const u8 *data,
unsigned int length)
{ … }
static int chksum_final(struct shash_desc *desc, u8 *out)
{ … }
static int __chksum_finup(u32 *crcp, const u8 *data, unsigned int len, u8 *out)
{ … }
static int chksum_finup(struct shash_desc *desc, const u8 *data,
unsigned int len, u8 *out)
{ … }
static int chksum_digest(struct shash_desc *desc, const u8 *data,
unsigned int length, u8 *out)
{ … }
static int crc32c_cra_init(struct crypto_tfm *tfm)
{ … }
static struct shash_alg alg = …;
static int __init crc32c_mod_init(void)
{ … }
static void __exit crc32c_mod_fini(void)
{ … }
subsys_initcall(crc32c_mod_init);
module_exit(crc32c_mod_fini);
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;
MODULE_ALIAS_CRYPTO(…) …;
MODULE_ALIAS_CRYPTO(…) …;