
1. The PR proceeds with a backend target hook to allow front-ends to determine what target features are available in a compilation based on the CPU name. 2. Fix a backend target feature bug that supports HTM for Power8/9/10/11. However, HTM is only supported on Power8/9 according to the ISA. 3. All target features that are hardcoded in PPC.cpp can be retrieved from the backend target feature. I have double-checked that the hardcoded logic for inferring target features from the CPU in the frontend(PPC.cpp) is the same as in PPC.td. The reland patch addressed the comment https://github.com/llvm/llvm-project/pull/137670#discussion_r2143541120
57 lines
3.5 KiB
C
57 lines
3.5 KiB
C
// RUN: %clang --target=powerpc64-unknown-aix -S -emit-llvm %s -o - | FileCheck --check-prefix=CHECK-DEFAULT %s
|
|
// RUN: %clang --target=powerpc-unknown-aix -S -emit-llvm %s -o - | FileCheck --check-prefix=CHECK-DEFAULT %s
|
|
// RUN: %clang --target=powerpc64le-unknown-linux-gnu -S -emit-llvm %s -o - | FileCheck --check-prefix=CHECK-DEFAULT %s
|
|
// RUN: %clang --target=powerpc64-unknown-linux-gnu -S -emit-llvm %s -o - | FileCheck --check-prefix=CHECK-DEFAULT %s
|
|
|
|
// RUN: %clang --target=powerpc64-unknown-aix -maix-small-local-exec-tls -S -emit-llvm \
|
|
// RUN: %s -o - | FileCheck %s --check-prefix=CHECK-AIX_SMALL_LOCALEXEC_TLS
|
|
|
|
// RUN: %clang --target=powerpc64-unknown-aix -maix-small-local-dynamic-tls -S -emit-llvm \
|
|
// RUN: %s -o - | FileCheck %s --check-prefix=CHECK-AIX_SMALL_LOCALDYNAMIC_TLS
|
|
|
|
// RUN: not %clang --target=powerpc-unknown-aix -maix-small-local-exec-tls \
|
|
// RUN: -fsyntax-only %s 2>&1 | FileCheck --check-prefix=CHECK-UNSUPPORTED-AIX32 %s
|
|
// RUN: not %clang --target=powerpc64le-unknown-linux-gnu -maix-small-local-exec-tls \
|
|
// RUN: -fsyntax-only %s 2>&1 | FileCheck --check-prefix=CHECK-UNSUPPORTED-LINUX %s
|
|
// RUN: not %clang --target=powerpc64-unknown-linux-gnu -maix-small-local-exec-tls \
|
|
// RUN: -fsyntax-only %s 2>&1 | FileCheck --check-prefix=CHECK-UNSUPPORTED-LINUX %s
|
|
// RUN: not %clang --target=powerpc64-unknown-aix -maix-small-local-exec-tls \
|
|
// RUN: -fsyntax-only -fno-data-sections %s 2>&1 | \
|
|
// RUN: FileCheck --check-prefix=CHECK-UNSUPPORTED-NO-DATASEC %s
|
|
// RUN: not %clang --target=powerpc64-unknown-linux-gnu -maix-small-local-exec-tls \
|
|
// RUN: -fsyntax-only -fno-data-sections %s 2>&1 | \
|
|
// RUN: FileCheck --check-prefix=CHECK-UNSUPPORTED-NO-DATASEC %s
|
|
|
|
// RUN: not %clang --target=powerpc-unknown-aix -maix-small-local-dynamic-tls \
|
|
// RUN: -fsyntax-only %s 2>&1 | FileCheck --check-prefix=CHECK-UNSUPPORTED-AIX32 %s
|
|
// RUN: not %clang --target=powerpc64le-unknown-linux-gnu -maix-small-local-dynamic-tls \
|
|
// RUN: -fsyntax-only %s 2>&1 | FileCheck --check-prefix=CHECK-UNSUPPORTED-LINUX %s
|
|
// RUN: not %clang --target=powerpc64-unknown-linux-gnu -maix-small-local-dynamic-tls \
|
|
// RUN: -fsyntax-only %s 2>&1 | FileCheck --check-prefix=CHECK-UNSUPPORTED-LINUX %s
|
|
// RUN: not %clang --target=powerpc64-unknown-aix -maix-small-local-dynamic-tls \
|
|
// RUN: -fsyntax-only -fno-data-sections %s 2>&1 | \
|
|
// RUN: FileCheck --check-prefix=CHECK-UNSUPPORTED-NO-DATASEC %s
|
|
// RUN: not %clang --target=powerpc64-unknown-linux-gnu -maix-small-local-dynamic-tls \
|
|
// RUN: -fsyntax-only -fno-data-sections %s 2>&1 | \
|
|
// RUN: FileCheck --check-prefix=CHECK-UNSUPPORTED-NO-DATASEC %s
|
|
|
|
int test(void) {
|
|
return 0;
|
|
}
|
|
|
|
// CHECK-DEFAULT: test() #0 {
|
|
// CHECK-DEFAULT: attributes #0 = {
|
|
// CHECK-DEFAULT-NOT: {{[-+]aix-small-local-exec-tls,.*[-+]aix-small-local-dynamic-tls|[-+]aix-small-local-dynamic-tls,.*[-+]aix-small-local-exec-tls}}
|
|
|
|
// CHECK-UNSUPPORTED-AIX32: option '-maix-small-local-[exec|dynamic]-tls' cannot be specified on this target
|
|
// CHECK-UNSUPPORTED-LINUX: option '-maix-small-local-[exec|dynamic]-tls' cannot be specified on this target
|
|
// CHECK-UNSUPPORTED-NO-DATASEC: invalid argument '-maix-small-local-[exec|dynamic]-tls' only allowed with '-fdata-sections'
|
|
|
|
// CHECK-AIX_SMALL_LOCALEXEC_TLS: test() #0 {
|
|
// CHECK-AIX_SMALL_LOCALEXEC_TLS: attributes #0 = {
|
|
// CHECK-AIX_SMALL_LOCALEXEC_TLS-SAME: +aix-small-local-exec-tls
|
|
|
|
// CHECK-AIX_SMALL_LOCALDYNAMIC_TLS: test() #0 {
|
|
// CHECK-AIX_SMALL_LOCALDYNAMIC_TLS: attributes #0 = {
|
|
// CHECK-AIX_SMALL_LOCALDYNAMIC_TLS-SAME: +aix-small-local-dynamic-tls
|