diff options
| author | Owen Anderson <resistor@mac.com> | 2009-06-23 18:01:04 +0000 |
|---|---|---|
| committer | Owen Anderson <resistor@mac.com> | 2009-06-23 18:01:04 +0000 |
| commit | 9e3df5b67f85234b85492ac0a417135c518e926a (patch) | |
| tree | 2bd390e04aebc9e5f186cf8e93ed176a3450eb2a /llvm/lib | |
| parent | 881af589335ce55b437f2d7bbb78bfbb4f616fdc (diff) | |
| download | bcm5719-llvm-9e3df5b67f85234b85492ac0a417135c518e926a.tar.gz bcm5719-llvm-9e3df5b67f85234b85492ac0a417135c518e926a.zip | |
Label the existing atomic functions as 32-bit specific, and add a 64-bit one that will be useful in
the near future.
llvm-svn: 73971
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/System/Atomic.cpp | 26 | ||||
| -rw-r--r-- | llvm/lib/VMCore/Mangler.cpp | 2 |
2 files changed, 20 insertions, 8 deletions
diff --git a/llvm/lib/System/Atomic.cpp b/llvm/lib/System/Atomic.cpp index 6e751a30d4d..65e14697ede 100644 --- a/llvm/lib/System/Atomic.cpp +++ b/llvm/lib/System/Atomic.cpp @@ -35,11 +35,11 @@ void sys::MemoryFence() { #endif } -sys::cas_flag sys::CompareAndSwap(volatile sys::cas_flag* ptr, - sys::cas_flag new_value, - sys::cas_flag old_value) { +uint32_t sys::CompareAndSwap32(volatile uint32_t* ptr, + uint32_t new_value, + uint32_t old_value) { #if LLVM_MULTITHREADED==0 - sys::cas_flag result = *ptr; + uint32_t result = *ptr; if (result == old_value) *ptr = new_value; return result; @@ -52,7 +52,7 @@ sys::cas_flag sys::CompareAndSwap(volatile sys::cas_flag* ptr, #endif } -sys::cas_flag sys::AtomicIncrement(volatile sys::cas_flag* ptr) { +uint32_t sys::AtomicIncrement32(volatile uint32_t* ptr) { #if LLVM_MULTITHREADED==0 ++(*ptr); return *ptr; @@ -65,7 +65,7 @@ sys::cas_flag sys::AtomicIncrement(volatile sys::cas_flag* ptr) { #endif } -sys::cas_flag sys::AtomicDecrement(volatile sys::cas_flag* ptr) { +uint32_t sys::AtomicDecrement32(volatile uint32_t* ptr) { #if LLVM_MULTITHREADED==0 --(*ptr); return *ptr; @@ -78,7 +78,7 @@ sys::cas_flag sys::AtomicDecrement(volatile sys::cas_flag* ptr) { #endif } -sys::cas_flag sys::AtomicAdd(volatile sys::cas_flag* ptr, sys::cas_flag val) { +uint32_t sys::AtomicAdd32(volatile uint32_t* ptr, uint32_t val) { #if LLVM_MULTITHREADED==0 *ptr += val; return *ptr; @@ -91,4 +91,16 @@ sys::cas_flag sys::AtomicAdd(volatile sys::cas_flag* ptr, sys::cas_flag val) { #endif } +uint64_t sys::AtomicAdd64(volatile uint64_t* ptr, uint64_t val) { +#if LLVM_MULTITHREADED==0 + *ptr += val; + return *ptr; +#elif defined(__GNUC__) + return __sync_add_and_fetch(ptr, val); +#elif defined(_MSC_VER) + return InterlockedAdd64(ptr, val); +#else +# error No atomic add implementation for your platform! +#endif +} diff --git a/llvm/lib/VMCore/Mangler.cpp b/llvm/lib/VMCore/Mangler.cpp index 1a68b890542..0f6f216ceb8 100644 --- a/llvm/lib/VMCore/Mangler.cpp +++ b/llvm/lib/VMCore/Mangler.cpp @@ -168,7 +168,7 @@ std::string Mangler::getValueName(const GlobalValue *GV, const char * Suffix) { static uint32_t GlobalID = 0; unsigned OldID = GlobalID; - sys::AtomicIncrement(&GlobalID); + sys::AtomicIncrement32(&GlobalID); Name = "__unnamed_" + utostr(TypeUniqueID) + "_" + utostr(OldID); } else { |

