Blame view
lib/libcrc32c.c
1.98 KB
2874c5fd2
|
1 |
// SPDX-License-Identifier: GPL-2.0-or-later |
1da177e4c
|
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
/* * CRC32C *@Article{castagnoli-crc, * author = { Guy Castagnoli and Stefan Braeuer and Martin Herrman}, * title = {{Optimization of Cyclic Redundancy-Check Codes with 24 * and 32 Parity Bits}}, * journal = IEEE Transactions on Communication, * year = {1993}, * volume = {41}, * number = {6}, * pages = {}, * month = {June}, *} * Used by the iSCSI driver, possibly others, and derived from the * the iscsi-crc.c module of the linux-iscsi driver at * http://linux-iscsi.sourceforge.net. * * Following the example of lib/crc32, this function is intended to be * flexible and useful for all users. Modules that currently have their * own crc32c, but hopefully may be able to use this one are: * net/sctp (please add all your doco to here if you change to * use this one!) * <endoflist> * * Copyright (c) 2004 Cisco Systems, Inc. |
1da177e4c
|
27 |
*/ |
1da177e4c
|
28 |
|
69c35efcf
|
29 30 31 32 33 |
#include <crypto/hash.h> #include <linux/err.h> #include <linux/init.h> #include <linux/kernel.h> #include <linux/module.h> |
290e0e0f2
|
34 |
#include <linux/crc32c.h> |
1da177e4c
|
35 |
|
69c35efcf
|
36 |
static struct crypto_shash *tfm; |
1da177e4c
|
37 |
|
69c35efcf
|
38 |
u32 crc32c(u32 crc, const void *address, unsigned int length) |
1da177e4c
|
39 |
{ |
ea0e0de69
|
40 |
SHASH_DESC_ON_STACK(shash, tfm); |
d41519a69
|
41 |
u32 ret, *ctx = (u32 *)shash_desc_ctx(shash); |
69c35efcf
|
42 |
int err; |
1da177e4c
|
43 |
|
ea0e0de69
|
44 |
shash->tfm = tfm; |
ea0e0de69
|
45 |
*ctx = crc; |
1da177e4c
|
46 |
|
ea0e0de69
|
47 |
err = crypto_shash_update(shash, address, length); |
69c35efcf
|
48 |
BUG_ON(err); |
1da177e4c
|
49 |
|
d41519a69
|
50 51 52 |
ret = *ctx; barrier_data(ctx); return ret; |
69c35efcf
|
53 |
} |
1da177e4c
|
54 |
|
53b146ae5
|
55 |
EXPORT_SYMBOL(crc32c); |
69c35efcf
|
56 |
static int __init libcrc32c_mod_init(void) |
1da177e4c
|
57 |
{ |
69c35efcf
|
58 |
tfm = crypto_alloc_shash("crc32c", 0, 0); |
f8eaf298c
|
59 |
return PTR_ERR_OR_ZERO(tfm); |
1da177e4c
|
60 |
} |
69c35efcf
|
61 |
static void __exit libcrc32c_mod_fini(void) |
1da177e4c
|
62 |
{ |
69c35efcf
|
63 |
crypto_free_shash(tfm); |
1da177e4c
|
64 |
} |
1da177e4c
|
65 |
|
df91f56ad
|
66 67 68 69 70 |
const char *crc32c_impl(void) { return crypto_shash_driver_name(tfm); } EXPORT_SYMBOL(crc32c_impl); |
69c35efcf
|
71 72 73 74 75 76 |
module_init(libcrc32c_mod_init); module_exit(libcrc32c_mod_fini); MODULE_AUTHOR("Clay Haapala <chaapala@cisco.com>"); MODULE_DESCRIPTION("CRC32c (Castagnoli) calculations"); MODULE_LICENSE("GPL"); |
fd7f67271
|
77 |
MODULE_SOFTDEP("pre: crc32c"); |