The exit code for -### is inconsistent. Unrecognized options lead to exit code 1, as expected. However, most others errors (including invalid option value) lead to exit code 0, differing from GCC and most utilities. This is a longstanding quirk of -###, and we didn't fix it because many driver tests need adjustment. Change -### to be similar to -fdriver-only -v and exit with code 1. This requires fixing many driver tests, but the end result gives us stronger tests. * Existing `RUN: %clang -### ...` tests usually don't use `CHECK-NOT: error:` or `--implicit-check-not=error:`. If a change introduces an error, such a change usually cannot be detected. * Many folks contributing new tests don't know `-fdriver-only -v`. To test no driver error/warning for new tests, they can use the familiar `-### -Werror` instead of `-fdriver-only -v -Werror`. An incomplete list of prerequisite test improvement: * 2f79bb10461d114783a1548201928549ace09755: add -nogpulib to some AMDGPU tests * 9155e517e6e1cda474d0d0fa82f71696c325bc10: add --cuda-path= (test w/ and w/o /usr/local/cuda) * 80765ede5bbcca1364c2d4ae06127011eaba6389: -mcpu=native may return either 0 or 1, depending on whether `--target=` specifies a native target * abae53f43f0d1da8d8e421f4a628d7ec64d6e365: fix -fuse-ld=lld misuses (test w/o and w/o /usr/local/bin/ld.lld) * ab68df505e5bb8808ee44f53044b50ca7575098e: add -resource-dir= and -fvisibility=hidden to some -fsanitize=cfi tests * d5ca1602f64114f612ad5630f04e4aa90591c78d: --rtlib=platform without --unwindlib= may fail if CLANG_DEFAULT_UNWINDLIB=unwindlib Reviewed By: jhuber6, yaxunl, dblaikie Differential Revision: https://reviews.llvm.org/D156363
31 lines
1.4 KiB
C++
31 lines
1.4 KiB
C++
// REQUIRES: x86-registered-target
|
|
// UNSUPPORTED: system-windows
|
|
|
|
// RUN: not %clang -### -x hip --target=x86_64-linux-gnu --offload= \
|
|
// RUN: --hip-path=%S/Inputs/hipspv -nogpuinc -nogpulib %s \
|
|
// RUN: 2>&1 | FileCheck --check-prefix=INVALID-TARGET %s
|
|
// RUN: not %clang -### -x hip --target=x86_64-linux-gnu --offload=foo \
|
|
// RUN: --hip-path=%S/Inputs/hipspv -nogpuinc -nogpulib %s \
|
|
// RUN: 2>&1 | FileCheck --check-prefix=INVALID-TARGET %s
|
|
|
|
// INVALID-TARGET: error: invalid or unsupported offload target: '{{.*}}'
|
|
|
|
// In the future we should be able to specify multiple targets for HIP
|
|
// compilation but currently it is not supported.
|
|
//
|
|
// RUN: not %clang -### -x hip --target=x86_64-linux-gnu --offload=foo,bar \
|
|
// RUN: --hip-path=%S/Inputs/hipspv -nogpuinc -nogpulib %s \
|
|
// RUN: 2>&1 | FileCheck --check-prefix=TOO-MANY-TARGETS %s
|
|
// RUN: not %clang -### -x hip --target=x86_64-linux-gnu \
|
|
// RUN: --offload=foo --offload=bar \
|
|
// RUN: --hip-path=%S/Inputs/hipspv -nogpuinc -nogpulib %s \
|
|
// RUN: 2>&1 | FileCheck --check-prefix=TOO-MANY-TARGETS %s
|
|
|
|
// TOO-MANY-TARGETS: error: only one offload target is supported
|
|
|
|
// RUN: not %clang -### -x hip --target=x86_64-linux-gnu -nogpuinc -nogpulib \
|
|
// RUN: --offload=amdgcn-amd-amdhsa --offload-arch=gfx900 %s \
|
|
// RUN: 2>&1 | FileCheck --check-prefix=OFFLOAD-ARCH-MIX %s
|
|
|
|
// OFFLOAD-ARCH-MIX: error: option '--offload-arch' cannot be specified with '--offload'
|