tls: in AES-CBC code, do not set key for every record - do it once
authorDenys Vlasenko <vda.linux@googlemail.com>
Fri, 23 Nov 2018 17:02:44 +0000 (18:02 +0100)
committerDenys Vlasenko <vda.linux@googlemail.com>
Fri, 23 Nov 2018 17:02:44 +0000 (18:02 +0100)
commit5e4236d226309a32842a6928878fd0e1cd5937e7
treeeb41a6c5cbaaac79b22b8c200e0aabfe26ba7d15
parent83e5c627e1b2c7f34d694696d0c3d5a3ce25dc59
tls: in AES-CBC code, do not set key for every record - do it once

function                                             old     new   delta
aes_setkey                                            16     212    +196
tls_handshake                                       1941    1977     +36
aes_encrypt_1                                        382     396     +14
xwrite_encrypted                                     605     604      -1
tls_xread_record                                     659     656      -3
aes_encrypt_one_block                                 65      59      -6
aes_cbc_encrypt                                      172     121     -51
aesgcm_setkey                                         58       -     -58
aes_cbc_decrypt                                      958     881     -77
KeyExpansion                                         188       -    -188
------------------------------------------------------------------------------
(add/remove: 0/2 grow/shrink: 3/5 up/down: 246/-384)         Total: -138 bytes

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
networking/tls.c
networking/tls_aes.c
networking/tls_aes.h
networking/tls_aesgcm.c
networking/tls_aesgcm.h