Revert "[llvm] Improve llvm.objectsize computation by computing GEP, alloca and mallo...
[llvm-project.git] / clang / test / CodeGenCUDA / grid-constant.cu
blob8d4be9c9dc7e1ef60bf3b3c0ff85af3c0b74543c
1 // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --check-globals all --version 5
2 // RUN: %clang_cc1 "-triple" "nvptx64-nvidia-cuda" -emit-llvm -fcuda-is-device -o - %s | FileCheck %s
4 #include "Inputs/cuda.h"
6 struct S {};
8 __global__ void kernel(__grid_constant__ const S gc_arg1, int arg2, __grid_constant__ const int gc_arg3) {}
10 // dependent arguments get diagnosed after instantiation.
11 template <typename T>
12 __global__ void tkernel_const(__grid_constant__ const T arg) {}
14 template <typename T>
15 __global__ void tkernel(int dummy, __grid_constant__ T arg) {}
17 void foo() {
18   tkernel_const<const S><<<1,1>>>({});
19   tkernel_const<S><<<1,1>>>({});
20   tkernel<const S><<<1,1>>>(1, {});
22 //.
23 //.
24 // CHECK: [[META0:![0-9]+]] = !{ptr @_Z6kernel1Sii, !"kernel", i32 1, !"grid_constant", [[META1:![0-9]+]]}
25 // CHECK: [[META1]] = !{i32 1, i32 3}
26 // CHECK: [[META2:![0-9]+]] = !{ptr @_Z13tkernel_constIK1SEvT_, !"kernel", i32 1, !"grid_constant", [[META3:![0-9]+]]}
27 // CHECK: [[META3]] = !{i32 1}
28 // CHECK: [[META4:![0-9]+]] = !{ptr @_Z13tkernel_constI1SEvT_, !"kernel", i32 1, !"grid_constant", [[META3]]}
29 // CHECK: [[META5:![0-9]+]] = !{ptr @_Z7tkernelIK1SEviT_, !"kernel", i32 1, !"grid_constant", [[META6:![0-9]+]]}
30 // CHECK: [[META6]] = !{i32 2}
31 //.