blob: 45c2bddfdf326d85b6ddf707e852074e6011c966 [file] [log] [blame]
Herbert Xu18e33e62008-07-10 16:01:22 +08001/*
2 * Hash: Hash algorithms under the crypto API
3 *
4 * Copyright (c) 2008 Herbert Xu <herbert@gondor.apana.org.au>
5 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the Free
8 * Software Foundation; either version 2 of the License, or (at your option)
9 * any later version.
10 *
11 */
12
13#ifndef _CRYPTO_HASH_H
14#define _CRYPTO_HASH_H
15
16#include <linux/crypto.h>
17
Herbert Xu88056ec2009-07-14 12:28:26 +080018struct crypto_ahash;
19
20struct hash_alg_common {
21 unsigned int digestsize;
22 unsigned int statesize;
23
24 struct crypto_alg base;
25};
26
27struct ahash_request {
28 struct crypto_async_request base;
29
30 unsigned int nbytes;
31 struct scatterlist *src;
32 u8 *result;
33
34 void *__ctx[] CRYPTO_MINALIGN_ATTR;
35};
36
37struct ahash_alg {
38 int (*init)(struct ahash_request *req);
39 int (*update)(struct ahash_request *req);
40 int (*final)(struct ahash_request *req);
41 int (*finup)(struct ahash_request *req);
42 int (*digest)(struct ahash_request *req);
43 int (*export)(struct ahash_request *req, void *out);
44 int (*import)(struct ahash_request *req, const void *in);
45 int (*setkey)(struct crypto_ahash *tfm, const u8 *key,
46 unsigned int keylen);
47
48 struct hash_alg_common halg;
49};
50
Herbert Xu7b5a080b2008-08-31 15:47:27 +100051struct shash_desc {
52 struct crypto_shash *tfm;
53 u32 flags;
54
55 void *__ctx[] CRYPTO_MINALIGN_ATTR;
56};
57
58struct shash_alg {
59 int (*init)(struct shash_desc *desc);
60 int (*update)(struct shash_desc *desc, const u8 *data,
61 unsigned int len);
62 int (*final)(struct shash_desc *desc, u8 *out);
63 int (*finup)(struct shash_desc *desc, const u8 *data,
64 unsigned int len, u8 *out);
65 int (*digest)(struct shash_desc *desc, const u8 *data,
66 unsigned int len, u8 *out);
Herbert Xu99d27e12009-07-09 20:30:57 +080067 int (*export)(struct shash_desc *desc, void *out);
68 int (*import)(struct shash_desc *desc, const void *in);
Herbert Xu7b5a080b2008-08-31 15:47:27 +100069 int (*setkey)(struct crypto_shash *tfm, const u8 *key,
70 unsigned int keylen);
71
72 unsigned int descsize;
Herbert Xu88056ec2009-07-14 12:28:26 +080073
74 /* These fields must match hash_alg_common. */
Herbert Xu7b5a080b2008-08-31 15:47:27 +100075 unsigned int digestsize;
Herbert Xu99d27e12009-07-09 20:30:57 +080076 unsigned int statesize;
Herbert Xu7b5a080b2008-08-31 15:47:27 +100077
78 struct crypto_alg base;
79};
80
Herbert Xu18e33e62008-07-10 16:01:22 +080081struct crypto_ahash {
Herbert Xu88056ec2009-07-14 12:28:26 +080082 int (*init)(struct ahash_request *req);
83 int (*update)(struct ahash_request *req);
84 int (*final)(struct ahash_request *req);
85 int (*finup)(struct ahash_request *req);
86 int (*digest)(struct ahash_request *req);
87 int (*export)(struct ahash_request *req, void *out);
88 int (*import)(struct ahash_request *req, const void *in);
89 int (*setkey)(struct crypto_ahash *tfm, const u8 *key,
90 unsigned int keylen);
91
Herbert Xu88056ec2009-07-14 12:28:26 +080092 unsigned int reqsize;
Herbert Xu18e33e62008-07-10 16:01:22 +080093 struct crypto_tfm base;
94};
95
Herbert Xu7b5a080b2008-08-31 15:47:27 +100096struct crypto_shash {
Herbert Xu113adef2009-07-14 12:50:12 +080097 unsigned int descsize;
Herbert Xu7b5a080b2008-08-31 15:47:27 +100098 struct crypto_tfm base;
99};
100
Herbert Xu18e33e62008-07-10 16:01:22 +0800101static inline struct crypto_ahash *__crypto_ahash_cast(struct crypto_tfm *tfm)
102{
Herbert Xu88056ec2009-07-14 12:28:26 +0800103 return container_of(tfm, struct crypto_ahash, base);
Herbert Xu18e33e62008-07-10 16:01:22 +0800104}
105
Herbert Xu88056ec2009-07-14 12:28:26 +0800106struct crypto_ahash *crypto_alloc_ahash(const char *alg_name, u32 type,
107 u32 mask);
Herbert Xu18e33e62008-07-10 16:01:22 +0800108
109static inline struct crypto_tfm *crypto_ahash_tfm(struct crypto_ahash *tfm)
110{
111 return &tfm->base;
112}
113
114static inline void crypto_free_ahash(struct crypto_ahash *tfm)
115{
Herbert Xu88056ec2009-07-14 12:28:26 +0800116 crypto_destroy_tfm(tfm, crypto_ahash_tfm(tfm));
Herbert Xu18e33e62008-07-10 16:01:22 +0800117}
118
119static inline unsigned int crypto_ahash_alignmask(
120 struct crypto_ahash *tfm)
121{
122 return crypto_tfm_alg_alignmask(crypto_ahash_tfm(tfm));
123}
124
Herbert Xu88056ec2009-07-14 12:28:26 +0800125static inline struct hash_alg_common *__crypto_hash_alg_common(
126 struct crypto_alg *alg)
Herbert Xu18e33e62008-07-10 16:01:22 +0800127{
Herbert Xu88056ec2009-07-14 12:28:26 +0800128 return container_of(alg, struct hash_alg_common, base);
129}
130
131static inline struct hash_alg_common *crypto_hash_alg_common(
132 struct crypto_ahash *tfm)
133{
134 return __crypto_hash_alg_common(crypto_ahash_tfm(tfm)->__crt_alg);
Herbert Xu18e33e62008-07-10 16:01:22 +0800135}
136
137static inline unsigned int crypto_ahash_digestsize(struct crypto_ahash *tfm)
138{
Herbert Xu500b3e32009-07-14 20:29:57 +0800139 return crypto_hash_alg_common(tfm)->digestsize;
Herbert Xu88056ec2009-07-14 12:28:26 +0800140}
141
142static inline unsigned int crypto_ahash_statesize(struct crypto_ahash *tfm)
143{
144 return crypto_hash_alg_common(tfm)->statesize;
Herbert Xu18e33e62008-07-10 16:01:22 +0800145}
146
147static inline u32 crypto_ahash_get_flags(struct crypto_ahash *tfm)
148{
149 return crypto_tfm_get_flags(crypto_ahash_tfm(tfm));
150}
151
152static inline void crypto_ahash_set_flags(struct crypto_ahash *tfm, u32 flags)
153{
154 crypto_tfm_set_flags(crypto_ahash_tfm(tfm), flags);
155}
156
157static inline void crypto_ahash_clear_flags(struct crypto_ahash *tfm, u32 flags)
158{
159 crypto_tfm_clear_flags(crypto_ahash_tfm(tfm), flags);
160}
161
162static inline struct crypto_ahash *crypto_ahash_reqtfm(
163 struct ahash_request *req)
164{
165 return __crypto_ahash_cast(req->base.tfm);
166}
167
168static inline unsigned int crypto_ahash_reqsize(struct crypto_ahash *tfm)
169{
Herbert Xu88056ec2009-07-14 12:28:26 +0800170 return tfm->reqsize;
Herbert Xu18e33e62008-07-10 16:01:22 +0800171}
172
Herbert Xudec8b782008-11-02 21:38:11 +0800173static inline void *ahash_request_ctx(struct ahash_request *req)
174{
175 return req->__ctx;
176}
177
Herbert Xu18e33e62008-07-10 16:01:22 +0800178static inline int crypto_ahash_setkey(struct crypto_ahash *tfm,
179 const u8 *key, unsigned int keylen)
180{
Herbert Xu88056ec2009-07-14 12:28:26 +0800181 return tfm->setkey(tfm, key, keylen);
Herbert Xu18e33e62008-07-10 16:01:22 +0800182}
183
184static inline int crypto_ahash_digest(struct ahash_request *req)
185{
Herbert Xu88056ec2009-07-14 12:28:26 +0800186 return crypto_ahash_reqtfm(req)->digest(req);
Herbert Xu18e33e62008-07-10 16:01:22 +0800187}
188
Herbert Xu88056ec2009-07-14 12:28:26 +0800189static inline int crypto_ahash_export(struct ahash_request *req, void *out)
Herbert Xudec8b782008-11-02 21:38:11 +0800190{
Herbert Xu88056ec2009-07-14 12:28:26 +0800191 return crypto_ahash_reqtfm(req)->export(req, out);
Herbert Xudec8b782008-11-02 21:38:11 +0800192}
193
Herbert Xu88056ec2009-07-14 12:28:26 +0800194static inline int crypto_ahash_import(struct ahash_request *req, const void *in)
195{
196 return crypto_ahash_reqtfm(req)->import(req, in);
197}
Herbert Xudec8b782008-11-02 21:38:11 +0800198
Herbert Xu318e5312008-08-05 13:34:30 +0800199static inline int crypto_ahash_init(struct ahash_request *req)
200{
Herbert Xu88056ec2009-07-14 12:28:26 +0800201 return crypto_ahash_reqtfm(req)->init(req);
Herbert Xu318e5312008-08-05 13:34:30 +0800202}
203
204static inline int crypto_ahash_update(struct ahash_request *req)
205{
Herbert Xu88056ec2009-07-14 12:28:26 +0800206 return crypto_ahash_reqtfm(req)->update(req);
Herbert Xu318e5312008-08-05 13:34:30 +0800207}
208
209static inline int crypto_ahash_final(struct ahash_request *req)
210{
Herbert Xu88056ec2009-07-14 12:28:26 +0800211 return crypto_ahash_reqtfm(req)->final(req);
Herbert Xu318e5312008-08-05 13:34:30 +0800212}
213
Herbert Xu18e33e62008-07-10 16:01:22 +0800214static inline void ahash_request_set_tfm(struct ahash_request *req,
215 struct crypto_ahash *tfm)
216{
217 req->base.tfm = crypto_ahash_tfm(tfm);
218}
219
220static inline struct ahash_request *ahash_request_alloc(
221 struct crypto_ahash *tfm, gfp_t gfp)
222{
223 struct ahash_request *req;
224
225 req = kmalloc(sizeof(struct ahash_request) +
226 crypto_ahash_reqsize(tfm), gfp);
227
228 if (likely(req))
229 ahash_request_set_tfm(req, tfm);
230
231 return req;
232}
233
234static inline void ahash_request_free(struct ahash_request *req)
235{
Herbert Xuaef73cf2009-07-11 22:22:14 +0800236 kzfree(req);
Herbert Xu18e33e62008-07-10 16:01:22 +0800237}
238
239static inline struct ahash_request *ahash_request_cast(
240 struct crypto_async_request *req)
241{
242 return container_of(req, struct ahash_request, base);
243}
244
245static inline void ahash_request_set_callback(struct ahash_request *req,
246 u32 flags,
247 crypto_completion_t complete,
248 void *data)
249{
250 req->base.complete = complete;
251 req->base.data = data;
252 req->base.flags = flags;
253}
254
255static inline void ahash_request_set_crypt(struct ahash_request *req,
256 struct scatterlist *src, u8 *result,
257 unsigned int nbytes)
258{
259 req->src = src;
260 req->nbytes = nbytes;
261 req->result = result;
262}
263
Herbert Xu7b5a080b2008-08-31 15:47:27 +1000264struct crypto_shash *crypto_alloc_shash(const char *alg_name, u32 type,
265 u32 mask);
266
267static inline struct crypto_tfm *crypto_shash_tfm(struct crypto_shash *tfm)
268{
269 return &tfm->base;
270}
271
272static inline void crypto_free_shash(struct crypto_shash *tfm)
273{
Herbert Xu412e87a2009-02-05 16:51:25 +1100274 crypto_destroy_tfm(tfm, crypto_shash_tfm(tfm));
Herbert Xu7b5a080b2008-08-31 15:47:27 +1000275}
276
277static inline unsigned int crypto_shash_alignmask(
278 struct crypto_shash *tfm)
279{
280 return crypto_tfm_alg_alignmask(crypto_shash_tfm(tfm));
281}
282
Herbert Xu97495982009-02-03 12:47:44 +1100283static inline unsigned int crypto_shash_blocksize(struct crypto_shash *tfm)
284{
285 return crypto_tfm_alg_blocksize(crypto_shash_tfm(tfm));
286}
287
Herbert Xu7b5a080b2008-08-31 15:47:27 +1000288static inline struct shash_alg *__crypto_shash_alg(struct crypto_alg *alg)
289{
290 return container_of(alg, struct shash_alg, base);
291}
292
293static inline struct shash_alg *crypto_shash_alg(struct crypto_shash *tfm)
294{
295 return __crypto_shash_alg(crypto_shash_tfm(tfm)->__crt_alg);
296}
297
298static inline unsigned int crypto_shash_digestsize(struct crypto_shash *tfm)
299{
300 return crypto_shash_alg(tfm)->digestsize;
301}
302
Herbert Xu99d27e12009-07-09 20:30:57 +0800303static inline unsigned int crypto_shash_statesize(struct crypto_shash *tfm)
304{
305 return crypto_shash_alg(tfm)->statesize;
306}
307
Herbert Xu7b5a080b2008-08-31 15:47:27 +1000308static inline u32 crypto_shash_get_flags(struct crypto_shash *tfm)
309{
310 return crypto_tfm_get_flags(crypto_shash_tfm(tfm));
311}
312
313static inline void crypto_shash_set_flags(struct crypto_shash *tfm, u32 flags)
314{
315 crypto_tfm_set_flags(crypto_shash_tfm(tfm), flags);
316}
317
318static inline void crypto_shash_clear_flags(struct crypto_shash *tfm, u32 flags)
319{
320 crypto_tfm_clear_flags(crypto_shash_tfm(tfm), flags);
321}
322
323static inline unsigned int crypto_shash_descsize(struct crypto_shash *tfm)
324{
Herbert Xu113adef2009-07-14 12:50:12 +0800325 return tfm->descsize;
Herbert Xu7b5a080b2008-08-31 15:47:27 +1000326}
327
328static inline void *shash_desc_ctx(struct shash_desc *desc)
329{
330 return desc->__ctx;
331}
332
333int crypto_shash_setkey(struct crypto_shash *tfm, const u8 *key,
334 unsigned int keylen);
335int crypto_shash_digest(struct shash_desc *desc, const u8 *data,
336 unsigned int len, u8 *out);
337
Herbert Xu99d27e12009-07-09 20:30:57 +0800338static inline int crypto_shash_export(struct shash_desc *desc, void *out)
Herbert Xudec8b782008-11-02 21:38:11 +0800339{
Herbert Xu99d27e12009-07-09 20:30:57 +0800340 return crypto_shash_alg(desc->tfm)->export(desc, out);
Herbert Xudec8b782008-11-02 21:38:11 +0800341}
342
Herbert Xu99d27e12009-07-09 20:30:57 +0800343static inline int crypto_shash_import(struct shash_desc *desc, const void *in)
344{
345 return crypto_shash_alg(desc->tfm)->import(desc, in);
346}
Herbert Xudec8b782008-11-02 21:38:11 +0800347
Herbert Xu7b5a080b2008-08-31 15:47:27 +1000348static inline int crypto_shash_init(struct shash_desc *desc)
349{
350 return crypto_shash_alg(desc->tfm)->init(desc);
351}
352
353int crypto_shash_update(struct shash_desc *desc, const u8 *data,
354 unsigned int len);
355int crypto_shash_final(struct shash_desc *desc, u8 *out);
356int crypto_shash_finup(struct shash_desc *desc, const u8 *data,
357 unsigned int len, u8 *out);
358
Herbert Xu18e33e62008-07-10 16:01:22 +0800359#endif /* _CRYPTO_HASH_H */