Blame view
crypto/crc32_generic.c
3.74 KB
78c37d191 crypto: crc32 - a... |
1 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 27 28 29 30 |
/* GPL HEADER START * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 only, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License version 2 for more details (a copy is included * in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU General Public License * version 2 along with this program; If not, see http://www.gnu.org/licenses * * Please visit http://www.xyratex.com/contact if you need additional * information or have any questions. * * GPL HEADER END */ /* * Copyright 2012 Xyratex Technology Limited */ /* * This is crypto api shash wrappers to crc32_le. */ |
fffe7d927 crypto: crc32-gen... |
31 |
#include <asm/unaligned.h> |
78c37d191 crypto: crc32 - a... |
32 33 34 35 36 37 38 39 40 |
#include <linux/crc32.h> #include <crypto/internal/hash.h> #include <linux/init.h> #include <linux/module.h> #include <linux/string.h> #include <linux/kernel.h> #define CHKSUM_BLOCK_SIZE 1 #define CHKSUM_DIGEST_SIZE 4 |
78c37d191 crypto: crc32 - a... |
41 42 43 44 45 46 47 48 49 |
/** No default init with ~0 */ static int crc32_cra_init(struct crypto_tfm *tfm) { u32 *key = crypto_tfm_ctx(tfm); *key = 0; return 0; } |
78c37d191 crypto: crc32 - a... |
50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
/* * Setting the seed allows arbitrary accumulators and flexible XOR policy * If your algorithm starts with ~0, then XOR with ~0 before you set * the seed. */ static int crc32_setkey(struct crypto_shash *hash, const u8 *key, unsigned int keylen) { u32 *mctx = crypto_shash_ctx(hash); if (keylen != sizeof(u32)) { crypto_shash_set_flags(hash, CRYPTO_TFM_RES_BAD_KEY_LEN); return -EINVAL; } |
fffe7d927 crypto: crc32-gen... |
64 |
*mctx = get_unaligned_le32(key); |
78c37d191 crypto: crc32 - a... |
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
return 0; } static int crc32_init(struct shash_desc *desc) { u32 *mctx = crypto_shash_ctx(desc->tfm); u32 *crcp = shash_desc_ctx(desc); *crcp = *mctx; return 0; } static int crc32_update(struct shash_desc *desc, const u8 *data, unsigned int len) { u32 *crcp = shash_desc_ctx(desc); |
6943546c2 crypto: crc32-gen... |
82 |
*crcp = crc32_le(*crcp, data, len); |
78c37d191 crypto: crc32 - a... |
83 84 85 86 87 88 89 |
return 0; } /* No final XOR 0xFFFFFFFF, like crc32_le */ static int __crc32_finup(u32 *crcp, const u8 *data, unsigned int len, u8 *out) { |
6943546c2 crypto: crc32-gen... |
90 |
put_unaligned_le32(crc32_le(*crcp, data, len), out); |
78c37d191 crypto: crc32 - a... |
91 92 93 94 95 96 97 98 99 100 101 102 |
return 0; } static int crc32_finup(struct shash_desc *desc, const u8 *data, unsigned int len, u8 *out) { return __crc32_finup(shash_desc_ctx(desc), data, len, out); } static int crc32_final(struct shash_desc *desc, u8 *out) { u32 *crcp = shash_desc_ctx(desc); |
fffe7d927 crypto: crc32-gen... |
103 |
put_unaligned_le32(*crcp, out); |
78c37d191 crypto: crc32 - a... |
104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 |
return 0; } static int crc32_digest(struct shash_desc *desc, const u8 *data, unsigned int len, u8 *out) { return __crc32_finup(crypto_shash_ctx(desc->tfm), data, len, out); } static struct shash_alg alg = { .setkey = crc32_setkey, .init = crc32_init, .update = crc32_update, .final = crc32_final, .finup = crc32_finup, .digest = crc32_digest, .descsize = sizeof(u32), .digestsize = CHKSUM_DIGEST_SIZE, .base = { .cra_name = "crc32", |
a7c58ac06 crypto: crc32 - R... |
124 |
.cra_driver_name = "crc32-generic", |
78c37d191 crypto: crc32 - a... |
125 |
.cra_priority = 100, |
a208fa8f3 crypto: hash - an... |
126 |
.cra_flags = CRYPTO_ALG_OPTIONAL_KEY, |
78c37d191 crypto: crc32 - a... |
127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 |
.cra_blocksize = CHKSUM_BLOCK_SIZE, .cra_ctxsize = sizeof(u32), .cra_module = THIS_MODULE, .cra_init = crc32_cra_init, } }; static int __init crc32_mod_init(void) { return crypto_register_shash(&alg); } static void __exit crc32_mod_fini(void) { crypto_unregister_shash(&alg); } |
c4741b230 crypto: run initc... |
143 |
subsys_initcall(crc32_mod_init); |
78c37d191 crypto: crc32 - a... |
144 145 146 147 148 |
module_exit(crc32_mod_fini); MODULE_AUTHOR("Alexander Boyko <alexander_boyko@xyratex.com>"); MODULE_DESCRIPTION("CRC32 calculations wrapper for lib/crc32"); MODULE_LICENSE("GPL"); |
5d26a105b crypto: prefix mo... |
149 |
MODULE_ALIAS_CRYPTO("crc32"); |
a7c58ac06 crypto: crc32 - R... |
150 |
MODULE_ALIAS_CRYPTO("crc32-generic"); |