OpenCloudOS-Kernel/arch
Eric Biggers 678cce4019 crypto: x86/poly1305 - fix overflow during partial reduction
The x86_64 implementation of Poly1305 produces the wrong result on some
inputs because poly1305_4block_avx2() incorrectly assumes that when
partially reducing the accumulator, the bits carried from limb 'd4' to
limb 'h0' fit in a 32-bit integer.  This is true for poly1305-generic
which processes only one block at a time.  However, it's not true for
the AVX2 implementation, which processes 4 blocks at a time and
therefore can produce intermediate limbs about 4x larger.

Fix it by making the relevant calculations use 64-bit arithmetic rather
than 32-bit.  Note that most of the carries already used 64-bit
arithmetic, but the d4 -> h0 carry was different for some reason.

To be safe I also made the same change to the corresponding SSE2 code,
though that only operates on 1 or 2 blocks at a time.  I don't think
it's really needed for poly1305_block_sse2(), but it doesn't hurt
because it's already x86_64 code.  It *might* be needed for
poly1305_2block_sse2(), but overflows aren't easy to reproduce there.

This bug was originally detected by my patches that improve testmgr to
fuzz algorithms against their generic implementation.  But also add a
test vector which reproduces it directly (in the AVX2 case).

Fixes: b1ccc8f4b6 ("crypto: poly1305 - Add a four block AVX2 variant for x86_64")
Fixes: c70f4abef0 ("crypto: poly1305 - Add a SSE2 SIMD variant for x86_64")
Cc: <stable@vger.kernel.org> # v4.3+
Cc: Martin Willi <martin@strongswan.org>
Cc: Jason A. Donenfeld <Jason@zx2c4.com>
Signed-off-by: Eric Biggers <ebiggers@google.com>
Reviewed-by: Martin Willi <martin@strongswan.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
2019-04-08 14:43:06 +08:00
..
alpha treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
arc memblock: drop memblock_alloc_*_nopanic() variants 2019-03-12 10:04:02 -07:00
arm treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
arm64 treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
c6x treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
csky treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
h8300 treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
hexagon y2038: additional syscall ABI cleanup 2019-02-27 21:45:27 +01:00
ia64 ia64: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:01 -07:00
m68k Merge branch 'akpm' (patches from Andrew) 2019-03-12 10:39:53 -07:00
microblaze treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
mips treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
nds32 treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
nios2 nios2 update for v5.1-rc1 2019-03-10 10:13:37 -07:00
openrisc treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
parisc Char/Misc driver patches for 5.1-rc1 2019-03-06 14:18:59 -08:00
powerpc treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
riscv DMA mapping updates for 5.1 2019-03-10 11:54:48 -07:00
s390 treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
sh memblock: drop memblock_alloc_*_nopanic() variants 2019-03-12 10:04:02 -07:00
sparc sparc: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
um treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
unicore32 treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
x86 crypto: x86/poly1305 - fix overflow during partial reduction 2019-04-08 14:43:06 +08:00
xtensa treewide: add checks for the return value of memblock_alloc*() 2019-03-12 10:04:02 -07:00
.gitignore
Kconfig Char/Misc driver patches for 5.1-rc1 2019-03-06 14:18:59 -08:00