forked from OSchip/llvm-project
[mips] Improve handling of -fno-[pic/PIC] option
In order to disable PIC and to match GCC behaviour, -mno-abicalls option is neccessary. When -fno-[pic/PIC] is used witout -mno-abicalls, warning is reported. An error is reported when -fno-pic or -fno-PIC is used in combination with -mabicalls. Depends on D44381. Differential Revision: https://reviews.llvm.org/D44684 llvm-svn: 331636
This commit is contained in:
parent
cc4915701c
commit
f9b3fc5e2b
|
@ -339,10 +339,12 @@ def warn_drv_unsupported_longcalls : Warning<
|
|||
"ignoring '-mlong-calls' option as it is not currently supported with "
|
||||
"%select{|the implicit usage of }0-mabicalls">,
|
||||
InGroup<OptionIgnored>;
|
||||
def warn_drv_unsupported_abicalls : Warning<
|
||||
"ignoring '-mabicalls' option as it cannot be used with "
|
||||
"non position-independent code and the N64 ABI">,
|
||||
def warn_drv_unsupported_pic_with_mabicalls : Warning<
|
||||
"ignoring '%0' option as it cannot be used with "
|
||||
"%select{implicit usage of|}1 -mabicalls and the N64 ABI">,
|
||||
InGroup<OptionIgnored>;
|
||||
def err_drv_unsupported_noabicalls_pic : Error<
|
||||
"position-independent code requires ‘-mabicalls’">;
|
||||
def err_drv_unsupported_indirect_jump_opt : Error<
|
||||
"'-mindirect-jump=%0' is unsupported with the '%1' architecture">;
|
||||
def err_drv_unknown_indirect_jump_opt : Error<
|
||||
|
|
|
@ -214,6 +214,7 @@ void mips::getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
|
|||
// For case (a) we need to add +noabicalls for N64.
|
||||
|
||||
bool IsN64 = ABIName == "64";
|
||||
bool IsPIC = false;
|
||||
bool NonPIC = false;
|
||||
|
||||
Arg *LastPICArg = Args.getLastArg(options::OPT_fPIC, options::OPT_fno_PIC,
|
||||
|
@ -225,6 +226,9 @@ void mips::getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
|
|||
NonPIC =
|
||||
(O.matches(options::OPT_fno_PIC) || O.matches(options::OPT_fno_pic) ||
|
||||
O.matches(options::OPT_fno_PIE) || O.matches(options::OPT_fno_pie));
|
||||
IsPIC =
|
||||
(O.matches(options::OPT_fPIC) || O.matches(options::OPT_fpic) ||
|
||||
O.matches(options::OPT_fPIE) || O.matches(options::OPT_fpie));
|
||||
}
|
||||
|
||||
bool UseAbiCalls = false;
|
||||
|
@ -234,9 +238,14 @@ void mips::getMIPSTargetFeatures(const Driver &D, const llvm::Triple &Triple,
|
|||
UseAbiCalls =
|
||||
!ABICallsArg || ABICallsArg->getOption().matches(options::OPT_mabicalls);
|
||||
|
||||
if (UseAbiCalls && IsN64 && NonPIC) {
|
||||
D.Diag(diag::warn_drv_unsupported_abicalls);
|
||||
UseAbiCalls = false;
|
||||
if (IsN64 && NonPIC && (!ABICallsArg || UseAbiCalls)) {
|
||||
D.Diag(diag::warn_drv_unsupported_pic_with_mabicalls)
|
||||
<< LastPICArg->getAsString(Args) << (!ABICallsArg ? 0 : 1);
|
||||
NonPIC = false;
|
||||
}
|
||||
|
||||
if (ABICallsArg && !UseAbiCalls && IsPIC) {
|
||||
D.Diag(diag::err_drv_unsupported_noabicalls_pic);
|
||||
}
|
||||
|
||||
if (!UseAbiCalls)
|
||||
|
|
|
@ -1018,6 +1018,14 @@ tools::ParsePICArgs(const ToolChain &ToolChain, const ArgList &Args) {
|
|||
Triple.getArch() == llvm::Triple::mipsel ||
|
||||
Triple.getArch() == llvm::Triple::mips64 ||
|
||||
Triple.getArch() == llvm::Triple::mips64el) {
|
||||
StringRef CPUName;
|
||||
StringRef ABIName;
|
||||
mips::getMipsCPUAndABI(Args, Triple, CPUName, ABIName);
|
||||
// When targeting the N64 ABI, PIC is the default, except in the case
|
||||
// when the -mno-abicalls option is used. In that case we exit
|
||||
// at next check regardless of PIC being set below.
|
||||
if (ABIName == "n64")
|
||||
PIC = true;
|
||||
// When targettng MIPS with -mno-abicalls, it's always static.
|
||||
if(Args.hasArg(options::OPT_mno_abicalls))
|
||||
return std::make_tuple(llvm::Reloc::Static, 0U, false);
|
||||
|
|
|
@ -1,6 +1,27 @@
|
|||
// REQUIRES: mips-registered-target
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-PIC -mabicalls %s 2>&1 | FileCheck %s
|
||||
// CHECK: warning: ignoring '-mabicalls' option as it cannot be used with non position-independent code and the N64 ABI
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-pic %s 2>&1 | FileCheck -check-prefix=CHECK-PIC1-IMPLICIT %s
|
||||
// CHECK-PIC1-IMPLICIT: warning: ignoring '-fno-pic' option as it cannot be used with implicit usage of -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-pic -mabicalls %s 2>&1 | FileCheck -check-prefix=CHECK-PIC1-EXPLICIT %s
|
||||
// CHECK-PIC1-EXPLICIT: warning: ignoring '-fno-pic' option as it cannot be used with -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-PIC %s 2>&1 | FileCheck -check-prefix=CHECK-PIC2-IMPLICIT %s
|
||||
// CHECK-PIC2-IMPLICIT: warning: ignoring '-fno-PIC' option as it cannot be used with implicit usage of -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-PIC -mabicalls %s 2>&1 | FileCheck -check-prefix=CHECK-PIC2-EXPLICIT %s
|
||||
// CHECK-PIC2-EXPLICIT: warning: ignoring '-fno-PIC' option as it cannot be used with -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-pie %s 2>&1 | FileCheck -check-prefix=CHECK-PIE1-IMPLICIT %s
|
||||
// CHECK-PIE1-IMPLICIT: warning: ignoring '-fno-pie' option as it cannot be used with implicit usage of -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-pie -mabicalls %s 2>&1 | FileCheck -check-prefix=CHECK-PIE1-EXPLICIT %s
|
||||
// CHECK-PIE1-EXPLICIT: warning: ignoring '-fno-pie' option as it cannot be used with -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-PIE %s 2>&1 | FileCheck -check-prefix=CHECK-PIE2-IMPLICIT %s
|
||||
// CHECK-PIE2-IMPLICIT: warning: ignoring '-fno-PIE' option as it cannot be used with implicit usage of -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips64-mti-elf -fno-PIE -mabicalls %s 2>&1 | FileCheck -check-prefix=CHECK-PIE2-EXPLICIT %s
|
||||
// CHECK-PIE2-EXPLICIT: warning: ignoring '-fno-PIE' option as it cannot be used with -mabicalls and the N64 ABI
|
||||
|
||||
// RUN: %clang -### -c -target mips-mti-elf -mlong-calls %s 2>&1 | FileCheck -check-prefix=LONGCALL-IMP %s
|
||||
// LONGCALL-IMP: warning: ignoring '-mlong-calls' option as it is not currently supported with the implicit usage of -mabicalls
|
||||
|
|
|
@ -21,7 +21,7 @@
|
|||
// MIPS32R2-DEF-EL-AS: as{{(.exe)?}}" "-march" "mips32r2" "-mabi" "32" "-mno-shared" "-call_nonpic" "-EL"
|
||||
//
|
||||
// RUN: %clang -target mips64-linux-gnu -### \
|
||||
// RUN: -no-integrated-as -fno-pic -c %s 2>&1 \
|
||||
// RUN: -no-integrated-as -fno-pic -mno-abicalls -c %s 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS64R2-EB-AS %s
|
||||
// MIPS64R2-EB-AS: as{{(.exe)?}}" "-march" "mips64r2" "-mabi" "64" "-mno-shared" "-EB"
|
||||
//
|
||||
|
@ -31,7 +31,7 @@
|
|||
// MIPS64R2-EB-AS-PIC: as{{(.exe)?}}" "-march" "mips64r2" "-mabi" "64" "-EB" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64el-linux-gnu -### \
|
||||
// RUN: -no-integrated-as -c -fno-pic %s 2>&1 \
|
||||
// RUN: -no-integrated-as -c -fno-pic -mno-abicalls %s 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS64R2-DEF-EL-AS %s
|
||||
// MIPS64R2-DEF-EL-AS: as{{(.exe)?}}" "-march" "mips64r2" "-mabi" "64" "-mno-shared" "-EL"
|
||||
//
|
||||
|
@ -64,7 +64,7 @@
|
|||
// MIPS64R2-EL-AS-PIC: as{{(.exe)?}}" "-march" "mips64r2" "-mabi" "64" "-EL" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64el-linux-gnu -mabi=64 -### \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic 2>&1 \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic -mno-abicalls 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS64R2-EL-AS %s
|
||||
// MIPS64R2-EL-AS: as{{(.exe)?}}" "-march" "mips64r2" "-mabi" "64" "-mno-shared" "-EL"
|
||||
//
|
||||
|
@ -84,7 +84,7 @@
|
|||
// MIPS-OCTEON-PIC: as{{(.exe)?}}" "-march" "octeon" "-mabi" "64" "-EB" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64-linux-gnu -march=octeon -### \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic 2>&1 \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic -mno-abicalls 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS-OCTEON %s
|
||||
// MIPS-OCTEON: as{{(.exe)?}}" "-march" "octeon" "-mabi" "64" "-mno-shared" "-EB"
|
||||
//
|
||||
|
@ -144,7 +144,7 @@
|
|||
// MIPS-ALIAS-64-PIC: as{{(.exe)?}}" "-march" "mips64" "-mabi" "64" "-EB" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64-linux-gnu -mips64 -### \
|
||||
// RUN: -no-integrated-as -c -fno-pic %s 2>&1 \
|
||||
// RUN: -no-integrated-as -c -fno-pic -mno-abicalls %s 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS-ALIAS-64 %s
|
||||
// MIPS-ALIAS-64: as{{(.exe)?}}" "-march" "mips64" "-mabi" "64" "-mno-shared" "-EB"
|
||||
//
|
||||
|
@ -159,7 +159,7 @@
|
|||
// MIPS-ALIAS-64R3-PIC: as{{(.exe)?}}" "-march" "mips64r3" "-mabi" "64" "-EB" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64-linux-gnu -mips64r3 -### \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic 2>&1 \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic -mno-abicalls 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS-ALIAS-64R3 %s
|
||||
// MIPS-ALIAS-64R3: as{{(.exe)?}}" "-march" "mips64r3" "-mabi" "64" "-mno-shared" "-EB"
|
||||
//
|
||||
|
@ -169,7 +169,7 @@
|
|||
// MIPS-ALIAS-64R5-PIC: as{{(.exe)?}}" "-march" "mips64r5" "-mabi" "64" "-EB" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64-linux-gnu -mips64r5 -### \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic 2>&1 \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic -mno-abicalls 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS-ALIAS-64R5 %s
|
||||
// MIPS-ALIAS-64R5: as{{(.exe)?}}" "-march" "mips64r5" "-mabi" "64" "-mno-shared" "-EB"
|
||||
//
|
||||
|
@ -179,7 +179,7 @@
|
|||
// MIPS-ALIAS-64R6-PIC: as{{(.exe)?}}" "-march" "mips64r6" "-mabi" "64" "-EB" "-KPIC"
|
||||
//
|
||||
// RUN: %clang -target mips64-linux-gnu -mips64r6 -### \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic 2>&1 \
|
||||
// RUN: -no-integrated-as -c %s -fno-pic -mno-abicalls 2>&1 \
|
||||
// RUN: | FileCheck -check-prefix=MIPS-ALIAS-64R6 %s
|
||||
// MIPS-ALIAS-64R6: as{{(.exe)?}}" "-march" "mips64r6" "-mabi" "64" "-mno-shared" "-EB"
|
||||
//
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
// CHECK-MNOABICALLS: "-target-feature" "+noabicalls"
|
||||
//
|
||||
// -mno-abicalls non-PIC N64
|
||||
// RUN: %clang -target mips64-linux-gnu -### -c -fno-PIC %s 2>&1 \
|
||||
// RUN: %clang -target mips64-linux-gnu -### -c -fno-PIC -mno-abicalls %s 2>&1 \
|
||||
// RUN: | FileCheck --check-prefix=CHECK-MNOABICALLS-N64NPIC %s
|
||||
// CHECK-MNOABICALLS-N64NPIC: "-target-feature" "+noabicalls"
|
||||
//
|
||||
|
@ -86,13 +86,13 @@
|
|||
// CHECK-MEMBEDDEDDATADEF-NOT: "-mllvm" "-membedded-data"
|
||||
//
|
||||
// MIPS64 + N64: -fno-pic -> -mno-abicalls -mgpopt
|
||||
// RUN: %clang -target mips64-mti-elf -mabi=64 -### -c %s -fno-pic 2>&1 \
|
||||
// RUN: %clang -target mips64-mti-elf -mabi=64 -### -c %s -fno-pic -mno-abicalls 2>&1 \
|
||||
// RUN: | FileCheck --check-prefix=CHECK-N64-GPOPT %s
|
||||
// CHECK-N64-GPOPT: "-target-feature" "+noabicalls"
|
||||
// CHECK-N64-GPOPT: "-mllvm" "-mgpopt"
|
||||
//
|
||||
// MIPS64 + N64: -fno-pic -mno-gpopt
|
||||
// RUN: %clang -target mips64-mti-elf -mabi=64 -### -c %s -fno-pic -mno-gpopt 2>&1 \
|
||||
// RUN: %clang -target mips64-mti-elf -mabi=64 -### -c %s -fno-pic -mno-abicalls -mno-gpopt 2>&1 \
|
||||
// RUN: | FileCheck --check-prefix=CHECK-N64-MNO-GPOPT %s
|
||||
// CHECK-N64-MNO-GPOPT: "-target-feature" "+noabicalls"
|
||||
// CHECK-N64-MNO-GPOPT-NOT: "-mllvm" "-mgpopt"
|
||||
|
|
Loading…
Reference in New Issue