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