mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-18 12:06:08 +00:00

LLVM triple normalization is handling "unknown" and empty components differently; for example given "x86_64-unknown-linux-gnu" and "x86_64-linux-gnu" which should be equivalent, triple normalization returns "x86_64-unknown-linux-gnu" and "x86_64--linux-gnu". autoconf's config.sub returns "x86_64-unknown-linux-gnu" for both "x86_64-linux-gnu" and "x86_64-unknown-linux-gnu". This changes the triple normalization to behave the same way, replacing empty triple components with "unknown". This addresses PR37129. Differential Revision: https://reviews.llvm.org/D50219 llvm-svn: 339294
34 lines
1.7 KiB
Plaintext
34 lines
1.7 KiB
Plaintext
// Tests CUDA compilation with -S and -emit-llvm.
|
|
|
|
// REQUIRES: clang-driver
|
|
// REQUIRES: x86-registered-target
|
|
// REQUIRES: nvptx-registered-target
|
|
|
|
// RUN: %clang -### -S -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix HOST -check-prefix SM20 %s
|
|
// RUN: %clang -### -S -target x86_64-linux-gnu --cuda-host-only -o foo.s %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix HOST %s
|
|
// RUN: %clang -### -S -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 \
|
|
// RUN: --cuda-device-only -o foo.s %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix SM20 %s
|
|
// RUN: %clang -### -S -target x86_64-linux-gnu --cuda-gpu-arch=sm_20 \
|
|
// RUN: --cuda-gpu-arch=sm_30 --cuda-device-only %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix SM20 -check-prefix SM30 %s
|
|
|
|
// HOST-DAG: "-cc1" "-triple" "x86_64-unknown-linux-gnu"
|
|
// SM20-DAG: "-cc1" "-triple" "nvptx64-nvidia-cuda"
|
|
// SM20-same: "-target-cpu" "sm_20"
|
|
// SM30-DAG: "-cc1" "-triple" "nvptx64-nvidia-cuda"
|
|
// SM30-same: "-target-cpu" "sm_30"
|
|
|
|
// RUN: %clang -### -S -target x86_64-linux-gnu -o foo.s %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix MULTIPLE-OUTPUT-FILES %s
|
|
// RUN: %clang -### -S -target x86_64-linux-gnu --cuda-device-only \
|
|
// RUN: --cuda-gpu-arch=sm_20 --cuda-gpu-arch=sm_30 -o foo.s %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix MULTIPLE-OUTPUT-FILES %s
|
|
// RUN: %clang -### -emit-llvm -c -target x86_64-linux-gnu -o foo.s %s 2>&1 \
|
|
// RUN: | FileCheck -check-prefix MULTIPLE-OUTPUT-FILES %s
|
|
// MULTIPLE-OUTPUT-FILES: error: cannot specify -o when generating multiple output files
|
|
// Make sure we do not get duplicate diagnostics.
|
|
// MULTIPLE-OUTPUT-FILES-NOT: error: cannot specify -o when generating multiple output files
|