openssl/crypto/aes
Ard Biesheuvel 26217510d2 aes/asm/aesv8-armx.pl: avoid 32-bit lane assignment in CTR mode
ARM Cortex-A57 and Cortex-A72 cores running in 32-bit mode are affected
by silicon errata #1742098 [0] and #1655431 [1], respectively, where the
second instruction of a AES instruction pair may execute twice if an
interrupt is taken right after the first instruction consumes an input
register of which a single 32-bit lane has been updated the last time it
was modified.

This is not such a rare occurrence as it may seem: in counter mode, only
the least significant 32-bit word is incremented in the absence of a
carry, which makes our counter mode implementation susceptible to these
errata.

So let's shuffle the counter assignments around a bit so that the most
recent updates when the AES instruction pair executes are 128-bit wide.

[0] ARM-EPM-049219 v23 Cortex-A57 MPCore Software Developers Errata Notice
[1] ARM-EPM-012079 v11.0 Cortex-A72 MPCore Software Developers Errata Notice

Signed-off-by: Ard Biesheuvel <ard.biesheuvel@arm.com>

Reviewed-by: Paul Dale <paul.dale@oracle.com>
Reviewed-by: Tomas Mraz <tmraz@fedoraproject.org>
(Merged from https://github.com/openssl/openssl/pull/13504)
2020-11-30 12:14:54 +01:00
..
asm aes/asm/aesv8-armx.pl: avoid 32-bit lane assignment in CTR mode 2020-11-30 12:14:54 +01:00
aes_cbc.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_cfb.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_core.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_ecb.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_ige.c Avoid undefined behavior with unaligned accesses 2020-05-27 20:11:20 +02:00
aes_local.h Fix header file include guard names 2019-09-28 20:26:36 +02:00
aes_misc.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_ofb.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_wrap.c Update copyright year 2020-04-23 13:55:52 +01:00
aes_x86core.c Reorganize local header files 2019-09-28 20:26:35 +02:00
build.info Use build.info, not ifdef for crypto modules 2020-04-16 13:52:22 +02:00