blob: 5bfe07b94bfd2110cb9b9a7f1fc0a8ffc2e9cdf7 [file] [log] [blame]
Aaron Watry50a7bcb2013-09-05 16:04:01 +00001#include <clc/clc.h>
2
Aaron Watryea32a572014-09-16 22:34:53 +00003#define ATOMIC_FUNC_DEFINE(RET_SIGN, ARG_SIGN, TYPE, CL_FUNCTION, CLC_FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE) \
4_CLC_OVERLOAD _CLC_DEF RET_SIGN TYPE CL_FUNCTION (volatile CL_ADDRSPACE RET_SIGN TYPE *p, RET_SIGN TYPE val) { \
5 return (RET_SIGN TYPE)__clc_##CLC_FUNCTION##_addr##LLVM_ADDRSPACE((volatile CL_ADDRSPACE ARG_SIGN TYPE*)p, (ARG_SIGN TYPE)val); \
Aaron Watry50a7bcb2013-09-05 16:04:01 +00006}
7
Aaron Watryea32a572014-09-16 22:34:53 +00008/* For atomic functions that don't need different bitcode dependending on argument signedness */
Aaron Watry50a7bcb2013-09-05 16:04:01 +00009#define ATOMIC_FUNC_SIGN(TYPE, FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE) \
10 _CLC_DECL signed TYPE __clc_##FUNCTION##_addr##LLVM_ADDRSPACE(volatile CL_ADDRSPACE signed TYPE*, signed TYPE); \
Aaron Watryea32a572014-09-16 22:34:53 +000011 ATOMIC_FUNC_DEFINE(signed, signed, TYPE, FUNCTION, FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE) \
12 ATOMIC_FUNC_DEFINE(unsigned, signed, TYPE, FUNCTION, FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE)
Aaron Watry50a7bcb2013-09-05 16:04:01 +000013
14#define ATOMIC_FUNC_ADDRSPACE(TYPE, FUNCTION) \
15 ATOMIC_FUNC_SIGN(TYPE, FUNCTION, global, 1) \
16 ATOMIC_FUNC_SIGN(TYPE, FUNCTION, local, 3)
17
18#define ATOMIC_FUNC(FUNCTION) \
19 ATOMIC_FUNC_ADDRSPACE(int, FUNCTION)
20
Aaron Watryf4133b82014-09-16 22:34:59 +000021#define ATOMIC_FUNC_DEFINE_3_ARG(RET_SIGN, ARG_SIGN, TYPE, CL_FUNCTION, CLC_FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE) \
22_CLC_OVERLOAD _CLC_DEF RET_SIGN TYPE CL_FUNCTION (volatile CL_ADDRSPACE RET_SIGN TYPE *p, RET_SIGN TYPE cmp, RET_SIGN TYPE val) { \
23 return (RET_SIGN TYPE)__clc_##CLC_FUNCTION##_addr##LLVM_ADDRSPACE((volatile CL_ADDRSPACE ARG_SIGN TYPE*)p, (ARG_SIGN TYPE)cmp, (ARG_SIGN TYPE)val); \
24}
25
26/* For atomic functions that don't need different bitcode dependending on argument signedness */
27#define ATOMIC_FUNC_SIGN_3_ARG(TYPE, FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE) \
28 _CLC_DECL signed TYPE __clc_##FUNCTION##_addr##LLVM_ADDRSPACE(volatile CL_ADDRSPACE signed TYPE*, signed TYPE, signed TYPE); \
29 ATOMIC_FUNC_DEFINE_3_ARG(signed, signed, TYPE, FUNCTION, FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE) \
30 ATOMIC_FUNC_DEFINE_3_ARG(unsigned, signed, TYPE, FUNCTION, FUNCTION, CL_ADDRSPACE, LLVM_ADDRSPACE)
31
32#define ATOMIC_FUNC_ADDRSPACE_3_ARG(TYPE, FUNCTION) \
33 ATOMIC_FUNC_SIGN_3_ARG(TYPE, FUNCTION, global, 1) \
34 ATOMIC_FUNC_SIGN_3_ARG(TYPE, FUNCTION, local, 3)
35
36#define ATOMIC_FUNC_3_ARG(FUNCTION) \
37 ATOMIC_FUNC_ADDRSPACE_3_ARG(int, FUNCTION)
38
Aaron Watry50a7bcb2013-09-05 16:04:01 +000039ATOMIC_FUNC(atomic_add)
Aaron Watry348db3c2014-09-16 22:34:51 +000040ATOMIC_FUNC(atomic_and)
Aaron Watry5ab82be2014-09-16 22:34:52 +000041ATOMIC_FUNC(atomic_or)
Aaron Watry283e3fa2013-09-06 20:20:21 +000042ATOMIC_FUNC(atomic_sub)
Aaron Watrye210cae2014-09-16 22:34:58 +000043ATOMIC_FUNC(atomic_xchg)
Aaron Watrydd754f42014-09-16 22:34:55 +000044ATOMIC_FUNC(atomic_xor)
Aaron Watryf4133b82014-09-16 22:34:59 +000045ATOMIC_FUNC_3_ARG(atomic_cmpxchg)
Aaron Watryea32a572014-09-16 22:34:53 +000046
47_CLC_DECL signed int __clc_atomic_max_addr1(volatile global signed int*, signed int);
48_CLC_DECL signed int __clc_atomic_max_addr3(volatile local signed int*, signed int);
49_CLC_DECL uint __clc_atomic_umax_addr1(volatile global uint*, uint);
50_CLC_DECL uint __clc_atomic_umax_addr3(volatile local uint*, uint);
51
52ATOMIC_FUNC_DEFINE(signed, signed, int, atomic_max, atomic_max, global, 1)
53ATOMIC_FUNC_DEFINE(signed, signed, int, atomic_max, atomic_max, local, 3)
54ATOMIC_FUNC_DEFINE(unsigned, unsigned, int, atomic_max, atomic_umax, global, 1)
55ATOMIC_FUNC_DEFINE(unsigned, unsigned, int, atomic_max, atomic_umax, local, 3)
Aaron Watry0545fa32014-09-16 22:34:56 +000056
57_CLC_DECL signed int __clc_atomic_min_addr1(volatile global signed int*, signed int);
58_CLC_DECL signed int __clc_atomic_min_addr3(volatile local signed int*, signed int);
59_CLC_DECL uint __clc_atomic_umin_addr1(volatile global uint*, uint);
60_CLC_DECL uint __clc_atomic_umin_addr3(volatile local uint*, uint);
61
62ATOMIC_FUNC_DEFINE(signed, signed, int, atomic_min, atomic_min, global, 1)
63ATOMIC_FUNC_DEFINE(signed, signed, int, atomic_min, atomic_min, local, 3)
64ATOMIC_FUNC_DEFINE(unsigned, unsigned, int, atomic_min, atomic_umin, global, 1)
65ATOMIC_FUNC_DEFINE(unsigned, unsigned, int, atomic_min, atomic_umin, local, 3)