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.
25 lines
896 B
C
25 lines
896 B
C
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifdef cl_khr_global_int32_base_atomics
|
|
#define __CLC_FUNCTION atom_add
|
|
#define __CLC_ADDRESS_SPACE global
|
|
#include <clc/atomic/atom_decl_int32.inc>
|
|
#endif // cl_khr_global_int32_base_atomics
|
|
|
|
#ifdef cl_khr_local_int32_base_atomics
|
|
#define __CLC_FUNCTION atom_add
|
|
#define __CLC_ADDRESS_SPACE local
|
|
#include <clc/atomic/atom_decl_int32.inc>
|
|
#endif // cl_khr_local_int32_base_atomics
|
|
|
|
#ifdef cl_khr_int64_base_atomics
|
|
#define __CLC_FUNCTION atom_add
|
|
#include <clc/atomic/atom_decl_int64.inc>
|
|
#endif // cl_khr_int64_base_atomics
|