diff options
| author | Eric Biggers <ebiggers@kernel.org> | 2025-06-13 11:48:14 -0700 | 
|---|---|---|
| committer | Eric Biggers <ebiggers@kernel.org> | 2025-06-30 09:26:19 -0700 | 
| commit | e49a3eac9207e9575337f70feeb29430f6f16bb7 (patch) | |
| tree | 4015d009b6a174576d8ac9f791f4196e312ac3ac | |
| parent | d0b3b7b22dfa1f4b515fd3a295b3fd958f9e81af (diff) | |
lib/crypto: Explicitly include <linux/export.h>
Fix build warnings with W=1 that started appearing after
commit a934a57a42f6 ("scripts/misc-check: check missing #include
<linux/export.h> when W=1").
While at it, also sort the include lists alphabetically.  (Keep
asm/irqflags.h last, as otherwise it doesn't build on alpha.)
This handles all of lib/crypto/, but not arch/*/lib/crypto/.  The
exports in arch/*/lib/crypto/ will go away when the code is properly
integrated into lib/crypto/ as planned.
Link: https://lore.kernel.org/r/20250613184814.50173-1-ebiggers@kernel.org
Signed-off-by: Eric Biggers <ebiggers@kernel.org>
30 files changed, 64 insertions, 38 deletions
| diff --git a/lib/crypto/aes.c b/lib/crypto/aes.c index eafe14d021f5..b57fda3460f1 100644 --- a/lib/crypto/aes.c +++ b/lib/crypto/aes.c @@ -5,6 +5,7 @@  #include <crypto/aes.h>  #include <linux/crypto.h> +#include <linux/export.h>  #include <linux/module.h>  #include <linux/unaligned.h> diff --git a/lib/crypto/aescfb.c b/lib/crypto/aescfb.c index 2f09ae92ffa0..0f294c8cbf3c 100644 --- a/lib/crypto/aescfb.c +++ b/lib/crypto/aescfb.c @@ -5,11 +5,10 @@   * Copyright 2023 Google LLC   */ -#include <linux/module.h> - -#include <crypto/algapi.h>  #include <crypto/aes.h> - +#include <crypto/algapi.h> +#include <linux/export.h> +#include <linux/module.h>  #include <asm/irqflags.h>  static void aescfb_encrypt_block(const struct crypto_aes_ctx *ctx, void *dst, diff --git a/lib/crypto/aesgcm.c b/lib/crypto/aesgcm.c index faa4dee9bb1b..ac0b2fcfd606 100644 --- a/lib/crypto/aesgcm.c +++ b/lib/crypto/aesgcm.c @@ -5,12 +5,11 @@   * Copyright 2022 Google LLC   */ -#include <linux/module.h> -  #include <crypto/algapi.h>  #include <crypto/gcm.h>  #include <crypto/ghash.h> - +#include <linux/export.h> +#include <linux/module.h>  #include <asm/irqflags.h>  static void aesgcm_encrypt_block(const struct crypto_aes_ctx *ctx, void *dst, diff --git a/lib/crypto/arc4.c b/lib/crypto/arc4.c index 838812d18216..4e950e1e66d0 100644 --- a/lib/crypto/arc4.c +++ b/lib/crypto/arc4.c @@ -8,6 +8,7 @@   */  #include <crypto/arc4.h> +#include <linux/export.h>  #include <linux/module.h>  int arc4_setkey(struct arc4_ctx *ctx, const u8 *in_key, unsigned int key_len) diff --git a/lib/crypto/blake2s-generic.c b/lib/crypto/blake2s-generic.c index 09682136b57c..9828176a2efe 100644 --- a/lib/crypto/blake2s-generic.c +++ b/lib/crypto/blake2s-generic.c @@ -9,11 +9,12 @@   */  #include <crypto/internal/blake2s.h> -#include <linux/types.h> -#include <linux/string.h> -#include <linux/kernel.h> -#include <linux/init.h>  #include <linux/bug.h> +#include <linux/export.h> +#include <linux/init.h> +#include <linux/kernel.h> +#include <linux/string.h> +#include <linux/types.h>  #include <linux/unaligned.h>  static const u8 blake2s_sigma[10][16] = { diff --git a/lib/crypto/blake2s.c b/lib/crypto/blake2s.c index b0f9a678300b..f6ec68c3dcda 100644 --- a/lib/crypto/blake2s.c +++ b/lib/crypto/blake2s.c @@ -9,12 +9,13 @@   */  #include <crypto/internal/blake2s.h> -#include <linux/types.h> -#include <linux/string.h> +#include <linux/bug.h> +#include <linux/export.h> +#include <linux/init.h>  #include <linux/kernel.h>  #include <linux/module.h> -#include <linux/init.h> -#include <linux/bug.h> +#include <linux/string.h> +#include <linux/types.h>  static inline void blake2s_set_lastblock(struct blake2s_state *state)  { diff --git a/lib/crypto/chacha.c b/lib/crypto/chacha.c index ced87dd31a97..77f68de71066 100644 --- a/lib/crypto/chacha.c +++ b/lib/crypto/chacha.c @@ -5,13 +5,13 @@   * Copyright (C) 2015 Martin Willi   */ +#include <crypto/chacha.h> +#include <linux/bitops.h>  #include <linux/bug.h> -#include <linux/kernel.h>  #include <linux/export.h> -#include <linux/bitops.h> +#include <linux/kernel.h>  #include <linux/string.h>  #include <linux/unaligned.h> -#include <crypto/chacha.h>  static void chacha_permute(struct chacha_state *state, int nrounds)  { diff --git a/lib/crypto/chacha20poly1305.c b/lib/crypto/chacha20poly1305.c index e29eed49a5a1..0b49d6aedefd 100644 --- a/lib/crypto/chacha20poly1305.c +++ b/lib/crypto/chacha20poly1305.c @@ -7,16 +7,16 @@   * Information: https://tools.ietf.org/html/rfc8439   */ -#include <crypto/chacha20poly1305.h>  #include <crypto/chacha.h> +#include <crypto/chacha20poly1305.h>  #include <crypto/poly1305.h>  #include <crypto/utils.h> - -#include <linux/unaligned.h> -#include <linux/kernel.h> +#include <linux/export.h>  #include <linux/init.h> +#include <linux/kernel.h>  #include <linux/mm.h>  #include <linux/module.h> +#include <linux/unaligned.h>  static void chacha_load_key(u32 *k, const u8 *in)  { diff --git a/lib/crypto/curve25519-generic.c b/lib/crypto/curve25519-generic.c index de7c99172fa2..f8aa70c9f559 100644 --- a/lib/crypto/curve25519-generic.c +++ b/lib/crypto/curve25519-generic.c @@ -10,6 +10,7 @@   */  #include <crypto/curve25519.h> +#include <linux/export.h>  #include <linux/module.h>  const u8 curve25519_null_point[CURVE25519_KEY_SIZE] __aligned(32) = { 0 }; diff --git a/lib/crypto/des.c b/lib/crypto/des.c index d3423b34a8e9..a906070136dc 100644 --- a/lib/crypto/des.c +++ b/lib/crypto/des.c @@ -7,21 +7,20 @@   * Copyright (c) 2005 Dag Arne Osvik <da@osvik.no>   */ +#include <crypto/des.h> +#include <crypto/internal/des.h>  #include <linux/bitops.h>  #include <linux/compiler.h>  #include <linux/crypto.h>  #include <linux/errno.h> +#include <linux/export.h>  #include <linux/fips.h>  #include <linux/init.h>  #include <linux/module.h>  #include <linux/string.h>  #include <linux/types.h> -  #include <linux/unaligned.h> -#include <crypto/des.h> -#include <crypto/internal/des.h> -  #define ROL(x, r) ((x) = rol32((x), (r)))  #define ROR(x, r) ((x) = ror32((x), (r))) diff --git a/lib/crypto/gf128mul.c b/lib/crypto/gf128mul.c index fbe72cb3453a..2a34590fe3f1 100644 --- a/lib/crypto/gf128mul.c +++ b/lib/crypto/gf128mul.c @@ -49,6 +49,7 @@  */  #include <crypto/gf128mul.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/module.h>  #include <linux/slab.h> diff --git a/lib/crypto/libchacha.c b/lib/crypto/libchacha.c index ebcca381e248..26862ad90a96 100644 --- a/lib/crypto/libchacha.c +++ b/lib/crypto/libchacha.c @@ -5,12 +5,11 @@   * Copyright (C) 2015 Martin Willi   */ -#include <linux/kernel.h> -#include <linux/export.h> -#include <linux/module.h> -  #include <crypto/algapi.h> // for crypto_xor_cpy  #include <crypto/chacha.h> +#include <linux/export.h> +#include <linux/kernel.h> +#include <linux/module.h>  void chacha_crypt_generic(struct chacha_state *state, u8 *dst, const u8 *src,  			  unsigned int bytes, int nrounds) diff --git a/lib/crypto/memneq.c b/lib/crypto/memneq.c index a2afd10349c9..44daacb8cb51 100644 --- a/lib/crypto/memneq.c +++ b/lib/crypto/memneq.c @@ -59,9 +59,10 @@   * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.   */ -#include <linux/unaligned.h>  #include <crypto/algapi.h> +#include <linux/export.h>  #include <linux/module.h> +#include <linux/unaligned.h>  /* Generic path for arbitrary size */  static inline unsigned long diff --git a/lib/crypto/mpi/mpi-add.c b/lib/crypto/mpi/mpi-add.c index 3015140d4860..c0375c1672fa 100644 --- a/lib/crypto/mpi/mpi-add.c +++ b/lib/crypto/mpi/mpi-add.c @@ -11,6 +11,8 @@   *	 to avoid revealing of sensitive data due to paging etc.   */ +#include <linux/export.h> +  #include "mpi-internal.h"  int mpi_add(MPI w, MPI u, MPI v) diff --git a/lib/crypto/mpi/mpi-bit.c b/lib/crypto/mpi/mpi-bit.c index 934d81311360..b3d0e7ddbc03 100644 --- a/lib/crypto/mpi/mpi-bit.c +++ b/lib/crypto/mpi/mpi-bit.c @@ -18,6 +18,8 @@   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA   */ +#include <linux/export.h> +  #include "mpi-internal.h"  #include "longlong.h" diff --git a/lib/crypto/mpi/mpi-cmp.c b/lib/crypto/mpi/mpi-cmp.c index ceaebe181cd7..b42929296bce 100644 --- a/lib/crypto/mpi/mpi-cmp.c +++ b/lib/crypto/mpi/mpi-cmp.c @@ -18,6 +18,8 @@   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA   */ +#include <linux/export.h> +  #include "mpi-internal.h"  int mpi_cmp_ui(MPI u, unsigned long v) diff --git a/lib/crypto/mpi/mpi-mul.c b/lib/crypto/mpi/mpi-mul.c index 7e6ff1ce3e9b..d79f186ad90b 100644 --- a/lib/crypto/mpi/mpi-mul.c +++ b/lib/crypto/mpi/mpi-mul.c @@ -11,6 +11,8 @@   *	 to avoid revealing of sensitive data due to paging etc.   */ +#include <linux/export.h> +  #include "mpi-internal.h"  int mpi_mul(MPI w, MPI u, MPI v) diff --git a/lib/crypto/mpi/mpi-pow.c b/lib/crypto/mpi/mpi-pow.c index 67fbd4c2503d..9e695a3bda3a 100644 --- a/lib/crypto/mpi/mpi-pow.c +++ b/lib/crypto/mpi/mpi-pow.c @@ -13,8 +13,10 @@   *	 however I decided to publish this code under the plain GPL.   */ +#include <linux/export.h>  #include <linux/sched.h>  #include <linux/string.h> +  #include "mpi-internal.h"  #include "longlong.h" diff --git a/lib/crypto/mpi/mpi-sub-ui.c b/lib/crypto/mpi/mpi-sub-ui.c index b41b082b5f3e..0edcdbd24833 100644 --- a/lib/crypto/mpi/mpi-sub-ui.c +++ b/lib/crypto/mpi/mpi-sub-ui.c @@ -32,6 +32,8 @@   * see https://www.gnu.org/licenses/.   */ +#include <linux/export.h> +  #include "mpi-internal.h"  int mpi_sub_ui(MPI w, MPI u, unsigned long vval) diff --git a/lib/crypto/mpi/mpicoder.c b/lib/crypto/mpi/mpicoder.c index dde01030807d..47f6939599b3 100644 --- a/lib/crypto/mpi/mpicoder.c +++ b/lib/crypto/mpi/mpicoder.c @@ -19,8 +19,9 @@   */  #include <linux/bitops.h> -#include <linux/count_zeros.h>  #include <linux/byteorder/generic.h> +#include <linux/count_zeros.h> +#include <linux/export.h>  #include <linux/scatterlist.h>  #include <linux/string.h>  #include "mpi-internal.h" diff --git a/lib/crypto/mpi/mpiutil.c b/lib/crypto/mpi/mpiutil.c index 979ece5a81d2..7f2db830f404 100644 --- a/lib/crypto/mpi/mpiutil.c +++ b/lib/crypto/mpi/mpiutil.c @@ -18,6 +18,8 @@   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA   */ +#include <linux/export.h> +  #include "mpi-internal.h"  /**************** diff --git a/lib/crypto/poly1305-donna32.c b/lib/crypto/poly1305-donna32.c index 0a4a2d99e365..b66131b3f6d4 100644 --- a/lib/crypto/poly1305-donna32.c +++ b/lib/crypto/poly1305-donna32.c @@ -6,9 +6,10 @@   * public domain.   */ +#include <crypto/internal/poly1305.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/unaligned.h> -#include <crypto/internal/poly1305.h>  void poly1305_core_setkey(struct poly1305_core_key *key,  			  const u8 raw_key[POLY1305_BLOCK_SIZE]) diff --git a/lib/crypto/poly1305-donna64.c b/lib/crypto/poly1305-donna64.c index 530287531b2e..8a72a5a84944 100644 --- a/lib/crypto/poly1305-donna64.c +++ b/lib/crypto/poly1305-donna64.c @@ -6,9 +6,10 @@   * public domain.   */ +#include <crypto/internal/poly1305.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/unaligned.h> -#include <crypto/internal/poly1305.h>  void poly1305_core_setkey(struct poly1305_core_key *key,  			  const u8 raw_key[POLY1305_BLOCK_SIZE]) diff --git a/lib/crypto/poly1305-generic.c b/lib/crypto/poly1305-generic.c index a73f700fa1fb..71a16c5c538b 100644 --- a/lib/crypto/poly1305-generic.c +++ b/lib/crypto/poly1305-generic.c @@ -8,6 +8,7 @@   */  #include <crypto/internal/poly1305.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/module.h> diff --git a/lib/crypto/poly1305.c b/lib/crypto/poly1305.c index 5f2f2af3b59f..a6dc182b6c22 100644 --- a/lib/crypto/poly1305.c +++ b/lib/crypto/poly1305.c @@ -9,6 +9,7 @@  #include <crypto/internal/blockhash.h>  #include <crypto/internal/poly1305.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/module.h>  #include <linux/string.h> diff --git a/lib/crypto/sha1.c b/lib/crypto/sha1.c index ebb60519ae93..6d809c3088be 100644 --- a/lib/crypto/sha1.c +++ b/lib/crypto/sha1.c @@ -6,12 +6,12 @@   * This was based on the git SHA1 implementation.   */ -#include <linux/kernel.h> +#include <crypto/sha1.h> +#include <linux/bitops.h>  #include <linux/export.h> +#include <linux/kernel.h>  #include <linux/module.h> -#include <linux/bitops.h>  #include <linux/string.h> -#include <crypto/sha1.h>  #include <linux/unaligned.h>  /* diff --git a/lib/crypto/sha256-generic.c b/lib/crypto/sha256-generic.c index a16ad4f25ebb..2968d95d0403 100644 --- a/lib/crypto/sha256-generic.c +++ b/lib/crypto/sha256-generic.c @@ -12,6 +12,7 @@   */  #include <crypto/internal/sha2.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/module.h>  #include <linux/string.h> diff --git a/lib/crypto/sha256.c b/lib/crypto/sha256.c index 107e5162507a..6bfa4ae8dfb5 100644 --- a/lib/crypto/sha256.c +++ b/lib/crypto/sha256.c @@ -13,6 +13,7 @@  #include <crypto/internal/blockhash.h>  #include <crypto/internal/sha2.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/module.h>  #include <linux/string.h> diff --git a/lib/crypto/sm3.c b/lib/crypto/sm3.c index efff0e267d84..c6b9ad8a3ac6 100644 --- a/lib/crypto/sm3.c +++ b/lib/crypto/sm3.c @@ -9,6 +9,7 @@   */  #include <crypto/sm3.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/module.h>  #include <linux/string.h> diff --git a/lib/crypto/utils.c b/lib/crypto/utils.c index 87da2a6dd161..dec381d5e906 100644 --- a/lib/crypto/utils.c +++ b/lib/crypto/utils.c @@ -5,9 +5,10 @@   * Copyright (c) 2006 Herbert Xu <herbert@gondor.apana.org.au>   */ -#include <linux/unaligned.h>  #include <crypto/utils.h> +#include <linux/export.h>  #include <linux/module.h> +#include <linux/unaligned.h>  /*   * XOR @len bytes from @src1 and @src2 together, writing the result to @dst | 
