From: Hans Wennborg Date: Fri, 20 Apr 2018 07:34:59 +0000 (+0000) Subject: Revert r330376 "[sanitizer] Generalize atomic_uint8_t, atomic_uint16_t, ... into... X-Git-Tag: llvmorg-7.0.0-rc1~7847 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=2473183c15a2396a307c6f8fdc921608185a8a5a;p=platform%2Fupstream%2Fllvm.git Revert r330376 "[sanitizer] Generalize atomic_uint8_t, atomic_uint16_t, ... into a template. NFC." This broke the Windows build, see e.g. http://lab.llvm.org:8011/builders/clang-x64-ninja-win7/builds/10130 > Differential Revision: https://reviews.llvm.org/D44246 llvm-svn: 330395 --- diff --git a/compiler-rt/lib/sanitizer_common/sanitizer_atomic.h b/compiler-rt/lib/sanitizer_common/sanitizer_atomic.h index f61efe8..8f400ac 100644 --- a/compiler-rt/lib/sanitizer_common/sanitizer_atomic.h +++ b/compiler-rt/lib/sanitizer_common/sanitizer_atomic.h @@ -27,18 +27,36 @@ enum memory_order { memory_order_seq_cst = 1 << 5 }; -template -struct atomic { - typedef T Type; - volatile Type ALIGNED(sizeof(Type)) val_dont_use; +struct atomic_uint8_t { + typedef u8 Type; + volatile Type val_dont_use; +}; + +struct atomic_uint16_t { + typedef u16 Type; + volatile Type val_dont_use; +}; + +struct atomic_sint32_t { + typedef s32 Type; + volatile Type val_dont_use; }; -typedef atomic atomic_uint8_t; -typedef atomic atomic_uint16_t; -typedef atomic atomic_sint32_t; -typedef atomic atomic_uint32_t; -typedef atomic atomic_uint64_t; -typedef atomic atomic_uintptr_t; +struct atomic_uint32_t { + typedef u32 Type; + volatile Type val_dont_use; +}; + +struct atomic_uint64_t { + typedef u64 Type; + // On 32-bit platforms u64 is not necessary aligned on 8 bytes. + volatile ALIGNED(8) Type val_dont_use; +}; + +struct atomic_uintptr_t { + typedef uptr Type; + volatile Type val_dont_use; +}; } // namespace __sanitizer