Files
clang-p2996/clang/test/Driver/hip-code-object-version.hip
Pierre van Houtryve 500846d2f5 [AMDGPU] Introduce Code Object V6 (#76954)
Introduce Code Object V6 in Clang, LLD, Flang and LLVM. This is the same
as V5 except a new "generic version" flag can be present in EFLAGS. This
is related to new generic targets that'll be added in a follow-up patch.
It's also likely V6 will have new changes (possibly new metadata
entries) added later.

Docs change are part of the follow-up patch #76955
2024-02-05 08:19:53 +01:00

88 lines
3.4 KiB
Plaintext

// REQUIRES: amdgpu-registered-target
// Check bundle ID for code object version 4.
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=4 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm \
// RUN: %s 2>&1 | FileCheck -check-prefix=V4 %s
// V4: "-mcode-object-version=4"
// V4: "-mllvm" "--amdhsa-code-object-version=4"
// V4: "-targets=host-x86_64-unknown-linux,hipv4-amdgcn-amd-amdhsa--gfx906"
// Check bundle ID for code object version 5.
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=5 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm \
// RUN: %s 2>&1 | FileCheck -check-prefix=V5 %s
// V5: "-mcode-object-version=5"
// V5: "-mllvm" "--amdhsa-code-object-version=5"
// V5: "-targets=host-x86_64-unknown-linux,hipv4-amdgcn-amd-amdhsa--gfx906"
// Check bundle ID for code object version 6.
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=6 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm \
// RUN: %s 2>&1 | FileCheck -check-prefix=V6 %s
// V6: warning: code object v6 is still in development and not ready for production use yet; use at your own risk
// V6: "-mcode-object-version=6"
// V6: "-mllvm" "--amdhsa-code-object-version=6"
// V6: "-targets=host-x86_64-unknown-linux,hipv4-amdgcn-amd-amdhsa--gfx906"
// Check bundle ID for code object version default
// RUN: %clang -### --target=x86_64-linux-gnu \
// RUN: --offload-arch=gfx906 -nogpuinc -nogpulib \
// RUN: %s 2>&1 | FileCheck -check-prefix=VD %s
// VD: "-targets=host-x86_64-unknown-linux,hipv4-amdgcn-amd-amdhsa--gfx906"
// Check invalid code object version option.
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=1 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm \
// RUN: %s 2>&1 | FileCheck -check-prefix=INVALID_1 %s
// INVALID_1: error: invalid integral value '1' in '-mcode-object-version=1'
// INVALID_1-NOT: error: invalid integral value
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=2 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm \
// RUN: %s 2>&1 | FileCheck -check-prefix=INVALID_2 %s
// INVALID_2: error: invalid integral value '2' in '-mcode-object-version=2'
// INVALID_2-NOT: error: invalid integral value
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=3 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm \
// RUN: %s 2>&1 | FileCheck -check-prefix=INVALID_3 %s
// INVALID_3: error: invalid integral value '3' in '-mcode-object-version=3'
// INVALID_3-NOT: error: invalid integral value
// Check LLVM code object version option --amdhsa-code-object-version
// is passed to -cc1 and -cc1as, and -mcode-object-version is passed
// to -cc1 but not -cc1as.
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=5 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm -save-temps \
// RUN: %s 2>&1 | FileCheck -check-prefix=CC1 %s
// CC1: "-cc1" {{.*}}"-mcode-object-version=5" {{.*}}"-mllvm" "--amdhsa-code-object-version=5"
// CC1: "-cc1as" {{.*}}"-mllvm" "--amdhsa-code-object-version=5"
// RUN: not %clang -### --target=x86_64-linux-gnu \
// RUN: -mcode-object-version=5 \
// RUN: --offload-arch=gfx906 --rocm-path=%S/Inputs/rocm -save-temps \
// RUN: %s 2>&1 | FileCheck -check-prefix=CC1NEG %s
// CC1NEG-NOT: "-cc1as" {{.*}}"-mcode-object-version=5"