1 // RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -fsyntax-only -verify %s 2 // RUN: %clang_cc1 -triple nvptx-unknown-cuda -fsyntax-only -verify -fcuda-is-device %s 3 // 4 // We run clang_cc1 with 'not' because source file contains 5 // intentional errors. CC1 failure is expected and must be ignored 6 // here. We're interested in what ends up in AST and that's what 7 // FileCheck verifies. 8 // RUN: not %clang_cc1 -triple x86_64-unknown-linux-gnu -fsyntax-only -ast-dump %s \ 9 // RUN: | FileCheck %s --check-prefix=CHECK-ALL --check-prefix=CHECK-HOST 10 // RUN: not %clang_cc1 -triple nvptx-unknown-cuda -fsyntax-only -ast-dump -fcuda-is-device %s \ 11 // RUN: | FileCheck %s --check-prefix=CHECK-ALL --check-prefix=CHECK-DEVICE 12 13 #include "Inputs/cuda.h" 14 15 // Host (x86) supports TLS and device-side compilation should ignore 16 // host variables. No errors in either case. 17 int __thread host_tls_var; 18 // CHECK-ALL: host_tls_var 'int' tls 19 20 #if defined(__CUDA_ARCH__) 21 // NVPTX does not support TLS 22 __device__ int __thread device_tls_var; // expected-error {{thread-local storage is not supported for the current target}} 23 // CHECK-DEVICE: device_tls_var 'int' tls 24 __shared__ int __thread shared_tls_var; // expected-error {{thread-local storage is not supported for the current target}} 25 // CHECK-DEVICE: shared_tls_var 'int' tls 26 #else 27 // Device-side vars should not produce any errors during host-side 28 // compilation. 29 __device__ int __thread device_tls_var; 30 // CHECK-HOST: device_tls_var 'int' tls 31 __shared__ int __thread shared_tls_var; 32 // CHECK-HOST: shared_tls_var 'int' tls 33 #endif 34 35 __global__ void g1(int x) {} 36 __global__ int g2(int x) { // expected-error {{must have void return type}} 37 return 1; 38 } 39