1*67e74705SXin Li // RUN: %clang_cc1 %s -triple nvptx-unknown-unknown -fcuda-is-device -emit-llvm -o - | FileCheck %s
2*67e74705SXin Li
3*67e74705SXin Li #include "Inputs/cuda.h"
4*67e74705SXin Li
5*67e74705SXin Li #define MAX_THREADS_PER_BLOCK 256
6*67e74705SXin Li #define MIN_BLOCKS_PER_MP 2
7*67e74705SXin Li
8*67e74705SXin Li // Test both max threads per block and Min cta per sm.
9*67e74705SXin Li extern "C" {
10*67e74705SXin Li __global__ void
__launch_bounds__(MAX_THREADS_PER_BLOCK,MIN_BLOCKS_PER_MP)11*67e74705SXin Li __launch_bounds__( MAX_THREADS_PER_BLOCK, MIN_BLOCKS_PER_MP )
12*67e74705SXin Li Kernel1()
13*67e74705SXin Li {
14*67e74705SXin Li }
15*67e74705SXin Li }
16*67e74705SXin Li
17*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @Kernel1, !"maxntidx", i32 256}
18*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @Kernel1, !"minctasm", i32 2}
19*67e74705SXin Li
20*67e74705SXin Li // Test only max threads per block. Min cta per sm defaults to 0, and
21*67e74705SXin Li // CodeGen doesn't output a zero value for minctasm.
22*67e74705SXin Li extern "C" {
23*67e74705SXin Li __global__ void
__launch_bounds__(MAX_THREADS_PER_BLOCK)24*67e74705SXin Li __launch_bounds__( MAX_THREADS_PER_BLOCK )
25*67e74705SXin Li Kernel2()
26*67e74705SXin Li {
27*67e74705SXin Li }
28*67e74705SXin Li }
29*67e74705SXin Li
30*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @Kernel2, !"maxntidx", i32 256}
31*67e74705SXin Li
32*67e74705SXin Li template <int max_threads_per_block>
33*67e74705SXin Li __global__ void
__launch_bounds__(max_threads_per_block)34*67e74705SXin Li __launch_bounds__(max_threads_per_block)
35*67e74705SXin Li Kernel3()
36*67e74705SXin Li {
37*67e74705SXin Li }
38*67e74705SXin Li
39*67e74705SXin Li template void Kernel3<MAX_THREADS_PER_BLOCK>();
40*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel3{{.*}}, !"maxntidx", i32 256}
41*67e74705SXin Li
42*67e74705SXin Li template <int max_threads_per_block, int min_blocks_per_mp>
43*67e74705SXin Li __global__ void
__launch_bounds__(max_threads_per_block,min_blocks_per_mp)44*67e74705SXin Li __launch_bounds__(max_threads_per_block, min_blocks_per_mp)
45*67e74705SXin Li Kernel4()
46*67e74705SXin Li {
47*67e74705SXin Li }
48*67e74705SXin Li template void Kernel4<MAX_THREADS_PER_BLOCK, MIN_BLOCKS_PER_MP>();
49*67e74705SXin Li
50*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel4{{.*}}, !"maxntidx", i32 256}
51*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel4{{.*}}, !"minctasm", i32 2}
52*67e74705SXin Li
53*67e74705SXin Li const int constint = 100;
54*67e74705SXin Li template <int max_threads_per_block, int min_blocks_per_mp>
55*67e74705SXin Li __global__ void
56*67e74705SXin Li __launch_bounds__(max_threads_per_block + constint,
57*67e74705SXin Li min_blocks_per_mp + max_threads_per_block)
Kernel5()58*67e74705SXin Li Kernel5()
59*67e74705SXin Li {
60*67e74705SXin Li }
61*67e74705SXin Li template void Kernel5<MAX_THREADS_PER_BLOCK, MIN_BLOCKS_PER_MP>();
62*67e74705SXin Li
63*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel5{{.*}}, !"maxntidx", i32 356}
64*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel5{{.*}}, !"minctasm", i32 258}
65*67e74705SXin Li
66*67e74705SXin Li // Make sure we don't emit negative launch bounds values.
67*67e74705SXin Li __global__ void
68*67e74705SXin Li __launch_bounds__( -MAX_THREADS_PER_BLOCK, MIN_BLOCKS_PER_MP )
Kernel6()69*67e74705SXin Li Kernel6()
70*67e74705SXin Li {
71*67e74705SXin Li }
72*67e74705SXin Li // CHECK-NOT: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel6{{.*}}, !"maxntidx",
73*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel6{{.*}}, !"minctasm",
74*67e74705SXin Li
75*67e74705SXin Li __global__ void
76*67e74705SXin Li __launch_bounds__( MAX_THREADS_PER_BLOCK, -MIN_BLOCKS_PER_MP )
Kernel7()77*67e74705SXin Li Kernel7()
78*67e74705SXin Li {
79*67e74705SXin Li }
80*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel7{{.*}}, !"maxntidx",
81*67e74705SXin Li // CHECK-NOT: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel7{{.*}}, !"minctasm",
82*67e74705SXin Li
83*67e74705SXin Li const char constchar = 12;
__launch_bounds__(constint,constchar)84*67e74705SXin Li __global__ void __launch_bounds__(constint, constchar) Kernel8() {}
85*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel8{{.*}}, !"maxntidx", i32 100
86*67e74705SXin Li // CHECK: !{{[0-9]+}} = !{void ()* @{{.*}}Kernel8{{.*}}, !"minctasm", i32 12
87