diff options
| author | Aaron Watry <awatry@gmail.com> | 2014-09-16 22:34:45 +0000 |
|---|---|---|
| committer | Aaron Watry <awatry@gmail.com> | 2014-09-16 22:34:45 +0000 |
| commit | 025d79ad6cbb346bb11637f5860d14fc7c347387 (patch) | |
| tree | ae147cf96a86a05cc70ef5c08d3043c7fa525cfd /libclc/generic/lib/atomic | |
| parent | 7cfa12c2a5a1c2ba8d478604420b0167f5fd0246 (diff) | |
| download | bcm5719-llvm-025d79ad6cbb346bb11637f5860d14fc7c347387.tar.gz bcm5719-llvm-025d79ad6cbb346bb11637f5860d14fc7c347387.zip | |
atomic: Implement generic atom[ic]_xchg
Signed-off-by: Aaron Watry <awatry@gmail.com>
Reviewed-by: Tom Stellard <thomas.stellard@amd.com>
llvm-svn: 217917
Diffstat (limited to 'libclc/generic/lib/atomic')
| -rw-r--r-- | libclc/generic/lib/atomic/atomic_impl.ll | 12 | ||||
| -rw-r--r-- | libclc/generic/lib/atomic/atomic_xchg.cl | 9 |
2 files changed, 21 insertions, 0 deletions
diff --git a/libclc/generic/lib/atomic/atomic_impl.ll b/libclc/generic/lib/atomic/atomic_impl.ll index 792762b2172..b5495cc3788 100644 --- a/libclc/generic/lib/atomic/atomic_impl.ll +++ b/libclc/generic/lib/atomic/atomic_impl.ll @@ -94,6 +94,18 @@ entry: ret i32 %0 } +define i32 @__clc_atomic_xchg_addr1(i32 addrspace(1)* nocapture %ptr, i32 %value) nounwind alwaysinline { +entry: + %0 = atomicrmw volatile xchg i32 addrspace(1)* %ptr, i32 %value seq_cst + ret i32 %0 +} + +define i32 @__clc_atomic_xchg_addr3(i32 addrspace(3)* nocapture %ptr, i32 %value) nounwind alwaysinline { +entry: + %0 = atomicrmw volatile xchg i32 addrspace(3)* %ptr, i32 %value seq_cst + ret i32 %0 +} + define i32 @__clc_atomic_xor_addr1(i32 addrspace(1)* nocapture %ptr, i32 %value) nounwind alwaysinline { entry: %0 = atomicrmw volatile xor i32 addrspace(1)* %ptr, i32 %value seq_cst diff --git a/libclc/generic/lib/atomic/atomic_xchg.cl b/libclc/generic/lib/atomic/atomic_xchg.cl new file mode 100644 index 00000000000..9aee5950141 --- /dev/null +++ b/libclc/generic/lib/atomic/atomic_xchg.cl @@ -0,0 +1,9 @@ +#include <clc/clc.h> + +_CLC_OVERLOAD _CLC_DEF float atomic_xchg(volatile global float *p, float val) { + return as_float(atomic_xchg((volatile global int *)p, as_int(val))); +} + +_CLC_OVERLOAD _CLC_DEF float atomic_xchg(volatile local float *p, float val) { + return as_float(atomic_xchg((volatile local int *)p, as_int(val))); +} |

