De-pessimize QCryptographicHash::reset() in OpenSSL3 mode

Instead of going through the whole dance with provider loading,
context creation etc, just call EVP_MD_CTX_reset() to reuse the
already-setup context, if any.

This makes QCryptographicHash::reset() adhere to its noexcept
specification again (assuming EVP_MD_CTX_reset() doesn't allocate
state, and, despite its non-void return type, cannot fail on a valid
context), and should greatly improve the speed of reset(), addData(),
resultView() cycles.

Pick-to: 6.5
Change-Id: I7c35b61cbeab1ffd6dd258e8389ea614d49e2e1e
Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
Reviewed-by: Jan Grulich <jgrulich@redhat.com>
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
This commit is contained in:
Marc Mutz 2023-02-23 15:00:42 +01:00
parent 3b08cbff69
commit 189444d8c4

View File

@ -547,6 +547,12 @@ void QCryptographicHashPrivate::reset() noexcept
return; return;
} }
if (context && !initializationFailed) {
// everything already set up - just reset the context
EVP_MD_CTX_reset(context.get());
return;
}
initializationFailed = true; initializationFailed = true;
if (method == QCryptographicHash::Md4) { if (method == QCryptographicHash::Md4) {