Browse Source

Merge pull request #2301 from jbrianceau/arm-atomic-kuser-helpers-fix-v2

[arm/gcc] Don't rely on KUSER_HELPERS feature for atomics
Feng Xiao 9 years ago
parent
commit
7bd11fcb59
1 changed files with 4 additions and 0 deletions
  1. 4 0
      src/google/protobuf/stubs/atomicops.h

+ 4 - 0
src/google/protobuf/stubs/atomicops.h

@@ -203,7 +203,11 @@ Atomic64 Release_Load(volatile const Atomic64* ptr);
 #if defined(GOOGLE_PROTOBUF_ARCH_IA32) || defined(GOOGLE_PROTOBUF_ARCH_X64)
 #include <google/protobuf/stubs/atomicops_internals_x86_gcc.h>
 #elif defined(GOOGLE_PROTOBUF_ARCH_ARM) && defined(__linux__)
+#if (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) || (__GNUC__ > 4))
+#include <google/protobuf/stubs/atomicops_internals_generic_gcc.h>
+#else
 #include <google/protobuf/stubs/atomicops_internals_arm_gcc.h>
+#endif
 #elif defined(GOOGLE_PROTOBUF_ARCH_AARCH64)
 #include <google/protobuf/stubs/atomicops_internals_arm64_gcc.h>
 #elif defined(GOOGLE_PROTOBUF_ARCH_ARM_QNX)