On Wed, Apr 22, 2020 at 05:18:53PM -0600, Jason A. Donenfeld wrote: > The initial Zinc patchset, after some mailing list discussion, contained > code to ensure that kernel_fpu_enable would not be kept on for more than > a 4k chunk, since it disables preemption. The choice of 4k isn't totally > scientific, but it's not a bad guess either, and it's what's used in > both the x86 poly1305, blake2s, and nhpoly1305 code already (in the form > of PAGE_SIZE, which this commit corrects to be explicitly 4k for the > former two). > > Ard did some back of the envelope calculations and found that > at 5 cycles/byte (overestimate) on a 1ghz processor (pretty slow), 4k > means we have a maximum preemption disabling of 20us, which Sebastian > confirmed was probably a good limit. > > Unfortunately the chunking appears to have been left out of the final > patchset that added the glue code. So, this commit adds it back in. > > Fixes: 84e03fa39fbe ("crypto: x86/chacha - expose SIMD ChaCha routine as library function") > Fixes: b3aad5bad26a ("crypto: arm64/chacha - expose arm64 ChaCha routine as library function") > Fixes: a44a3430d71b ("crypto: arm/chacha - expose ARM ChaCha routine as library function") > Fixes: d7d7b8535662 ("crypto: x86/poly1305 - wire up faster implementations for kernel") > Fixes: f569ca164751 ("crypto: arm64/poly1305 - incorporate OpenSSL/CRYPTOGAMS NEON implementation") > Fixes: a6b803b3ddc7 ("crypto: arm/poly1305 - incorporate OpenSSL/CRYPTOGAMS NEON implementation") > Fixes: ed0356eda153 ("crypto: blake2s - x86_64 SIMD implementation") > Cc: Eric Biggers <ebiggers@xxxxxxxxxx> > Cc: Ard Biesheuvel <ardb@xxxxxxxxxx> > Cc: Sebastian Andrzej Siewior <bigeasy@xxxxxxxxxxxxx> > Cc: stable@xxxxxxxxxxxxxxx > Signed-off-by: Jason A. Donenfeld <Jason@xxxxxxxxx> > --- > Changes v2->v3: > - [Eric] Split nhpoly1305 changes into separate commit, since it's not > related to the library interface. > > Changes v1->v2: > - [Ard] Use explicit 4k chunks instead of PAGE_SIZE. > - [Eric] Prefer do-while over for (;;). > > arch/arm/crypto/chacha-glue.c | 14 +++++++++++--- > arch/arm/crypto/poly1305-glue.c | 15 +++++++++++---- > arch/arm64/crypto/chacha-neon-glue.c | 14 +++++++++++--- > arch/arm64/crypto/poly1305-glue.c | 15 +++++++++++---- > arch/x86/crypto/blake2s-glue.c | 10 ++++------ > arch/x86/crypto/chacha_glue.c | 14 +++++++++++--- > arch/x86/crypto/poly1305_glue.c | 13 ++++++------- > 7 files changed, 65 insertions(+), 30 deletions(-) All applied. Thanks. -- Email: Herbert Xu <herbert@xxxxxxxxxxxxxxxxxxx> Home Page: http://gondor.apana.org.au/~herbert/ PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt