| Index: base/atomicops.h
|
| diff --git a/base/atomicops.h b/base/atomicops.h
|
| index 6a5371c75c295e87d33e21fc16ddc89d4937e4d5..f983b455f193d2227b72c42e10caa8ba18708772 100644
|
| --- a/base/atomicops.h
|
| +++ b/base/atomicops.h
|
| @@ -144,33 +144,6 @@ Atomic64 Release_Load(volatile const Atomic64* ptr);
|
| } // namespace subtle
|
| } // namespace base
|
|
|
| -// The following x86 CPU features are used in atomicops_internals_x86_gcc.h, but
|
| -// this file is duplicated inside of Chrome: protobuf and tcmalloc rely on the
|
| -// struct being present at link time. Some parts of Chrome can currently use the
|
| -// portable interface whereas others still use GCC one. The include guards are
|
| -// the same as in atomicops_internals_x86_gcc.cc.
|
| -#if defined(__i386__) || defined(__x86_64__)
|
| -// This struct is not part of the public API of this module; clients may not
|
| -// use it. (However, it's exported via BASE_EXPORT because clients implicitly
|
| -// do use it at link time by inlining these functions.)
|
| -// Features of this x86. Values may not be correct before main() is run,
|
| -// but are set conservatively.
|
| -struct AtomicOps_x86CPUFeatureStruct {
|
| - bool has_amd_lock_mb_bug; // Processor has AMD memory-barrier bug; do lfence
|
| - // after acquire compare-and-swap.
|
| - // The following fields are unused by Chrome's base implementation but are
|
| - // still used by copies of the same code in other parts of the code base. This
|
| - // causes an ODR violation, and the other code is likely reading invalid
|
| - // memory.
|
| - // TODO(jfb) Delete these fields once the rest of the Chrome code base doesn't
|
| - // depend on them.
|
| - bool has_sse2; // Processor has SSE2.
|
| - bool has_cmpxchg16b; // Processor supports cmpxchg16b instruction.
|
| -};
|
| -BASE_EXPORT extern struct AtomicOps_x86CPUFeatureStruct
|
| - AtomicOps_Internalx86CPUFeatures;
|
| -#endif
|
| -
|
| // Try to use a portable implementation based on C++11 atomics.
|
| //
|
| // Some toolchains support C++11 language features without supporting library
|
| @@ -188,17 +161,6 @@ BASE_EXPORT extern struct AtomicOps_x86CPUFeatureStruct
|
| # include "base/atomicops_internals_x86_msvc.h"
|
| # elif defined(OS_MACOSX)
|
| # include "base/atomicops_internals_mac.h"
|
| -# elif defined(OS_NACL)
|
| -# include "base/atomicops_internals_gcc.h"
|
| -# elif defined(COMPILER_GCC) && defined(ARCH_CPU_ARMEL)
|
| -# include "base/atomicops_internals_arm_gcc.h"
|
| -# elif defined(COMPILER_GCC) && defined(ARCH_CPU_ARM64)
|
| -# include "base/atomicops_internals_arm64_gcc.h"
|
| -# elif defined(COMPILER_GCC) && defined(ARCH_CPU_X86_FAMILY)
|
| -# include "base/atomicops_internals_x86_gcc.h"
|
| -# elif (defined(COMPILER_GCC) && \
|
| - (defined(ARCH_CPU_MIPS_FAMILY) || defined(ARCH_CPU_MIPS64_FAMILY)))
|
| -# include "base/atomicops_internals_mips_gcc.h"
|
| # else
|
| # error "Atomic operations are not supported on your platform"
|
| # endif
|
|
|