llvm-diff shows there is no change to amdgcn--amdhsa.bc. Similar to how cl_khr_fp64 and cl_khr_fp16 implementations are put in a same file for math built-ins, this PR do the same to atom_* built-ins. The main motivation is to prevent that two files with same base name implementats different built-ins. In a follow-up PR, I'd like to relax libclc_configure_lib_source to only compare filename instead of path for overriding, since in our downstream the same category of built-ins, e.g. math, are organized in several different folders.
43 lines
1.4 KiB
Common Lisp
43 lines
1.4 KiB
Common Lisp
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include <clc/atomic/atom_add.h>
|
|
#include <clc/atomic/atom_inc.h>
|
|
#include <clc/atomic/atomic_inc.h>
|
|
|
|
#define IMPL(AS, TYPE) \
|
|
_CLC_OVERLOAD _CLC_DEF TYPE atom_inc(volatile AS TYPE *p) { \
|
|
return atomic_inc(p); \
|
|
}
|
|
|
|
#ifdef cl_khr_global_int32_base_atomics
|
|
IMPL(global, int)
|
|
IMPL(global, unsigned int)
|
|
#endif // cl_khr_global_int32_base_atomics
|
|
#ifdef cl_khr_local_int32_base_atomics
|
|
IMPL(local, int)
|
|
IMPL(local, unsigned int)
|
|
#endif // cl_khr_local_int32_base_atomics
|
|
|
|
#undef IMPL
|
|
|
|
#ifdef cl_khr_int64_base_atomics
|
|
|
|
#define IMPL(AS, TYPE) \
|
|
_CLC_OVERLOAD _CLC_DEF TYPE atom_inc(volatile AS TYPE *p) { \
|
|
return atom_add(p, (TYPE)1); \
|
|
}
|
|
|
|
IMPL(global, long)
|
|
IMPL(global, unsigned long)
|
|
IMPL(local, long)
|
|
IMPL(local, unsigned long)
|
|
#undef IMPL
|
|
|
|
#endif // cl_khr_int64_base_atomics
|