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.
38 lines
1.2 KiB
Common Lisp
38 lines
1.2 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/clc_convert.h>
|
|
#include <clc/opencl/convert.h>
|
|
|
|
#define __CLC_GENTYPE_SRC __CLC_XCONCAT(__CLC_SCALAR_TYPE_SRC, __CLC_VECSIZE)
|
|
|
|
#define __CLC_FUNCTION __CLC_XCONCAT(convert_, __CLC_GENTYPE)
|
|
#define __CLC_IMPL_FUNCTION __CLC_XCONCAT(__clc_convert_, __CLC_GENTYPE)
|
|
|
|
#define __CLC_F2F
|
|
|
|
#ifdef cl_khr_fp16
|
|
#pragma OPENCL EXTENSION cl_khr_fp16 : enable
|
|
#define __CLC_SCALAR_TYPE_SRC half
|
|
#define __CLC_BODY <convert_float.inc>
|
|
#include <clc/math/gentype.inc>
|
|
#undef __CLC_SCALAR_TYPE_SRC
|
|
#endif // cl_khr_fp16
|
|
|
|
#define __CLC_SCALAR_TYPE_SRC float
|
|
#define __CLC_BODY <convert_float.inc>
|
|
#include <clc/math/gentype.inc>
|
|
#undef __CLC_SCALAR_TYPE_SRC
|
|
|
|
#ifdef cl_khr_fp64
|
|
#define __CLC_SCALAR_TYPE_SRC double
|
|
#define __CLC_BODY <convert_float.inc>
|
|
#include <clc/math/gentype.inc>
|
|
#undef __CLC_SCALAR_TYPE_SRC
|
|
#endif // cl_khr_fp64
|