aboutsummaryrefslogtreecommitdiff
path: root/src/libmain/shared.cc
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2016-02-25 11:25:11 +0100
committerEelco Dolstra <eelco.dolstra@logicblox.com>2016-02-25 11:25:11 +0100
commitf1bdeac9864de8cd9994bb41da79f3a4d812dadc (patch)
tree9ea00480f826dc8d8d8248e11323266a42f9d4ae /src/libmain/shared.cc
parent9b05d5848c2fce73b75b3411e362c2bd48d53dcb (diff)
parent152b1d6bf9c89b4db9848475e3000821e159d479 (diff)
Merge branch 'master' into new-cli
Diffstat (limited to 'src/libmain/shared.cc')
-rw-r--r--src/libmain/shared.cc25
1 files changed, 21 insertions, 4 deletions
diff --git a/src/libmain/shared.cc b/src/libmain/shared.cc
index bf6bf5b71..e883967b7 100644
--- a/src/libmain/shared.cc
+++ b/src/libmain/shared.cc
@@ -6,10 +6,11 @@
#include "store-api.hh"
#include "util.hh"
-#include <iostream>
+#include <algorithm>
#include <cctype>
#include <exception>
-#include <algorithm>
+#include <iostream>
+#include <mutex>
#include <cstdlib>
#include <sys/time.h>
@@ -17,7 +18,7 @@
#include <unistd.h>
#include <signal.h>
-extern char * * environ;
+#include <openssl/crypto.h>
namespace nix {
@@ -94,7 +95,18 @@ string getArg(const string & opt,
}
-void detectStackOverflow();
+/* OpenSSL is not thread-safe by default - it will randomly crash
+ unless the user supplies a mutex locking function. So let's do
+ that. */
+static std::vector<std::mutex> opensslLocks;
+
+static void opensslLockCallback(int mode, int type, const char * file, int line)
+{
+ if (mode & CRYPTO_LOCK)
+ opensslLocks[type].lock();
+ else
+ opensslLocks[type].unlock();
+}
void initNix()
@@ -105,11 +117,16 @@ void initNix()
std::cerr.rdbuf()->pubsetbuf(buf, sizeof(buf));
#endif
+ // FIXME: do we need this? It's not thread-safe.
std::ios::sync_with_stdio(false);
if (getEnv("IN_SYSTEMD") == "1")
logType = ltSystemd;
+ /* Initialise OpenSSL locking. */
+ opensslLocks = std::vector<std::mutex>(CRYPTO_num_locks());
+ CRYPTO_set_locking_callback(opensslLockCallback);
+
settings.processEnvironment();
settings.loadConfFile();