summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/ec/ec_lib.c
diff options
context:
space:
mode:
authorjsing <>2023-07-02 13:11:23 +0000
committerjsing <>2023-07-02 13:11:23 +0000
commitb14b96c4bd58c5a55f44cf17aae27e8ccf5c4635 (patch)
tree085e6a450eaeaa483d6aff7b5ab2534db11035e3 /src/lib/libcrypto/ec/ec_lib.c
parent51a8a8a427e370e0d2e3f55eb3f33ca0289bcaaf (diff)
downloadopenbsd-b14b96c4bd58c5a55f44cf17aae27e8ccf5c4635.tar.gz
openbsd-b14b96c4bd58c5a55f44cf17aae27e8ccf5c4635.tar.bz2
openbsd-b14b96c4bd58c5a55f44cf17aae27e8ccf5c4635.zip
Replace bn_sqr_words() with bn_sqr_add_words().
In order to implement efficient squaring, we compute the sum of products (omitting the squares), double the sum of products and then finally compute and add in the squares. However, for reasons unknown the final calculation was implemented as two separate steps. Replace bn_sqr_words() with bn_sqr_add_words() such that we do the computation in one step, avoid the need for temporary BN and remove needless overhead. This gives us a performance gain across most architectures (even with the loss of sse2 on i386, for example). ok tb@
Diffstat (limited to 'src/lib/libcrypto/ec/ec_lib.c')
0 files changed, 0 insertions, 0 deletions