diff options
author | Tom Cosgrove <tom.cosgrove@arm.com> | 2022-07-18 10:24:47 +0100 |
---|---|---|
committer | Tomas Mraz <tomas@openssl.org> | 2022-07-19 12:14:33 +0200 |
commit | 1efd8533e1ccc5c5e69795eb393a6b79b62e48e2 (patch) | |
tree | 9ecc5e350b12d67105aa43c5d93569395fc0bb87 /crypto | |
parent | 7a16f179ab0bc2c474a754c0ad7e35b40534a38e (diff) | |
download | openssl-new-1efd8533e1ccc5c5e69795eb393a6b79b62e48e2.tar.gz |
Fix aarch64 signed bit shift issue found by UBSAN
Also fix conditional branch out of range when using sanitisers.
Fixes #18813
Signed-off-by: Tom Cosgrove <tom.cosgrove@arm.com>
Change-Id: Ic543885091ed3ef2ddcbe21de0a4ac0bca1e2494
Reviewed-by: Paul Dale <pauli@openssl.org>
Reviewed-by: Matt Caswell <matt@openssl.org>
Reviewed-by: Tomas Mraz <tomas@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/18816)
Diffstat (limited to 'crypto')
-rw-r--r-- | crypto/aes/asm/bsaes-armv8.pl | 4 | ||||
-rw-r--r-- | crypto/arm_arch.h | 8 |
2 files changed, 4 insertions, 8 deletions
diff --git a/crypto/aes/asm/bsaes-armv8.pl b/crypto/aes/asm/bsaes-armv8.pl index 1d1e886f03..b3058e38fa 100644 --- a/crypto/aes/asm/bsaes-armv8.pl +++ b/crypto/aes/asm/bsaes-armv8.pl @@ -1019,13 +1019,9 @@ _bsaes_key_convert: // No output registers, usual AAPCS64 register preservation ossl_bsaes_cbc_encrypt: cmp x2, #128 -#ifdef __APPLE__ bhs .Lcbc_do_bsaes b AES_cbc_encrypt .Lcbc_do_bsaes: -#else - blo AES_cbc_encrypt -#endif // it is up to the caller to make sure we are called with enc == 0 diff --git a/crypto/arm_arch.h b/crypto/arm_arch.h index 5d8788877f..da8fb5eeb3 100644 --- a/crypto/arm_arch.h +++ b/crypto/arm_arch.h @@ -104,17 +104,17 @@ extern unsigned int OPENSSL_armv8_rsa_neonized; # define ARM_CPU_PART_N2 0xD49 # define MIDR_PARTNUM_SHIFT 4 -# define MIDR_PARTNUM_MASK (0xfff << MIDR_PARTNUM_SHIFT) +# define MIDR_PARTNUM_MASK (0xfffU << MIDR_PARTNUM_SHIFT) # define MIDR_PARTNUM(midr) \ (((midr) & MIDR_PARTNUM_MASK) >> MIDR_PARTNUM_SHIFT) # define MIDR_IMPLEMENTER_SHIFT 24 -# define MIDR_IMPLEMENTER_MASK (0xff << MIDR_IMPLEMENTER_SHIFT) +# define MIDR_IMPLEMENTER_MASK (0xffU << MIDR_IMPLEMENTER_SHIFT) # define MIDR_IMPLEMENTER(midr) \ (((midr) & MIDR_IMPLEMENTER_MASK) >> MIDR_IMPLEMENTER_SHIFT) # define MIDR_ARCHITECTURE_SHIFT 16 -# define MIDR_ARCHITECTURE_MASK (0xf << MIDR_ARCHITECTURE_SHIFT) +# define MIDR_ARCHITECTURE_MASK (0xfU << MIDR_ARCHITECTURE_SHIFT) # define MIDR_ARCHITECTURE(midr) \ (((midr) & MIDR_ARCHITECTURE_MASK) >> MIDR_ARCHITECTURE_SHIFT) @@ -125,7 +125,7 @@ extern unsigned int OPENSSL_armv8_rsa_neonized; # define MIDR_CPU_MODEL(imp, partnum) \ (((imp) << MIDR_IMPLEMENTER_SHIFT) | \ - (0xf << MIDR_ARCHITECTURE_SHIFT) | \ + (0xfU << MIDR_ARCHITECTURE_SHIFT) | \ ((partnum) << MIDR_PARTNUM_SHIFT)) # define MIDR_IS_CPU_MODEL(midr, imp, partnum) \ |