This adds -no-opaque-pointers to clang tests whose output will change when opaque pointers are enabled by default. This is intended to be part of the migration approach described in https://discourse.llvm.org/t/enabling-opaque-pointers-by-default/61322/9. The patch has been produced by replacing %clang_cc1 with %clang_cc1 -no-opaque-pointers for tests that fail with opaque pointers enabled. Worth noting that this doesn't cover all tests, there's a remaining ~40 tests not using %clang_cc1 that will need a followup change. Differential Revision: https://reviews.llvm.org/D123115
29 lines
1.1 KiB
Plaintext
29 lines
1.1 KiB
Plaintext
// RUN: %clang_cc1 -no-opaque-pointers -triple x86_64-unknown-gnu-linux -aux-triple amdgcn-amd-amdhsa \
|
|
// RUN: -emit-llvm -o - -x hip %s | FileCheck -check-prefixes=CHECK,LNX %s
|
|
// RUN: %clang_cc1 -no-opaque-pointers -triple x86_64-unknown-windows-msvc -aux-triple amdgcn-amd-amdhsa \
|
|
// RUN: -emit-llvm -o - -x hip %s | FileCheck -check-prefixes=CHECK,MSVC %s
|
|
|
|
#include "Inputs/cuda.h"
|
|
|
|
namespace X {
|
|
__global__ void kern1(int *x);
|
|
__device__ int var1;
|
|
}
|
|
|
|
// CHECK: @[[STR1:.*]] = {{.*}} c"_ZN1X5kern1EPi\00"
|
|
// CHECK: @[[STR2:.*]] = {{.*}} c"_ZN1X4var1E\00"
|
|
|
|
// LNX-LABEL: define {{.*}}@_Z4fun1v()
|
|
// MSVC-LABEL: define {{.*}} @"?fun1@@YAPEBDXZ"()
|
|
// CHECK: ret i8* getelementptr inbounds ({{.*}} @[[STR1]], i64 0, i64 0)
|
|
const char *fun1() {
|
|
return __builtin_get_device_side_mangled_name(X::kern1);
|
|
}
|
|
|
|
// LNX-LABEL: define {{.*}}@_Z4fun2v()
|
|
// MSVC-LABEL: define {{.*}}@"?fun2@@YAPEBDXZ"()
|
|
// CHECK: ret i8* getelementptr inbounds ({{.*}} @[[STR2]], i64 0, i64 0)
|
|
__host__ __device__ const char *fun2() {
|
|
return __builtin_get_device_side_mangled_name(X::var1);
|
|
}
|