Commit 5c8ab2cb authored by xfxyjwf's avatar xfxyjwf

Merge pull request #21 from edmonds/branches/clang_generic_atomics

Expose generic atomicops on Clang
parents 7b6c5d58 628a23ba
...@@ -192,7 +192,8 @@ GOOGLE_PROTOBUF_ATOMICOPS_ERROR ...@@ -192,7 +192,8 @@ GOOGLE_PROTOBUF_ATOMICOPS_ERROR
#include <google/protobuf/stubs/atomicops_internals_mips_gcc.h> #include <google/protobuf/stubs/atomicops_internals_mips_gcc.h>
#elif defined(__native_client__) #elif defined(__native_client__)
#include <google/protobuf/stubs/atomicops_internals_pnacl.h> #include <google/protobuf/stubs/atomicops_internals_pnacl.h>
#elif (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) || (__GNUC__ > 4)) #elif (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) || (__GNUC__ > 4)) || \
(defined(__clang__) && __has_extension(c_atomic))
#include <google/protobuf/stubs/atomicops_internals_generic_gcc.h> #include <google/protobuf/stubs/atomicops_internals_generic_gcc.h>
#else #else
GOOGLE_PROTOBUF_ATOMICOPS_ERROR GOOGLE_PROTOBUF_ATOMICOPS_ERROR
......
...@@ -63,7 +63,8 @@ ...@@ -63,7 +63,8 @@
#elif defined(__pnacl__) #elif defined(__pnacl__)
#define GOOGLE_PROTOBUF_ARCH_32_BIT 1 #define GOOGLE_PROTOBUF_ARCH_32_BIT 1
#elif defined(__GNUC__) && \ #elif defined(__GNUC__) && \
(((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) || (__GNUC__ > 4)) ((((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) || (__GNUC__ > 4)) || \
(defined(__clang__) && __has_extension(c_atomic)))
// We fallback to the generic GCC >= 4.7 implementation in atomicops.h // We fallback to the generic GCC >= 4.7 implementation in atomicops.h
# if __LP64__ # if __LP64__
# define GOOGLE_PROTOBUF_ARCH_64_BIT 1 # define GOOGLE_PROTOBUF_ARCH_64_BIT 1
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment