// RUN: %clang_cc1 -emit-llvm -o - -aux-triple x86_64-pc-windows-msvc \
// RUN: -fms-extensions -triple amdgcn-amd-amdhsa \
// RUN: -target-cpu gfx1030 -fcuda-is-device -x hip %s \
// RUN: | FileCheck -check-prefix=DEV %s
// RUN: %clang_cc1 -emit-llvm -o - -triple x86_64-pc-windows-msvc \
// RUN: -fms-extensions -aux-triple amdgcn-amd-amdhsa \
// RUN: -aux-target-cpu gfx1030 -x hip %s \
// RUN: | FileCheck -check-prefix=HOST %s
// RUN: %clang_cc1 -emit-llvm -o - -triple x86_64-pc-windows-msvc \
// RUN: -fms-extensions -aux-triple amdgcn-amd-amdhsa \
// RUN: -aux-target-cpu gfx1030 -x hip %s \
// RUN: | FileCheck -check-prefix=HOST-NEG %s
// RUN: %clang_cc1 -emit-llvm -o - -triple x86_64-pc-windows-msvc \
// RUN: -fms-extensions -x c++ %s \
// RUN: | FileCheck -check-prefix=CPP %s
#if __HIP__
#include "Inputs/cuda.h"
#endif
// Check local struct 'Op' uses Itanium mangling number instead of MSVC mangling
// number in device side name mangling. It is the same in device and host
// compilation.
// DEV: define amdgpu_kernel void @_Z6kernelIZN4TestIiE3runEvE2OpEvv(
// HOST-DAG: @{{.*}} = {{.*}}c"_Z6kernelIZN4TestIiE3runEvE2OpEvv\00"
// HOST-NEG-NOT: @{{.*}} = {{.*}}c"_Z6kernelIZN4TestIiE3runEvE2Op_1Evv\00"
#if __HIP__
template<typename T>
__attribute__((global)) void kernel()
{
}
#endif
// Check local struct 'Op' uses MSVC mangling number in host function name mangling.
// It is the same when compiled as HIP or C++ program.
// HOST-DAG: call void @"??$fun@UOp@?2??run@?$Test@H@@QEAAXXZ@@@YAXXZ"()
// CPP: call void @"??$fun@UOp@?2??run@?$Test@H@@QEAAXXZ@@@YAXXZ"()
template<typename T>
void fun()
{
}
template <typename T>
class Test {
public:
void run()
{
struct Op
{
};
#if __HIP__
kernel<Op><<<1, 1>>>();
#endif
fun<Op>();
}
};
int main() {
Test<int> A;
A.run();
}