diff options
author | Christian Beier <dontmind@freeshell.org> | 2018-11-19 09:56:18 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-11-19 09:56:18 +0100 |
commit | 2c61a095c6fd9e1654bf41dd96b74223815df83f (patch) | |
tree | 6ebb42dcf64aa816ebcc5a057549b9dd2e1bebda | |
parent | cfdbb94038e76ff002e3d68dc6b1ca0df2606ef6 (diff) | |
parent | 2411769962b1c95015bfc2d0c817a34213afbbc9 (diff) | |
download | libtdevnc-2c61a095c6fd9e1654bf41dd96b74223815df83f.tar.gz libtdevnc-2c61a095c6fd9e1654bf41dd96b74223815df83f.zip |
Merge pull request #266 from veyon/fix-tls
LibVNCServer: properly use thread-local storage
-rw-r--r-- | libvncserver/tight.c | 7 | ||||
-rw-r--r-- | libvncserver/zlib.c | 7 |
2 files changed, 8 insertions, 6 deletions
diff --git a/libvncserver/tight.c b/libvncserver/tight.c index 1081c8f..d6f4749 100644 --- a/libvncserver/tight.c +++ b/libvncserver/tight.c @@ -57,10 +57,11 @@ * that we resort to using thread local storage instead of having * per-client data. */ -#if LIBVNCSERVER_HAVE_LIBPTHREAD && LIBVNCSERVER_HAVE_TLS && !defined(TLS) && defined(__linux__) +#if defined(__GNUC__) #define TLS __thread -#endif -#ifndef TLS +#elif defined(_MSC_VER) +#define TLS __declspec(thread) +#else #define TLS #endif diff --git a/libvncserver/zlib.c b/libvncserver/zlib.c index 45a1314..6fee4df 100644 --- a/libvncserver/zlib.c +++ b/libvncserver/zlib.c @@ -45,10 +45,11 @@ * tight. N.B. ZRLE does it the traditional way with per-client storage * (and so at least ZRLE will work threaded on older systems.) */ -#if LIBVNCSERVER_HAVE_LIBPTHREAD && LIBVNCSERVER_HAVE_TLS && !defined(TLS) && defined(__linux__) +#if defined(__GNUC__) #define TLS __thread -#endif -#ifndef TLS +#elif defined(_MSC_VER) +#define TLS __declspec(thread) +#else #define TLS #endif |