Blame view
include/crypto/scatterwalk.h
3.14 KB
2874c5fd2 treewide: Replace... |
1 |
/* SPDX-License-Identifier: GPL-2.0-or-later */ |
1da177e4c Linux-2.6.12-rc2 |
2 |
/* |
42c271c6c [CRYPTO] scatterw... |
3 |
* Cryptographic scatter and gather helpers. |
1da177e4c Linux-2.6.12-rc2 |
4 5 6 7 |
* * Copyright (c) 2002 James Morris <jmorris@intercode.com.au> * Copyright (c) 2002 Adam J. Richter <adam@yggdrasil.com> * Copyright (c) 2004 Jean-Luc Cooke <jlcooke@certainkey.com> |
42c271c6c [CRYPTO] scatterw... |
8 |
* Copyright (c) 2007 Herbert Xu <herbert@gondor.apana.org.au> |
1da177e4c Linux-2.6.12-rc2 |
9 10 11 12 |
*/ #ifndef _CRYPTO_SCATTERWALK_H #define _CRYPTO_SCATTERWALK_H |
5c64097aa [CRYPTO] scatterw... |
13 |
|
42c271c6c [CRYPTO] scatterw... |
14 |
#include <crypto/algapi.h> |
42c271c6c [CRYPTO] scatterw... |
15 16 |
#include <linux/highmem.h> #include <linux/kernel.h> |
5c64097aa [CRYPTO] scatterw... |
17 |
#include <linux/scatterlist.h> |
1da177e4c Linux-2.6.12-rc2 |
18 |
|
079f2f748 crypto: scatterwa... |
19 |
static inline void scatterwalk_crypto_chain(struct scatterlist *head, |
8c30fbe63 crypto: scatterwa... |
20 |
struct scatterlist *sg, int num) |
079f2f748 crypto: scatterwa... |
21 |
{ |
079f2f748 crypto: scatterwa... |
22 |
if (sg) |
c56f6d127 crypto: replace s... |
23 |
sg_chain(head, num, sg); |
079f2f748 crypto: scatterwa... |
24 25 26 |
else sg_mark_end(head); } |
5c64097aa [CRYPTO] scatterw... |
27 28 29 30 31 |
static inline unsigned int scatterwalk_pagelen(struct scatter_walk *walk) { unsigned int len = walk->sg->offset + walk->sg->length - walk->offset; unsigned int len_this_page = offset_in_page(~walk->offset) + 1; return len_this_page > len ? len : len_this_page; |
1da177e4c Linux-2.6.12-rc2 |
32 |
} |
c774e93e2 [CRYPTO] Add plum... |
33 34 |
static inline unsigned int scatterwalk_clamp(struct scatter_walk *walk, unsigned int nbytes) |
1da177e4c Linux-2.6.12-rc2 |
35 |
{ |
5c64097aa [CRYPTO] scatterw... |
36 37 |
unsigned int len_this_page = scatterwalk_pagelen(walk); return nbytes > len_this_page ? len_this_page : nbytes; |
1da177e4c Linux-2.6.12-rc2 |
38 39 40 41 42 |
} static inline void scatterwalk_advance(struct scatter_walk *walk, unsigned int nbytes) { |
1da177e4c Linux-2.6.12-rc2 |
43 |
walk->offset += nbytes; |
1da177e4c Linux-2.6.12-rc2 |
44 |
} |
954773779 [CRYPTO] Add alig... |
45 46 47 48 49 |
static inline unsigned int scatterwalk_aligned(struct scatter_walk *walk, unsigned int alignmask) { return !(walk->offset & alignmask); } |
5c64097aa [CRYPTO] scatterw... |
50 51 |
static inline struct page *scatterwalk_page(struct scatter_walk *walk) { |
78c2f0b8c [SG] Update crypt... |
52 |
return sg_page(walk->sg) + (walk->offset >> PAGE_SHIFT); |
5c64097aa [CRYPTO] scatterw... |
53 |
} |
f0dfc0b0b crypto: remove th... |
54 |
static inline void scatterwalk_unmap(void *vaddr) |
5c64097aa [CRYPTO] scatterw... |
55 |
{ |
f0dfc0b0b crypto: remove th... |
56 |
kunmap_atomic(vaddr); |
5c64097aa [CRYPTO] scatterw... |
57 |
} |
ac0272581 crypto: scatterwa... |
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
static inline void scatterwalk_start(struct scatter_walk *walk, struct scatterlist *sg) { walk->sg = sg; walk->offset = sg->offset; } static inline void *scatterwalk_map(struct scatter_walk *walk) { return kmap_atomic(scatterwalk_page(walk)) + offset_in_page(walk->offset); } static inline void scatterwalk_pagedone(struct scatter_walk *walk, int out, unsigned int more) { if (out) { struct page *page; page = sg_page(walk->sg) + ((walk->offset - 1) >> PAGE_SHIFT); /* Test ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE first as * PageSlab cannot be optimised away per se due to * use of volatile pointer. */ if (ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE && !PageSlab(page)) flush_dcache_page(page); } if (more && walk->offset >= walk->sg->offset + walk->sg->length) scatterwalk_start(walk, sg_next(walk->sg)); } static inline void scatterwalk_done(struct scatter_walk *walk, int out, int more) { if (!more || walk->offset >= walk->sg->offset + walk->sg->length || !(walk->offset & (PAGE_SIZE - 1))) scatterwalk_pagedone(walk, out, more); } |
5c64097aa [CRYPTO] scatterw... |
97 98 |
void scatterwalk_copychunks(void *buf, struct scatter_walk *walk, size_t nbytes, int out); |
f0dfc0b0b crypto: remove th... |
99 |
void *scatterwalk_map(struct scatter_walk *walk); |
1da177e4c Linux-2.6.12-rc2 |
100 |
|
5fa0fea27 [CRYPTO] scatterw... |
101 102 |
void scatterwalk_map_and_copy(void *buf, struct scatterlist *sg, unsigned int start, unsigned int nbytes, int out); |
fc42bcba9 crypto: scatterwa... |
103 104 105 |
struct scatterlist *scatterwalk_ffwd(struct scatterlist dst[2], struct scatterlist *src, unsigned int len); |
1da177e4c Linux-2.6.12-rc2 |
106 |
#endif /* _CRYPTO_SCATTERWALK_H */ |