summaryrefslogtreecommitdiff
path: root/net/lapb/lapb_subr.c
diff options
context:
space:
mode:
authorEric Biggers <ebiggers@google.com>2019-02-23 09:54:07 +0300
committerHerbert Xu <herbert@gondor.apana.org.au>2019-02-28 09:37:48 +0300
commit4b6d196c9cec548a6b1cf5bb07b4a8b8d375829d (patch)
treee6b9e6144f7933b6d5a2f6796ec86e49eabd00ea /net/lapb/lapb_subr.c
parentc64316502008064c158fa40cc250665e461b0f2a (diff)
downloadlinux-4b6d196c9cec548a6b1cf5bb07b4a8b8d375829d.tar.xz
crypto: arm64/chacha - fix chacha_4block_xor_neon() for big endian
The change to encrypt a fifth ChaCha block using scalar instructions caused the chacha20-neon, xchacha20-neon, and xchacha12-neon self-tests to start failing on big endian arm64 kernels. The bug is that the keystream block produced in 32-bit scalar registers is directly XOR'd with the data words, which are loaded and stored in native endianness. Thus in big endian mode the data bytes end up XOR'd with the wrong bytes. Fix it by byte-swapping the keystream words in big endian mode. Fixes: 2fe55987b262 ("crypto: arm64/chacha - use combined SIMD/ALU routine for more speed") Signed-off-by: Eric Biggers <ebiggers@google.com> Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'net/lapb/lapb_subr.c')
0 files changed, 0 insertions, 0 deletions