summaryrefslogtreecommitdiffstats
path: root/Configurations
diff options
context:
space:
mode:
authorViktor Dukhovni <openssl-users@dukhovni.org>2018-02-13 22:43:15 -0500
committerViktor Dukhovni <openssl-users@dukhovni.org>2018-02-13 23:27:51 -0500
commitbabab8e7c9060cd4e8e423a783853503982a5d27 (patch)
treec693d31d5d3c1a308ffba96b02c89361b4b63457 /Configurations
parent72960279562e9af53264155a46b4a0b6a40f9590 (diff)
Avoid fragile aliasing of SHA224/384 update/final
This is purported to save a few cycles, but makes the code less obvious and more brittle, and in fact breaks on platforms where for ABI continuity reasons there is a SHA2 implementation in libc, and so EVP needs to call those to avoid conflicts. A sufficiently good optimizer could simply generate the same entry points for: foo(...) { ... } and bar(...) { return foo(...); } but, even without that, the different is negligible, with the "winner" varying from run to run (openssl speed -evp sha384): Old: type 16 bytes 64 bytes 256 bytes 1024 bytes 8192 bytes 16384 bytes sha384 28864.28k 117362.62k 266469.21k 483258.03k 635144.87k 649123.16k New: type 16 bytes 64 bytes 256 bytes 1024 bytes 8192 bytes 16384 bytes sha384 30055.18k 120725.98k 272057.26k 482847.40k 634585.09k 650308.27k Reviewed-by: Rich Salz <rsalz@openssl.org>
Diffstat (limited to 'Configurations')
0 files changed, 0 insertions, 0 deletions