Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / SemaCUDA / static-device-var.cu
blob8027f265266ef671f273e3f8f244ff254da63ee5
1 // REQUIRES: x86-registered-target
2 // REQUIRES: amdgpu-registered-target
4 // RUN: %clang_cc1 -triple nvptx -fcuda-is-device -std=c++11 \
5 // RUN:    -emit-llvm -o - %s -fsyntax-only -verify=dev,com
7 // RUN: %clang_cc1 -triple x86_64-gnu-linux -std=c++11 \
8 // RUN:    -emit-llvm -o - %s -fsyntax-only -verify=host,com
10 // Checks allowed usage of file-scope and function-scope static variables.
12 #include "Inputs/cuda.h"
14 // Checks static variables are allowed in device functions.
16 __device__ void f1() {
17   const static int b = 123;
18   static int a;
21 // Checks static variables are allowd in global functions.
23 __global__ void k1() {
24   const static int b = 123;
25   static int a;
28 // Checks static device and constant variables are allowed in device and
29 // host functions, and static host variables are not allowed in device
30 // functions.
32 static __device__ int x;
33 static __constant__ int y;
34 static int z; // dev-note {{host variable declared here}}
36 __global__ void kernel(int *a) {
37   a[0] = x;
38   a[1] = y;
39   a[2] = z;
40   // dev-error@-1 {{reference to __host__ variable 'z' in __global__ function}}
43 // Check dynamic initialization of static device variable is not allowed.
45 namespace TestStaticVarInLambda {
46 class A {
47 public:
48   A(char *);
50 class B {
51 public:
52   __device__ B(char *);
54 void fun() {
55   (void) [](char *c) {
56     static A var1(c);
57     static __device__ B var2(c);
58     // com-error@-1 {{dynamic initialization is not supported for __device__, __constant__, __shared__, and __managed__ variables}}
59     (void) var1;
60     (void) var2;
61   };
65 int* getDeviceSymbol(int *x);
67 void foo() {
68   getDeviceSymbol(&x);
69   getDeviceSymbol(&y);