]> granicus.if.org Git - gc/commitdiff
Workaround 'unresolved __tls_get_addr' error for Android NDK Clang
authorIvan Maidanski <ivmai@mail.ru>
Wed, 21 Oct 2015 23:01:33 +0000 (02:01 +0300)
committerIvan Maidanski <ivmai@mail.ru>
Wed, 21 Oct 2015 23:01:33 +0000 (02:01 +0300)
* include/private/thread_local_alloc.h (USE_COMPILER_TLS): Do not
define for Android Clang (any CPU arch); update comment.

include/private/thread_local_alloc.h

index 2b445bac41bc962f147ddbb6d90e3015ec7ff466..d5c5d5800d39b05267b0a3f0284a5d52c614f2ee 100644 (file)
          && !(defined(__clang__) && defined(PLATFORM_ANDROID))) \
        || (defined(PLATFORM_ANDROID) && !defined(__clang__) \
             && defined(ARM32) \
-            && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))) \
-       || (defined(PLATFORM_ANDROID) && !defined(ARM32) && !defined(MIPS) \
-            && (__clang_major__ > 3 \
-                || (__clang_major__ == 3 && __clang_minor__ >= 6)))
-          /* As of Android NDK r10e, Clang/arm with bfd linker and      */
-          /* Clang/mips cannot find __tls_get_addr.  Older NDK releases */
-          /* have same issue for arm (regardless of linker) and x86 if  */
-          /* gcc 4.6 toolchain is used for linking (checked condition   */
-          /* is based on the fact that Android NDK r10e added clang 3.6 */
-          /* dropping gcc 4.6).                                         */
+            && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)))
+          /* As of Android NDK r10e, Clang cannot find __tls_get_addr.  */
 #   define USE_COMPILER_TLS
 # elif defined(GC_DGUX386_THREADS) || defined(GC_OSF1_THREADS) \
        || defined(GC_AIX_THREADS) || defined(GC_DARWIN_THREADS) \