Remove the Python dependency for generating convert builtins, aligning with how other builtins are defined. In addition, our downstream target relies on this PR to override convert implementations. llvm-diff shows no changes to all bitcodes: amdgcn--amdhsa.bc, barts-r600--.bc, cayman-r600--.bc, cedar-r600--.bc, clspv64--.bc, clspv--.bc, cypress-r600--.bc, nvptx64--.bc, nvptx64--nvidiacl.bc, nvptx--.bc, nvptx--nvidiacl.bc, tahiti-amdgcn--.bc and tahiti-amdgcn-mesa-mesa3d.bc.
31 lines
1.5 KiB
PHP
31 lines
1.5 KiB
PHP
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#define __CLC_DEFINE_FUNCTION_ROUNDING_MODE_IMPL(TYPE_SRC, MODE) \
|
|
_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE __CLC_XCONCAT(__CLC_FUNCTION, \
|
|
MODE)(TYPE_SRC x) { \
|
|
return __CLC_XCONCAT(__CLC_IMPL_FUNCTION, MODE)(x); \
|
|
} \
|
|
_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE __CLC_XCONCAT(__CLC_FUNCTION_SAT, \
|
|
MODE)(TYPE_SRC x) { \
|
|
return __CLC_XCONCAT(__CLC_IMPL_FUNCTION_SAT, MODE)(x); \
|
|
}
|
|
|
|
#define __CLC_DEFINE_FUNCTION_ROUNDING_MODE(MODE) \
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE_IMPL(__CLC_S_GENTYPE_SRC, MODE) \
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE_IMPL(__CLC_U_GENTYPE_SRC, MODE)
|
|
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE()
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE(_rte)
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE(_rtz)
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE(_rtp)
|
|
__CLC_DEFINE_FUNCTION_ROUNDING_MODE(_rtn)
|
|
|
|
#undef __CLC_DEFINE_FUNCTION_ROUNDING_MODE_IMPL
|
|
#undef __CLC_DEFINE_FUNCTION_ROUNDING_MODE
|