[llvm] r293433 - ARM: support `-mlong-calls` with AEABI TLS on ELF

Hans Wennborg via llvm-commits llvm-commits at lists.llvm.org
Mon Feb 6 14:39:23 PST 2017


Renato, Tim: What do you think about merging this to 4.0?

On Sun, Jan 29, 2017 at 8:46 AM, Saleem Abdulrasool via llvm-commits
<llvm-commits at lists.llvm.org> wrote:
> Author: compnerd
> Date: Sun Jan 29 10:46:22 2017
> New Revision: 293433
>
> URL: http://llvm.org/viewvc/llvm-project?rev=293433&view=rev
> Log:
> ARM: support `-mlong-calls` with AEABI TLS on ELF
>
> Support lowering AEABI TLS access (__aeabi_read_tp) with long calls.
> This requires adjusting the call sequence to use an indirect call to get
> full addressability.
>
> Resolves PR31769!
>
> Added:
>     llvm/trunk/test/CodeGen/ARM/aeabi-read-tp.ll
> Modified:
>     llvm/trunk/lib/Target/ARM/ARMExpandPseudoInsts.cpp
>
> Modified: llvm/trunk/lib/Target/ARM/ARMExpandPseudoInsts.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/ARMExpandPseudoInsts.cpp?rev=293433&r1=293432&r2=293433&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/ARM/ARMExpandPseudoInsts.cpp (original)
> +++ llvm/trunk/lib/Target/ARM/ARMExpandPseudoInsts.cpp Sun Jan 29 10:46:22 2017
> @@ -1231,15 +1231,36 @@ bool ARMExpandPseudo::ExpandMI(MachineBa
>      }
>      case ARM::tTPsoft:
>      case ARM::TPsoft: {
> +      const bool Thumb = Opcode == ARM::tTPsoft;
> +
>        MachineInstrBuilder MIB;
> -      if (Opcode == ARM::tTPsoft)
> -        MIB = BuildMI(MBB, MBBI, MI.getDebugLoc(), TII->get(ARM::tBL))
> -                  .add(predOps(ARMCC::AL))
> -                  .addExternalSymbol("__aeabi_read_tp", 0);
> -      else
> +      if (STI->genLongCalls()) {
> +        MachineFunction *MF = MBB.getParent();
> +        MachineConstantPool *MCP = MF->getConstantPool();
> +        unsigned PCLabelID = AFI->createPICLabelUId();
> +        MachineConstantPoolValue *CPV =
> +            ARMConstantPoolSymbol::Create(MF->getFunction()->getContext(),
> +                                          "__aeabi_read_tp", PCLabelID, 0);
> +        unsigned Reg = MI.getOperand(0).getReg();
> +        MIB = BuildMI(MBB, MBBI, MI.getDebugLoc(),
> +                      TII->get(Thumb ? ARM::tLDRpci : ARM::LDRi12), Reg)
> +                  .addConstantPoolIndex(MCP->getConstantPoolIndex(CPV, 4));
> +        if (!Thumb)
> +          MIB.addImm(0);
> +        MIB.add(predOps(ARMCC::AL));
> +
> +        MIB = BuildMI(MBB, MBBI, MI.getDebugLoc(),
> +                      TII->get(Thumb ? ARM::tBLXr : ARM::BLX));
> +        if (Thumb)
> +          MIB.add(predOps(ARMCC::AL));
> +        MIB.addReg(Reg, RegState::Kill);
> +      } else {
>          MIB = BuildMI(MBB, MBBI, MI.getDebugLoc(),
> -                      TII->get( ARM::BL))
> -              .addExternalSymbol("__aeabi_read_tp", 0);
> +                      TII->get(Thumb ? ARM::tBL : ARM::BL));
> +        if (Thumb)
> +          MIB.add(predOps(ARMCC::AL));
> +        MIB.addExternalSymbol("__aeabi_read_tp", 0);
> +      }
>
>        MIB->setMemRefs(MI.memoperands_begin(), MI.memoperands_end());
>        TransferImpOps(MI, MIB, MIB);
>
> Added: llvm/trunk/test/CodeGen/ARM/aeabi-read-tp.ll
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/ARM/aeabi-read-tp.ll?rev=293433&view=auto
> ==============================================================================
> --- llvm/trunk/test/CodeGen/ARM/aeabi-read-tp.ll (added)
> +++ llvm/trunk/test/CodeGen/ARM/aeabi-read-tp.ll Sun Jan 29 10:46:22 2017
> @@ -0,0 +1,26 @@
> +; RUN: llc -mtriple armv7---eabi -filetype asm -o - %s | FileCheck %s -check-prefix CHECK -check-prefix CHECK-SHORT
> +; RUN: llc -mtriple thumbv7---eabi -filetype asm -o - %s | FileCheck %s -check-prefix CHECK -check-prefix CHECK-SHORT
> +; RUN: llc -mtriple armv7---eabi -mattr=+long-calls -filetype asm -o - %s | FileCheck %s -check-prefix CHECK -check-prefix CHECK-LONG
> +; RUN: llc -mtriple thumbv7---eabi -mattr=+long-calls -filetype asm -o - %s | FileCheck %s -check-prefix CHECK -check-prefix CHECK-LONG
> +
> + at i = thread_local local_unnamed_addr global i32 0, align 4
> +
> +define i32 @f() local_unnamed_addr {
> +entry:
> +  %0 = load i32, i32* @i, align 4
> +  ret i32 %0
> +}
> +
> +; CHECK-LABEL: f:
> +; CHECK-SHORT: ldr r1, [[VAR:.LCPI[0-9]+_[0-9]+]]
> +; CHECK-SHORT-NEXT: bl __aeabi_read_tp
> +; CHECK-SHORT: [[VAR]]:
> +; CHECK-SHORT-NEXT: .long i(TPOFF)
> +
> +; CHECK-LONG: ldr [[REG:r[0-9]+]], [[FUN:.LCPI[0-9]+_[0-9]+]]
> +; CHECK-LONG-NEXT: ldr r1, [[VAR:.LCPI[0-9]+_[0-9]+]]
> +; CHECK-LONG-NEXT: blx [[REG]]
> +; CHECK-LONG: [[VAR]]:
> +; CHECK-LONG-NEXT: .long i(TPOFF)
> +; CHECK-LONG: [[FUN]]:
> +; CHECK-LONG-NEXT: .long __aeabi_read_tp
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits


More information about the llvm-commits mailing list