llvm-project/clang/test/Preprocessor/cuda-preprocess.cu

32 lines
1.2 KiB
Plaintext

// Tests CUDA compilation with -E.
// REQUIRES: x86-registered-target
// REQUIRES: nvptx-registered-target
#ifndef __CUDA_ARCH__
#define PREPROCESSED_AWAY
clang_unittest_no_arch PREPROCESSED_AWAY
#else
clang_unittest_cuda_arch __CUDA_ARCH__
#endif
// CHECK-NOT: PREPROCESSED_AWAY
// RUN: %clang -E -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 -nocudainc -nocudalib %s 2>&1 \
// RUN: | FileCheck -check-prefix NOARCH %s
// RUN: %clang -E -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 --cuda-host-only -nocudainc %s 2>&1 \
// RUN: | FileCheck -check-prefix NOARCH %s
// NOARCH: clang_unittest_no_arch
// RUN: %clang -E -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 --cuda-device-only -nocudainc -nocudalib %s 2>&1 \
// RUN: | FileCheck -check-prefix SM20 %s
// SM20: clang_unittest_cuda_arch 200
// RUN: %clang -E -target x86_64-linux-gnu --cuda-gpu-arch=sm_30 --cuda-device-only -nocudainc -nocudalib %s 2>&1 \
// RUN: | FileCheck -check-prefix SM30 %s
// SM30: clang_unittest_cuda_arch 300
// RUN: %clang -E -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 --cuda-gpu-arch=sm_30 \
// RUN: --cuda-device-only -nocudainc -nocudalib %s 2>&1 \
// RUN: | FileCheck -check-prefix SM20 -check-prefix SM30 %s