openssl/crypto/aes
David Benjamin 2086edb799 Fix some CFI issues in x86_64 assembly
The add/double shortcut in ecp_nistz256-x86_64.pl left one instruction
point that did not unwind, and the "slow" path in AES_cbc_encrypt was
not annotated correctly. For the latter, add
.cfi_{remember,restore}_state support to perlasm.

Next, fill in a bunch of functions that are missing no-op .cfi_startproc
and .cfi_endproc blocks. libunwind cannot unwind those stack frames
otherwise.

Finally, work around a bug in libunwind by not encoding rflags. (rflags
isn't a callee-saved register, so there's not much need to annotate it
anyway.)

These were found as part of ABI testing work in BoringSSL.

Reviewed-by: Richard Levitte <levitte@openssl.org>
GH: #8109
(cherry picked from commit c0e8e5007b)
2019-02-17 23:41:11 +01:00
..
asm Fix some CFI issues in x86_64 assembly 2019-02-17 23:41:11 +01:00
aes_cbc.c Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_cfb.c Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_core.c Remove email addresses from source code. 2017-10-13 10:06:59 -04:00
aes_ecb.c Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_ige.c Don't call memcpy if len is zero. 2017-02-20 19:17:53 -05:00
aes_locl.h Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_misc.c Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_ofb.c Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_wrap.c Copyright consolidation 05/10 2016-05-17 15:38:09 -04:00
aes_x86core.c Remove email addresses from source code. 2017-10-13 10:06:59 -04:00
build.info Harmonize the make variables across all known platforms families 2018-02-14 17:13:53 +01:00