public inbox for linux-crypto@vger.kernel.org
 help / color / mirror / Atom feed
* [GIT PULL] Crypto library updates for 7.0
@ 2026-02-09  3:42 Eric Biggers
  2026-02-10 18:10 ` pr-tracker-bot
  0 siblings, 1 reply; 2+ messages in thread
From: Eric Biggers @ 2026-02-09  3:42 UTC (permalink / raw)
  To: Linus Torvalds
  Cc: linux-crypto, linux-kernel, Ard Biesheuvel, Jason A. Donenfeld,
	Herbert Xu, David Howells, Holger Dengler, Rusydi H. Makarim

The following changes since commit 0f61b1860cc3f52aef9036d7235ed1f017632193:

  Linux 6.19-rc5 (2026-01-11 17:03:14 -1000)

are available in the Git repository at:

  https://git.kernel.org/pub/scm/linux/kernel/git/ebiggers/linux.git tags/libcrypto-for-linus

for you to fetch changes up to ffd42b6d0420c4be97cc28fd1bb5f4c29e286e98:

  lib/crypto: mldsa: Clarify the documentation for mldsa_verify() slightly (2026-02-03 19:28:51 -0800)

----------------------------------------------------------------

- Add support for verifying ML-DSA signatures.

  ML-DSA (Module-Lattice-Based Digital Signature Algorithm) is a
  recently-standardized post-quantum (quantum-resistant) signature
  algorithm. It was known as Dilithium pre-standardization.

  The first use case in the kernel will be module signing. But there
  are also other users of RSA and ECDSA signatures in the kernel that
  might want to upgrade to ML-DSA eventually.

- Improve the AES library:

    - Make the AES key expansion and single block encryption and
      decryption functions use the architecture-optimized AES code.
      Enable these optimizations by default.

    - Support preparing an AES key for encryption-only, using about
      half as much memory as a bidirectional key.

    - Replace the existing two generic implementations of AES with a
      single one.

- Simplify how Adiantum message hashing is implemented. Remove the
  "nhpoly1305" crypto_shash in favor of direct lib/crypto/ support for
  NH hashing, and enable optimizations by default.

----------------------------------------------------------------
Eric Biggers (52):
      lib/crypto: Add ML-DSA verification support
      lib/crypto: tests: Add KUnit tests for ML-DSA verification
      lib/crypto: nh: Add NH library
      lib/crypto: tests: Add KUnit tests for NH
      lib/crypto: arm/nh: Migrate optimized code into library
      lib/crypto: arm64/nh: Migrate optimized code into library
      lib/crypto: x86/nh: Migrate optimized code into library
      crypto: adiantum - Convert to use NH library
      crypto: adiantum - Use scatter_walk API instead of sg_miter
      crypto: adiantum - Use memcpy_{to,from}_sglist()
      crypto: adiantum - Drop support for asynchronous xchacha ciphers
      crypto: nhpoly1305 - Remove crypto_shash support
      crypto: testmgr - Remove nhpoly1305 tests
      fscrypt: Drop obsolete recommendation to enable optimized NHPoly1305
      lib/crypto: nh: Restore dependency of arch code on !KMSAN
      lib/crypto: mldsa: Add FIPS cryptographic algorithm self-test
      crypto: powerpc/aes - Rename struct aes_key
      lib/crypto: aes: Introduce improved AES library
      crypto: arm/aes-neonbs - Use AES library for single blocks
      crypto: arm/aes - Switch to aes_enc_tab[] and aes_dec_tab[]
      crypto: arm64/aes - Switch to aes_enc_tab[] and aes_dec_tab[]
      crypto: arm64/aes - Select CRYPTO_LIB_SHA256 from correct places
      crypto: aegis - Switch from crypto_ft_tab[] to aes_enc_tab[]
      crypto: aes - Remove aes-fixed-time / CONFIG_CRYPTO_AES_TI
      crypto: aes - Replace aes-generic with wrapper around lib
      lib/crypto: arm/aes: Migrate optimized code into library
      lib/crypto: arm64/aes: Migrate optimized code into library
      lib/crypto: powerpc/aes: Migrate SPE optimized code into library
      lib/crypto: powerpc/aes: Migrate POWER8 optimized code into library
      lib/crypto: riscv/aes: Migrate optimized code into library
      lib/crypto: s390/aes: Migrate optimized code into library
      lib/crypto: sparc/aes: Migrate optimized code into library
      lib/crypto: x86/aes: Add AES-NI optimization
      crypto: x86/aes - Remove the superseded AES-NI crypto_cipher
      Bluetooth: SMP: Use new AES library API
      chelsio: Use new AES library API
      net: phy: mscc: macsec: Use new AES library API
      staging: rtl8723bs: core: Use new AES library API
      crypto: arm/ghash - Use new AES library API
      crypto: arm64/ghash - Use new AES library API
      crypto: x86/aes-gcm - Use new AES library API
      crypto: ccp - Use new AES library API
      crypto: chelsio - Use new AES library API
      crypto: crypto4xx - Use new AES library API
      crypto: drbg - Use new AES library API
      crypto: inside-secure - Use new AES library API
      crypto: omap - Use new AES library API
      lib/crypto: aescfb: Use new AES library API
      lib/crypto: aesgcm: Use new AES library API
      lib/crypto: aes: Remove old AES en/decryption functions
      lib/crypto: aes: Drop 'volatile' from aes_sbox and aes_inv_sbox
      lib/crypto: mldsa: Clarify the documentation for mldsa_verify() slightly

Rusydi H. Makarim (1):
      lib/crypto: md5: Use rol32() instead of open-coding it

 Documentation/filesystems/fscrypt.rst              |    5 -
 arch/arm/configs/milbeaut_m10v_defconfig           |    1 -
 arch/arm/configs/multi_v7_defconfig                |    2 +-
 arch/arm/configs/omap2plus_defconfig               |    2 +-
 arch/arm/configs/pxa_defconfig                     |    2 +-
 arch/arm/crypto/Kconfig                            |   29 -
 arch/arm/crypto/Makefile                           |    4 -
 arch/arm/crypto/aes-cipher-glue.c                  |   69 -
 arch/arm/crypto/aes-cipher.h                       |   13 -
 arch/arm/crypto/aes-neonbs-glue.c                  |   29 +-
 arch/arm/crypto/ghash-ce-glue.c                    |   14 +-
 arch/arm/crypto/nhpoly1305-neon-glue.c             |   80 -
 arch/arm64/crypto/Kconfig                          |   39 +-
 arch/arm64/crypto/Makefile                         |    9 -
 arch/arm64/crypto/aes-ce-ccm-glue.c                |    2 -
 arch/arm64/crypto/aes-ce-glue.c                    |  178 --
 arch/arm64/crypto/aes-ce-setkey.h                  |    6 -
 arch/arm64/crypto/aes-cipher-glue.c                |   63 -
 arch/arm64/crypto/aes-glue.c                       |    2 -
 arch/arm64/crypto/ghash-ce-glue.c                  |   27 +-
 arch/arm64/crypto/nhpoly1305-neon-glue.c           |   79 -
 arch/m68k/configs/amiga_defconfig                  |    1 -
 arch/m68k/configs/apollo_defconfig                 |    1 -
 arch/m68k/configs/atari_defconfig                  |    1 -
 arch/m68k/configs/bvme6000_defconfig               |    1 -
 arch/m68k/configs/hp300_defconfig                  |    1 -
 arch/m68k/configs/mac_defconfig                    |    1 -
 arch/m68k/configs/multi_defconfig                  |    1 -
 arch/m68k/configs/mvme147_defconfig                |    1 -
 arch/m68k/configs/mvme16x_defconfig                |    1 -
 arch/m68k/configs/q40_defconfig                    |    1 -
 arch/m68k/configs/sun3_defconfig                   |    1 -
 arch/m68k/configs/sun3x_defconfig                  |    1 -
 arch/powerpc/crypto/Kconfig                        |    2 +-
 arch/powerpc/crypto/Makefile                       |    9 +-
 arch/powerpc/crypto/aes-gcm-p10-glue.c             |    4 +-
 arch/powerpc/crypto/aes-spe-glue.c                 |   88 +-
 arch/powerpc/crypto/aes.c                          |  134 --
 arch/powerpc/crypto/aes_cbc.c                      |    4 +-
 arch/powerpc/crypto/aes_ctr.c                      |    2 +-
 arch/powerpc/crypto/aes_xts.c                      |    6 +-
 arch/powerpc/crypto/aesp8-ppc.h                    |   22 -
 arch/powerpc/crypto/vmx.c                          |   10 +-
 arch/riscv/crypto/Kconfig                          |    2 -
 arch/riscv/crypto/aes-macros.S                     |   12 +-
 arch/riscv/crypto/aes-riscv64-glue.c               |   81 +-
 arch/riscv/crypto/aes-riscv64-zvkned.S             |   27 -
 arch/s390/configs/debug_defconfig                  |    2 +-
 arch/s390/configs/defconfig                        |    2 +-
 arch/s390/crypto/Kconfig                           |    2 -
 arch/s390/crypto/aes_s390.c                        |  113 --
 arch/sparc/crypto/Kconfig                          |    2 +-
 arch/sparc/crypto/Makefile                         |    2 +-
 arch/sparc/crypto/aes_glue.c                       |  140 +-
 arch/x86/crypto/Kconfig                            |   22 -
 arch/x86/crypto/Makefile                           |    5 -
 arch/x86/crypto/aes-gcm-aesni-x86_64.S             |   33 +-
 arch/x86/crypto/aes-gcm-vaes-avx2.S                |   21 +-
 arch/x86/crypto/aes-gcm-vaes-avx512.S              |   25 +-
 arch/x86/crypto/aesni-intel_asm.S                  |   25 -
 arch/x86/crypto/aesni-intel_glue.c                 |  119 +-
 arch/x86/crypto/nhpoly1305-avx2-glue.c             |   81 -
 arch/x86/crypto/nhpoly1305-sse2-glue.c             |   80 -
 crypto/Kconfig                                     |   31 +-
 crypto/Makefile                                    |    5 +-
 crypto/adiantum.c                                  |  442 ++---
 crypto/aegis.h                                     |    2 +-
 crypto/aes.c                                       |   66 +
 crypto/aes_generic.c                               | 1320 --------------
 crypto/aes_ti.c                                    |   83 -
 crypto/crypto_user.c                               |    2 +-
 crypto/df_sp80090a.c                               |   30 +-
 crypto/drbg.c                                      |   12 +-
 crypto/nhpoly1305.c                                |  255 ---
 crypto/testmgr.c                                   |   49 +-
 crypto/testmgr.h                                   | 1372 --------------
 drivers/char/tpm/tpm2-sessions.c                   |   10 +-
 drivers/crypto/amcc/crypto4xx_alg.c                |   10 +-
 drivers/crypto/ccp/ccp-crypto-aes-cmac.c           |    4 +-
 drivers/crypto/chelsio/chcr_algo.c                 |   10 +-
 drivers/crypto/inside-secure/safexcel_cipher.c     |   12 +-
 drivers/crypto/inside-secure/safexcel_hash.c       |   14 +-
 drivers/crypto/omap-aes-gcm.c                      |    6 +-
 drivers/crypto/omap-aes.h                          |    2 +-
 drivers/crypto/starfive/jh7110-aes.c               |   10 +-
 drivers/crypto/xilinx/xilinx-trng.c                |    8 +-
 .../chelsio/inline_crypto/ch_ipsec/chcr_ipsec.c    |    4 +-
 .../chelsio/inline_crypto/ch_ktls/chcr_ktls.c      |    8 +-
 .../chelsio/inline_crypto/chtls/chtls_hw.c         |    4 +-
 drivers/net/phy/mscc/mscc_macsec.c                 |    8 +-
 drivers/staging/rtl8723bs/core/rtw_security.c      |   20 +-
 include/crypto/aes.h                               |  278 ++-
 include/crypto/df_sp80090a.h                       |    2 +-
 include/crypto/gcm.h                               |    2 +-
 include/crypto/mldsa.h                             |   62 +
 include/crypto/nh.h                                |   52 +
 include/crypto/nhpoly1305.h                        |   74 -
 lib/crypto/Kconfig                                 |   32 +
 lib/crypto/Makefile                                |   59 +-
 lib/crypto/aes.c                                   |  473 +++--
 lib/crypto/aescfb.c                                |   30 +-
 lib/crypto/aesgcm.c                                |   12 +-
 .../crypto => lib/crypto/arm}/aes-cipher-core.S    |    4 +-
 lib/crypto/arm/aes.h                               |   56 +
 {arch/arm/crypto => lib/crypto/arm}/nh-neon-core.S |    0
 lib/crypto/arm/nh.h                                |   33 +
 .../crypto => lib/crypto/arm64}/aes-ce-core.S      |    0
 .../crypto => lib/crypto/arm64}/aes-cipher-core.S  |    4 +-
 lib/crypto/arm64/aes.h                             |  164 ++
 .../crypto => lib/crypto/arm64}/nh-neon-core.S     |    3 +-
 lib/crypto/arm64/nh.h                              |   34 +
 lib/crypto/fips-mldsa.h                            |  458 +++++
 lib/crypto/md5.c                                   |    2 +-
 lib/crypto/mldsa.c                                 |  682 +++++++
 lib/crypto/nh.c                                    |   82 +
 lib/crypto/powerpc/.gitignore                      |    2 +
 .../crypto => lib/crypto/powerpc}/aes-spe-core.S   |    0
 .../crypto => lib/crypto/powerpc}/aes-spe-keys.S   |    0
 .../crypto => lib/crypto/powerpc}/aes-spe-modes.S  |    0
 .../crypto => lib/crypto/powerpc}/aes-spe-regs.h   |    0
 .../crypto => lib/crypto/powerpc}/aes-tab-4k.S     |    0
 lib/crypto/powerpc/aes.h                           |  238 +++
 .../crypto => lib/crypto/powerpc}/aesp8-ppc.pl     |    1 +
 lib/crypto/riscv/aes-riscv64-zvkned.S              |   84 +
 lib/crypto/riscv/aes.h                             |   63 +
 lib/crypto/s390/aes.h                              |  106 ++
 lib/crypto/sparc/aes.h                             |  149 ++
 {arch/sparc/crypto => lib/crypto/sparc}/aes_asm.S  |    0
 lib/crypto/tests/Kconfig                           |   17 +
 lib/crypto/tests/Makefile                          |    2 +
 lib/crypto/tests/mldsa-testvecs.h                  | 1887 ++++++++++++++++++++
 lib/crypto/tests/mldsa_kunit.c                     |  438 +++++
 lib/crypto/tests/nh-testvecs.h                     |  298 ++++
 lib/crypto/tests/nh_kunit.c                        |   43 +
 lib/crypto/x86/aes-aesni.S                         |  261 +++
 lib/crypto/x86/aes.h                               |   85 +
 .../nh-avx2-x86_64.S => lib/crypto/x86/nh-avx2.S   |    3 +-
 .../nh-sse2-x86_64.S => lib/crypto/x86/nh-sse2.S   |    3 +-
 lib/crypto/x86/nh.h                                |   45 +
 net/bluetooth/smp.c                                |    8 +-
 scripts/crypto/gen-hash-testvecs.py                |   40 +
 141 files changed, 6659 insertions(+), 5255 deletions(-)
 delete mode 100644 arch/arm/crypto/aes-cipher-glue.c
 delete mode 100644 arch/arm/crypto/aes-cipher.h
 delete mode 100644 arch/arm/crypto/nhpoly1305-neon-glue.c
 delete mode 100644 arch/arm64/crypto/aes-ce-glue.c
 delete mode 100644 arch/arm64/crypto/aes-ce-setkey.h
 delete mode 100644 arch/arm64/crypto/aes-cipher-glue.c
 delete mode 100644 arch/arm64/crypto/nhpoly1305-neon-glue.c
 delete mode 100644 arch/powerpc/crypto/aes.c
 delete mode 100644 arch/x86/crypto/nhpoly1305-avx2-glue.c
 delete mode 100644 arch/x86/crypto/nhpoly1305-sse2-glue.c
 create mode 100644 crypto/aes.c
 delete mode 100644 crypto/aes_generic.c
 delete mode 100644 crypto/aes_ti.c
 delete mode 100644 crypto/nhpoly1305.c
 create mode 100644 include/crypto/mldsa.h
 create mode 100644 include/crypto/nh.h
 delete mode 100644 include/crypto/nhpoly1305.h
 rename {arch/arm/crypto => lib/crypto/arm}/aes-cipher-core.S (97%)
 create mode 100644 lib/crypto/arm/aes.h
 rename {arch/arm/crypto => lib/crypto/arm}/nh-neon-core.S (100%)
 create mode 100644 lib/crypto/arm/nh.h
 rename {arch/arm64/crypto => lib/crypto/arm64}/aes-ce-core.S (100%)
 rename {arch/arm64/crypto => lib/crypto/arm64}/aes-cipher-core.S (96%)
 create mode 100644 lib/crypto/arm64/aes.h
 rename {arch/arm64/crypto => lib/crypto/arm64}/nh-neon-core.S (97%)
 create mode 100644 lib/crypto/arm64/nh.h
 create mode 100644 lib/crypto/fips-mldsa.h
 create mode 100644 lib/crypto/mldsa.c
 create mode 100644 lib/crypto/nh.c
 create mode 100644 lib/crypto/powerpc/.gitignore
 rename {arch/powerpc/crypto => lib/crypto/powerpc}/aes-spe-core.S (100%)
 rename {arch/powerpc/crypto => lib/crypto/powerpc}/aes-spe-keys.S (100%)
 rename {arch/powerpc/crypto => lib/crypto/powerpc}/aes-spe-modes.S (100%)
 rename {arch/powerpc/crypto => lib/crypto/powerpc}/aes-spe-regs.h (100%)
 rename {arch/powerpc/crypto => lib/crypto/powerpc}/aes-tab-4k.S (100%)
 create mode 100644 lib/crypto/powerpc/aes.h
 rename {arch/powerpc/crypto => lib/crypto/powerpc}/aesp8-ppc.pl (99%)
 create mode 100644 lib/crypto/riscv/aes-riscv64-zvkned.S
 create mode 100644 lib/crypto/riscv/aes.h
 create mode 100644 lib/crypto/s390/aes.h
 create mode 100644 lib/crypto/sparc/aes.h
 rename {arch/sparc/crypto => lib/crypto/sparc}/aes_asm.S (100%)
 create mode 100644 lib/crypto/tests/mldsa-testvecs.h
 create mode 100644 lib/crypto/tests/mldsa_kunit.c
 create mode 100644 lib/crypto/tests/nh-testvecs.h
 create mode 100644 lib/crypto/tests/nh_kunit.c
 create mode 100644 lib/crypto/x86/aes-aesni.S
 create mode 100644 lib/crypto/x86/aes.h
 rename arch/x86/crypto/nh-avx2-x86_64.S => lib/crypto/x86/nh-avx2.S (98%)
 rename arch/x86/crypto/nh-sse2-x86_64.S => lib/crypto/x86/nh-sse2.S (97%)
 create mode 100644 lib/crypto/x86/nh.h

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [GIT PULL] Crypto library updates for 7.0
  2026-02-09  3:42 [GIT PULL] Crypto library updates for 7.0 Eric Biggers
@ 2026-02-10 18:10 ` pr-tracker-bot
  0 siblings, 0 replies; 2+ messages in thread
From: pr-tracker-bot @ 2026-02-10 18:10 UTC (permalink / raw)
  To: Eric Biggers
  Cc: Linus Torvalds, linux-crypto, linux-kernel, Ard Biesheuvel,
	Jason A. Donenfeld, Herbert Xu, David Howells, Holger Dengler,
	Rusydi H. Makarim

The pull request you sent on Sun, 8 Feb 2026 19:42:57 -0800:

> https://git.kernel.org/pub/scm/linux/kernel/git/ebiggers/linux.git tags/libcrypto-for-linus

has been merged into torvalds/linux.git:
https://git.kernel.org/torvalds/c/13d83ea9d81ddcb08b46377dcc9de6e5df1248d1

Thank you!

-- 
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/prtracker.html

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2026-02-10 18:10 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-02-09  3:42 [GIT PULL] Crypto library updates for 7.0 Eric Biggers
2026-02-10 18:10 ` pr-tracker-bot

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox