From a3d19b5c0dccab79d25dc9aca3f6ce731b1ac62c Mon Sep 17 00:00:00 2001 From: Timo Teras Date: Wed, 8 Jul 2009 16:19:06 +0300 Subject: [PATCH] apk: initialize openssl add all ciphers and built-in engines so we get e.g. hw acceleration of sha1 when available. --- src/apk.c | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/src/apk.c b/src/apk.c index 08846c4..6e21072 100644 --- a/src/apk.c +++ b/src/apk.c @@ -18,6 +18,8 @@ #include #include +#include + #include "apk_defines.h" #include "apk_applet.h" #include "apk_blob.h" @@ -237,6 +239,24 @@ static void merge_options(struct option *opts, struct apk_option *ao, int num) opts->name = NULL; } +static void fini_openssl(void) +{ + EVP_cleanup(); +#ifndef OPENSSL_NO_ENGINE + ENGINE_cleanup(); +#endif + CRYPTO_cleanup_all_ex_data(); +} + +static void init_openssl(void) +{ + atexit(fini_openssl); + OpenSSL_add_all_algorithms(); +#ifndef OPENSSL_NO_ENGINE + ENGINE_load_builtin_engines(); +#endif +} + int main(int argc, char **argv) { struct apk_applet *applet; @@ -274,6 +294,8 @@ int main(int argc, char **argv) } } + init_openssl(); + optindex = 0; while ((r = getopt_long(argc, argv, short_options, all_options, &optindex)) != -1) {