QRandomGenerator: fix the timing of the closing of the Unix random fd

Let's make it happen even later: at the time of QtCore's unloading from
memory. This prevents issues with something using QRandomGenerator after
the global static destructor would have run.

Change-Id: Icaa86fc7b54d4b368c0efffd14eed56bbbb51cb6
Reviewed-by: Lars Knoll <lars.knoll@qt.io>
Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@qt.io>
This commit is contained in:
Thiago Macieira 2017-10-18 18:46:23 -07:00
parent 34c879f2e1
commit 68092ba6c0

View File

@ -152,15 +152,15 @@ class SystemRandom
{ {
static QBasicAtomicInt s_fdp1; // "file descriptor plus 1" static QBasicAtomicInt s_fdp1; // "file descriptor plus 1"
static int openDevice(); static int openDevice();
static __attribute__((destructor)) void closeDevice(); // assume GCC or a compiler able to understand GCC extensions
SystemRandom() {} SystemRandom() {}
~SystemRandom();
public: public:
enum { EfficientBufferFill = true }; enum { EfficientBufferFill = true };
static qssize_t fillBuffer(void *buffer, qssize_t count); static qssize_t fillBuffer(void *buffer, qssize_t count);
}; };
QBasicAtomicInt SystemRandom::s_fdp1 = Q_BASIC_ATOMIC_INITIALIZER(0); QBasicAtomicInt SystemRandom::s_fdp1 = Q_BASIC_ATOMIC_INITIALIZER(0);
SystemRandom::~SystemRandom() void SystemRandom::closeDevice()
{ {
int fd = s_fdp1.loadAcquire() - 1; int fd = s_fdp1.loadAcquire() - 1;
if (fd >= 0) if (fd >= 0)