Commit 8d5f1e1e authored by xfxyjwf's avatar xfxyjwf

Merge pull request #27 from edmonds/branches/fix_generic_atomicops_non_clang

Fix atomicops build failure on non-Clang
parents 5c8ab2cb 7432af82
...@@ -192,9 +192,14 @@ GOOGLE_PROTOBUF_ATOMICOPS_ERROR ...@@ -192,9 +192,14 @@ 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>
#elif defined(__clang__)
#if __has_extension(c_atomic)
#include <google/protobuf/stubs/atomicops_internals_generic_gcc.h>
#else
GOOGLE_PROTOBUF_ATOMICOPS_ERROR
#endif
#else #else
GOOGLE_PROTOBUF_ATOMICOPS_ERROR GOOGLE_PROTOBUF_ATOMICOPS_ERROR
#endif #endif
......
...@@ -33,6 +33,9 @@ ...@@ -33,6 +33,9 @@
#include <google/protobuf/stubs/common.h> #include <google/protobuf/stubs/common.h>
#define GOOGLE_PROTOBUF_PLATFORM_ERROR \
#error "Host platform was not detected as supported by protobuf"
// Processor architecture detection. For more info on what's defined, see: // Processor architecture detection. For more info on what's defined, see:
// http://msdn.microsoft.com/en-us/library/b0084kay.aspx // http://msdn.microsoft.com/en-us/library/b0084kay.aspx
// http://www.agner.org/optimize/calling_conventions.pdf // http://www.agner.org/optimize/calling_conventions.pdf
...@@ -62,17 +65,22 @@ ...@@ -62,17 +65,22 @@
#endif #endif
#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)) || \ # if (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 7)) || (__GNUC__ > 4))
(defined(__clang__) && __has_extension(c_atomic))) // We fallback to the generic Clang/GCC >= 4.7 implementation in atomicops.h
// We fallback to the generic GCC >= 4.7 implementation in atomicops.h # elif defined(__clang__)
# if !__has_extension(c_atomic)
GOOGLE_PROTOBUF_PLATFORM_ERROR
# endif
// We fallback to the generic Clang/GCC >= 4.7 implementation in atomicops.h
# endif
# if __LP64__ # if __LP64__
# define GOOGLE_PROTOBUF_ARCH_64_BIT 1 # define GOOGLE_PROTOBUF_ARCH_64_BIT 1
# else # else
# define GOOGLE_PROTOBUF_ARCH_32_BIT 1 # define GOOGLE_PROTOBUF_ARCH_32_BIT 1
# endif # endif
#else #else
#error Host architecture was not detected as supported by protobuf GOOGLE_PROTOBUF_PLATFORM_ERROR
#endif #endif
#if defined(__APPLE__) #if defined(__APPLE__)
......
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