diff options
| -rw-r--r-- | llvm/lib/Target/Mips/MipsAsmPrinter.cpp | 15 | ||||
| -rw-r--r-- | llvm/test/CodeGen/Mips/abicalls.ll | 1 | 
2 files changed, 12 insertions, 4 deletions
| diff --git a/llvm/lib/Target/Mips/MipsAsmPrinter.cpp b/llvm/lib/Target/Mips/MipsAsmPrinter.cpp index a3d34f64635..c9b56aa6352 100644 --- a/llvm/lib/Target/Mips/MipsAsmPrinter.cpp +++ b/llvm/lib/Target/Mips/MipsAsmPrinter.cpp @@ -620,10 +620,17 @@ printFCCOperand(const MachineInstr *MI, int opNum, raw_ostream &O,  void MipsAsmPrinter::EmitStartOfAsmFile(Module &M) {    // TODO: Need to add -mabicalls and -mno-abicalls flags.    // Currently we assume that -mabicalls is the default. -  getTargetStreamer().emitDirectiveAbiCalls(); -  Reloc::Model RM = Subtarget->getRelocationModel(); -  if (RM == Reloc::Static && !Subtarget->hasMips64()) -    getTargetStreamer().emitDirectiveOptionPic0(); +  bool IsABICalls = true; +  if (IsABICalls) { +    getTargetStreamer().emitDirectiveAbiCalls(); +    Reloc::Model RM = Subtarget->getRelocationModel(); +    // FIXME: This condition should be a lot more complicated that it is here. +    //        Ideally it should test for properties of the ABI and not the ABI +    //        itself. +    //        For the moment, I'm only correcting enough to make MIPS-IV work. +    if (RM == Reloc::Static && !Subtarget->isABI_N64()) +      getTargetStreamer().emitDirectiveOptionPic0(); +  }    // Tell the assembler which ABI we are using    std::string SectionName = std::string(".mdebug.") + getCurrentABIString(); diff --git a/llvm/test/CodeGen/Mips/abicalls.ll b/llvm/test/CodeGen/Mips/abicalls.ll index 7b98b02d05a..6fa33aa158a 100644 --- a/llvm/test/CodeGen/Mips/abicalls.ll +++ b/llvm/test/CodeGen/Mips/abicalls.ll @@ -7,6 +7,7 @@  ; RUN: llc -filetype=asm -mtriple mipsel-unknown-linux -mcpu=mips32 -relocation-model=static %s -o - | FileCheck -check-prefix=CHECK-STATIC %s  ; RUN: llc -filetype=asm -mtriple mipsel-unknown-linux -mcpu=mips32 %s -o - | FileCheck -check-prefix=CHECK-PIC %s +; RUN: llc -filetype=asm -mtriple mips64el-unknown-linux -mcpu=mips4 -relocation-model=static %s -o - | FileCheck -check-prefix=CHECK-PIC %s  ; RUN: llc -filetype=asm -mtriple mips64el-unknown-linux -mcpu=mips64 -relocation-model=static %s -o - | FileCheck -check-prefix=CHECK-PIC %s  ; CHECK-STATIC: .abicalls | 

