PATH:
usr
/
src
/
kernels
/
5.14.0-611.49.2.el9_7.x86_64
/
include
/
crypto
/* SPDX-License-Identifier: GPL-2.0-or-later */ /* * Cryptographic scatter and gather helpers. * * 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> * Copyright (c) 2007 Herbert Xu <herbert@gondor.apana.org.au> */ #ifndef _CRYPTO_SCATTERWALK_H #define _CRYPTO_SCATTERWALK_H #include <crypto/algapi.h> #include <linux/highmem.h> #include <linux/mm.h> #include <linux/scatterlist.h> static inline void scatterwalk_crypto_chain(struct scatterlist *head, struct scatterlist *sg, int num) { if (sg) sg_chain(head, num, sg); else sg_mark_end(head); } 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; } static inline unsigned int scatterwalk_clamp(struct scatter_walk *walk, unsigned int nbytes) { unsigned int len_this_page = scatterwalk_pagelen(walk); return nbytes > len_this_page ? len_this_page : nbytes; } static inline void scatterwalk_advance(struct scatter_walk *walk, unsigned int nbytes) { walk->offset += nbytes; } static inline unsigned int scatterwalk_aligned(struct scatter_walk *walk, unsigned int alignmask) { return !(walk->offset & alignmask); } static inline struct page *scatterwalk_page(struct scatter_walk *walk) { return sg_page(walk->sg) + (walk->offset >> PAGE_SHIFT); } static inline void scatterwalk_unmap(void *vaddr) { kunmap_atomic(vaddr); } 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); flush_dcache_page(page); } if (more && walk->offset >= walk->sg->offset + walk->sg->length) scatterwalk_start(walk, sg_next(walk->sg)); } /* * Flush the dcache of any pages that overlap the region * [offset, offset + nbytes) relative to base_page. * * This should be called only when ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE, to ensure * that all relevant code (including the call to sg_page() in the caller, if * applicable) gets fully optimized out when !ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE. */ static inline void __scatterwalk_flush_dcache_pages(struct page *base_page, unsigned int offset, unsigned int nbytes) { unsigned int num_pages; unsigned int i; base_page += offset / PAGE_SIZE; offset %= PAGE_SIZE; /* * This is an overflow-safe version of * num_pages = DIV_ROUND_UP(offset + nbytes, PAGE_SIZE). */ num_pages = nbytes / PAGE_SIZE; num_pages += DIV_ROUND_UP(offset + (nbytes % PAGE_SIZE), PAGE_SIZE); for (i = 0; i < num_pages; i++) flush_dcache_page(base_page + i); } 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); } void scatterwalk_copychunks(void *buf, struct scatter_walk *walk, size_t nbytes, int out); void *scatterwalk_map(struct scatter_walk *walk); void memcpy_sglist(struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes); void scatterwalk_map_and_copy(void *buf, struct scatterlist *sg, unsigned int start, unsigned int nbytes, int out); struct scatterlist *scatterwalk_ffwd(struct scatterlist dst[2], struct scatterlist *src, unsigned int len); #endif /* _CRYPTO_SCATTERWALK_H */
[-] akcipher.h
[edit]
[-] hkdf.h
[edit]
[-] dh.h
[edit]
[-] hash.h
[edit]
[-] ctr.h
[edit]
[-] blowfish.h
[edit]
[-] engine.h
[edit]
[-] arc4.h
[edit]
[-] kpp.h
[edit]
[-] blake2s.h
[edit]
[-] chacha20poly1305.h
[edit]
[-] ecdh.h
[edit]
[-] cast_common.h
[edit]
[-] gf128mul.h
[edit]
[-] asym_tpm_subtype.h
[edit]
[-] chacha.h
[edit]
[-] cryptd.h
[edit]
[-] b128ops.h
[edit]
[-] md5.h
[edit]
[-] streebog.h
[edit]
[-] sha1.h
[edit]
[-] public_key.h
[edit]
[-] drbg.h
[edit]
[-] sha256_base.h
[edit]
[-] sha2.h
[edit]
[-] sha512_base.h
[edit]
[-] pkcs7.h
[edit]
[-] skcipher.h
[edit]
[-] sm4.h
[edit]
[-] sha3.h
[edit]
[-] rng.h
[edit]
[-] cast6.h
[edit]
[-] twofish.h
[edit]
[-] scatterwalk.h
[edit]
[-] blake2b.h
[edit]
[-] ghash.h
[edit]
[+]
internal
[-] sm3.h
[edit]
[-] ecc_curve.h
[edit]
[-] des.h
[edit]
[-] aead.h
[edit]
[-] hash_info.h
[edit]
[-] gcm.h
[edit]
[-] cast5.h
[edit]
[-] sha1_base.h
[edit]
[-] xts.h
[edit]
[-] hmac.h
[edit]
[-] null.h
[edit]
[-] curve25519.h
[edit]
[-] acompress.h
[edit]
[-] nhpoly1305.h
[edit]
[-] sm3_base.h
[edit]
[-] serpent.h
[edit]
[-] algapi.h
[edit]
[-] padlock.h
[edit]
[-] pcrypt.h
[edit]
[+]
..
[-] poly1305.h
[edit]
[-] aes.h
[edit]
[-] if_alg.h
[edit]
[-] authenc.h
[edit]
[-] sm2.h
[edit]