2020-11-25 03:59:15 +08:00
|
|
|
/// Check default CC1 and linker options for ppc32.
|
2021-01-03 02:17:58 +08:00
|
|
|
// RUN: %clang -### -target powerpcle-unknown-linux-gnu %s 2>&1 | FileCheck --check-prefixes=PPC32,PPC32LELNX %s
|
|
|
|
// RUN: %clang -### -target powerpc-unknown-linux-gnu %s 2>&1 | FileCheck --check-prefixes=PPC32,PPC32BELNX %s
|
|
|
|
// RUN: %clang -### -target powerpcle-unknown-freebsd13.0 %s 2>&1 | FileCheck --check-prefixes=PPC32,PPC32LEFBSD %s
|
|
|
|
// RUN: %clang -### -target powerpc-unknown-freebsd13.0 %s 2>&1 | FileCheck --check-prefixes=PPC32,PPC32BEFBSD %s
|
2020-12-22 07:32:35 +08:00
|
|
|
// PPC32: "-munwind-tables"
|
|
|
|
// PPC32-SAME: "-mfloat-abi" "hard"
|
2020-11-25 03:59:15 +08:00
|
|
|
|
2021-01-03 02:17:58 +08:00
|
|
|
// PPC32LELNX-NEXT: "-m" "elf32lppclinux"
|
|
|
|
// PPC32BELNX-NEXT: "-m" "elf32ppclinux"
|
|
|
|
// PPC32LEFBSD-NEXT: "-m" "elf32lppc"
|
|
|
|
// PPC32BEFBSD-NEXT: "-m" "elf32ppc_fbsd"
|
2020-11-25 03:59:15 +08:00
|
|
|
|
2015-12-15 01:51:50 +08:00
|
|
|
// check -msoft-float option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -msoft-float -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-SOFTFLOAT %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-SOFTFLOAT: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check -mfloat-abi=soft option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -mfloat-abi=soft -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-FLOATABISOFT %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-FLOATABISOFT: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check -mhard-float option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -mhard-float -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-HARDFLOAT %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-HARDFLOAT-NOT: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check -mfloat-abi=hard option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -mfloat-abi=hard -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-FLOATABIHARD %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-FLOATABIHARD-NOT: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check combine -mhard-float -msoft-float option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -mhard-float -msoft-float -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-HARDSOFT %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-HARDSOFT: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check combine -msoft-float -mhard-float option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -msoft-float -mhard-float -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-SOFTHARD %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-SOFTHARD-NOT: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
2018-04-11 20:24:44 +08:00
|
|
|
// check -msecure-plt option for ppc32
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu -msecure-plt %s -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-SECUREPLT %s
|
|
|
|
// CHECK-SECUREPLT: "-target-feature" "+secure-plt"
|
|
|
|
|
2015-12-15 01:51:50 +08:00
|
|
|
// check -mfloat-abi=x option
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -mfloat-abi=x -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-ERRMSG %s
|
2015-12-15 03:22:35 +08:00
|
|
|
// CHECK-ERRMSG: error: invalid float ABI '-mfloat-abi=x'
|
2015-12-15 01:51:50 +08:00
|
|
|
|
2020-11-25 03:59:15 +08:00
|
|
|
|
|
|
|
/// Check default CC1 and linker options for ppc64.
|
2020-12-22 07:32:35 +08:00
|
|
|
// RUN: %clang -### -target powerpc64le-unknown-linux-gnu %s 2>&1 | FileCheck --check-prefixes=PPC64,PPC64LE %s
|
|
|
|
// RUN: %clang -### -target powerpc64-unknown-linux-gnu %s 2>&1 | FileCheck --check-prefixes=PPC64,PPC64BE %s
|
|
|
|
// PPC64: "-munwind-tables"
|
|
|
|
// PPC64-SAME: "-mfloat-abi" "hard"
|
2020-11-25 03:59:15 +08:00
|
|
|
|
2020-12-22 07:32:35 +08:00
|
|
|
// PPC64LE: "-m" "elf64lppc"
|
2020-11-25 03:59:15 +08:00
|
|
|
// PPC64BE: "-m" "elf64ppc"
|
|
|
|
|
2015-12-15 01:51:50 +08:00
|
|
|
// check -msoft-float option for ppc64
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -msoft-float -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-SOFTFLOAT64 %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-SOFTFLOAT64: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check -mfloat-abi=soft option for ppc64
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mfloat-abi=soft -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-FLOATABISOFT64 %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-FLOATABISOFT64: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check -msoft-float option for ppc64
|
|
|
|
// RUN: %clang -target powerpc64le-unknown-linux-gnu %s -msoft-float -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-SOFTFLOAT64le %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-SOFTFLOAT64le: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
|
|
|
// check -mfloat-abi=soft option for ppc64
|
|
|
|
// RUN: %clang -target powerpc64le-unknown-linux-gnu %s -mfloat-abi=soft -### -o %t.o 2>&1 | FileCheck --check-prefix=CHECK-FLOATABISOFT64le %s
|
2016-10-02 10:10:45 +08:00
|
|
|
// CHECK-FLOATABISOFT64le: "-target-feature" "-hard-float"
|
2015-12-15 01:51:50 +08:00
|
|
|
|
2017-03-22 06:06:18 +08:00
|
|
|
// Check that -mno-altivec correctly disables the altivec target feature on powerpc.
|
2013-02-01 22:45:29 +08:00
|
|
|
|
2020-11-25 03:59:15 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-altivec -maltivec -### -o %t.o 2>&1 | FileCheck --check-prefix=ALTIVEC %s
|
|
|
|
// ALTIVEC: "-target-feature" "+altivec"
|
2013-02-01 22:45:29 +08:00
|
|
|
|
2020-11-25 03:59:15 +08:00
|
|
|
// RUN: %clang -### -c -target powerpc64-unknown-linux-gnu %s -maltivec -mno-altivec 2>&1 | FileCheck --check-prefix=NO_ALTIVEC %s
|
|
|
|
// NO_ALTIVEC: "-target-feature" "-altivec"
|
2014-06-26 21:34:10 +08:00
|
|
|
|
2013-03-28 16:38:53 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-mfcrf -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOMFCRF %s
|
|
|
|
// CHECK-NOMFCRF: "-target-feature" "-mfocrf"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-mfcrf -mmfcrf -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-MFCRF %s
|
|
|
|
// CHECK-MFCRF: "-target-feature" "+mfocrf"
|
|
|
|
|
2015-04-10 01:38:50 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-isel -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOISEL %s
|
|
|
|
// CHECK-NOISEL: "-target-feature" "-isel"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-isel -misel -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-ISEL %s
|
|
|
|
// CHECK-ISEL: "-target-feature" "+isel"
|
|
|
|
|
2013-03-28 21:51:36 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-popcntd -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOPOPCNTD %s
|
|
|
|
// CHECK-NOPOPCNTD: "-target-feature" "-popcntd"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-popcntd -mpopcntd -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-POPCNTD %s
|
|
|
|
// CHECK-POPCNTD: "-target-feature" "+popcntd"
|
|
|
|
|
2013-03-30 21:47:44 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-fprnd -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOFPRND %s
|
|
|
|
// CHECK-NOFPRND: "-target-feature" "-fprnd"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-fprnd -mfprnd -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-FPRND %s
|
|
|
|
// CHECK-FPRND: "-target-feature" "+fprnd"
|
2013-10-17 04:40:13 +08:00
|
|
|
|
2015-01-07 07:06:41 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-cmpb -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOCMPB %s
|
|
|
|
// CHECK-NOCMPB: "-target-feature" "-cmpb"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-cmpb -mcmpb -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-CMPB %s
|
|
|
|
// CHECK-CMPB: "-target-feature" "+cmpb"
|
|
|
|
|
2013-10-17 04:40:13 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-vsx -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOVSX %s
|
|
|
|
// CHECK-NOVSX: "-target-feature" "-vsx"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-vsx -mvsx -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-VSX %s
|
|
|
|
// CHECK-VSX: "-target-feature" "+vsx"
|
|
|
|
|
2017-03-21 05:12:53 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-htm -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOHTM %s
|
|
|
|
// CHECK-NOHTM: "-target-feature" "-htm"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-htm -mhtm -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-HTM %s
|
|
|
|
// CHECK-HTM: "-target-feature" "+htm"
|
|
|
|
|
2014-10-10 23:09:43 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-power8-vector -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOP8VECTOR %s
|
|
|
|
// CHECK-NOP8VECTOR: "-target-feature" "-power8-vector"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-power8-vector -mpower8-vector -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-P8VECTOR %s
|
|
|
|
// CHECK-P8VECTOR: "-target-feature" "+power8-vector"
|
|
|
|
|
[PowerPC] Add -m[no-]power10-vector clang and llvm option
Summary: This patch adds command line option for enabling power10-vector support.
Reviewers: hfinkel, nemanjai, lei, amyk, #powerpc
Reviewed By: lei, amyk, #powerpc
Subscribers: wuzish, kbarton, hiraditya, shchenz, cfe-commits, llvm-commits
Tags: #llvm, #clang, #powerpc
Differential Revision: https://reviews.llvm.org/D80758
2020-06-17 03:39:18 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-power10-vector -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOP10VECTOR %s
|
|
|
|
// CHECK-NOP10VECTOR: "-target-feature" "-power10-vector"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-power10-vector -mpower10-vector -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-P10VECTOR %s
|
|
|
|
// CHECK-P10VECTOR: "-target-feature" "+power10-vector"
|
|
|
|
|
2014-02-28 08:27:57 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-crbits -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOCRBITS %s
|
|
|
|
// CHECK-NOCRBITS: "-target-feature" "-crbits"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-crbits -mcrbits -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-CRBITS %s
|
|
|
|
// CHECK-CRBITS: "-target-feature" "+crbits"
|
|
|
|
|
2016-08-30 09:07:03 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-longcall -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOLONGCALL %s
|
|
|
|
// CHECK-NOLONGCALL: "-target-feature" "-longcall"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-longcall -mlongcall -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-LONGCALL %s
|
|
|
|
// CHECK-LONGCALL: "-target-feature" "+longcall"
|
|
|
|
|
2015-01-16 05:22:22 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-invariant-function-descriptors -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-NOINVFUNCDESC %s
|
|
|
|
// CHECK-NOINVFUNCDESC: "-target-feature" "-invariant-function-descriptors"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -mno-invariant-function-descriptors -minvariant-function-descriptors -### -o %t.o 2>&1 | FileCheck -check-prefix=CHECK-INVFUNCDESC %s
|
|
|
|
// CHECK-INVFUNCDESC: "-target-feature" "+invariant-function-descriptors"
|
|
|
|
|
2020-01-09 12:43:57 +08:00
|
|
|
// RUN: %clang -target powerpc %s -mno-spe -mspe -c -### 2>&1 | FileCheck -check-prefix=CHECK-SPE %s
|
|
|
|
// RUN: %clang -target powerpcspe %s -c -### 2>&1 | FileCheck -check-prefix=CHECK-SPE %s
|
|
|
|
// RUN: %clang -target powerpcspe %s -mno-spe -c -### 2>&1 | FileCheck -check-prefix=CHECK-NOSPE %s
|
2019-09-05 21:38:46 +08:00
|
|
|
// CHECK-SPE: "-target-feature" "+spe"
|
2020-01-09 12:43:57 +08:00
|
|
|
// CHECK-NOSPE: "-target-feature" "-spe"
|
2019-09-05 21:38:46 +08:00
|
|
|
|
2021-01-12 23:46:11 +08:00
|
|
|
// RUN: %clang -target powerpc %s -mefpu2 -c -### 2>&1 | FileCheck -check-prefix=CHECK-EFPU2 %s
|
|
|
|
// CHECK-EFPU2: "-target-feature" "+efpu2"
|
|
|
|
|
2014-03-25 01:10:37 +08:00
|
|
|
// Assembler features
|
2021-01-12 06:39:01 +08:00
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -### -o %t.o -no-integrated-as 2>&1 | FileCheck -check-prefix=CHECK_32_BE_AS_ARGS %s
|
|
|
|
// CHECK_32_BE_AS_ARGS: "-mppc"
|
|
|
|
// CHECK_32_BE_AS_ARGS-SAME: "-mbig-endian"
|
|
|
|
// CHECK_32_BE_AS_ARGS-SAME: "-many"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpcle-unknown-linux-gnu %s -### -o %t.o -no-integrated-as 2>&1 | FileCheck -check-prefix=CHECK_32_LE_AS_ARGS %s
|
|
|
|
// CHECK_32_LE_AS_ARGS: "-mppc"
|
|
|
|
// CHECK_32_LE_AS_ARGS-SAME: "-mlittle-endian"
|
|
|
|
// CHECK_32_LE_AS_ARGS-SAME: "-many"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -### -o %t.o -no-integrated-as 2>&1 | FileCheck -check-prefix=CHECK_64_BE_AS_ARGS %s
|
|
|
|
// CHECK_64_BE_AS_ARGS: "-mppc64"
|
|
|
|
// CHECK_64_BE_AS_ARGS-SAME: "-mbig-endian"
|
|
|
|
// CHECK_64_BE_AS_ARGS-SAME: "-many"
|
|
|
|
|
|
|
|
// RUN: %clang -target powerpc64le-unknown-linux-gnu %s -### -o %t.o -no-integrated-as 2>&1 | FileCheck -check-prefix=CHECK_64_LE_AS_ARGS %s
|
|
|
|
// CHECK_64_LE_AS_ARGS: "-mppc64"
|
|
|
|
// CHECK_64_LE_AS_ARGS-SAME: "-mlittle-endian"
|
|
|
|
// CHECK_64_LE_AS_ARGS-SAME: "-mpower8"
|
2014-03-25 01:10:37 +08:00
|
|
|
|
2015-07-14 06:54:53 +08:00
|
|
|
// OpenMP features
|
|
|
|
// RUN: %clang -target powerpc-unknown-linux-gnu %s -### -fopenmp=libomp -o %t.o 2>&1 | FileCheck -check-prefix=CHECK_OPENMP_TLS %s
|
2021-01-03 02:18:07 +08:00
|
|
|
// RUN: %clang -target powerpcle-unknown-linux-gnu %s -### -fopenmp=libomp -o %t.o 2>&1 | FileCheck -check-prefix=CHECK_OPENMP_TLS %s
|
2015-07-14 06:54:53 +08:00
|
|
|
// RUN: %clang -target powerpc64-unknown-linux-gnu %s -### -fopenmp=libomp -o %t.o 2>&1 | FileCheck -check-prefix=CHECK_OPENMP_TLS %s
|
|
|
|
// RUN: %clang -target powerpc64le-unknown-linux-gnu %s -### -fopenmp=libomp -o %t.o 2>&1 | FileCheck -check-prefix=CHECK_OPENMP_TLS %s
|
|
|
|
// CHECK_OPENMP_TLS-NOT: "-fnoopenmp-use-tls"
|