diff options
Diffstat (limited to 'contrib/llvm/patches/patch-27-llvm-r222587-arm-add-pc.diff')
-rw-r--r-- | contrib/llvm/patches/patch-27-llvm-r222587-arm-add-pc.diff | 108 |
1 files changed, 0 insertions, 108 deletions
diff --git a/contrib/llvm/patches/patch-27-llvm-r222587-arm-add-pc.diff b/contrib/llvm/patches/patch-27-llvm-r222587-arm-add-pc.diff deleted file mode 100644 index 46b2a04..0000000 --- a/contrib/llvm/patches/patch-27-llvm-r222587-arm-add-pc.diff +++ /dev/null @@ -1,108 +0,0 @@ -Pull in r222587 from upstream llvm trunk (by Jörg Sonnenberger): - - Fix transformation of add with pc argument to adr for non-immediate - arguments. - -This fixes an "Unimplemented" error when assembling certain ARM add -instructions with pc-relative arguments. - -Reported by: sbruno -PR: 196412, 196423 - -Introduced here: http://svnweb.freebsd.org/changeset/base/276537 - -Index: lib/Target/ARM/AsmParser/ARMAsmParser.cpp -=================================================================== ---- lib/Target/ARM/AsmParser/ARMAsmParser.cpp -+++ lib/Target/ARM/AsmParser/ARMAsmParser.cpp -@@ -314,7 +314,7 @@ class ARMAsmParser : public MCTargetAsmParser { - void cvtThumbBranches(MCInst &Inst, const OperandVector &); - - bool validateInstruction(MCInst &Inst, const OperandVector &Ops); -- bool processInstruction(MCInst &Inst, const OperandVector &Ops); -+ bool processInstruction(MCInst &Inst, const OperandVector &Ops, MCStreamer &Out); - bool shouldOmitCCOutOperand(StringRef Mnemonic, OperandVector &Operands); - bool shouldOmitPredicateOperand(StringRef Mnemonic, OperandVector &Operands); - -@@ -6175,7 +6175,8 @@ static unsigned getRealVLDOpcode(unsigned Opc, uns - } - - bool ARMAsmParser::processInstruction(MCInst &Inst, -- const OperandVector &Operands) { -+ const OperandVector &Operands, -+ MCStreamer &Out) { - switch (Inst.getOpcode()) { - // Alias for alternate form of 'ldr{,b}t Rt, [Rn], #imm' instruction. - case ARM::LDRT_POST: -@@ -6216,12 +6217,31 @@ bool ARMAsmParser::processInstruction(MCInst &Inst - // Alias for alternate form of 'ADR Rd, #imm' instruction. - case ARM::ADDri: { - if (Inst.getOperand(1).getReg() != ARM::PC || -- Inst.getOperand(5).getReg() != 0) -+ Inst.getOperand(5).getReg() != 0 || -+ !(Inst.getOperand(2).isExpr() || Inst.getOperand(2).isImm())) - return false; - MCInst TmpInst; - TmpInst.setOpcode(ARM::ADR); - TmpInst.addOperand(Inst.getOperand(0)); -- TmpInst.addOperand(Inst.getOperand(2)); -+ if (Inst.getOperand(2).isImm()) { -+ TmpInst.addOperand(Inst.getOperand(2)); -+ } else { -+ // Turn PC-relative expression into absolute expression. -+ // Reading PC provides the start of the current instruction + 8 and -+ // the transform to adr is biased by that. -+ MCSymbol *Dot = getContext().CreateTempSymbol(); -+ Out.EmitLabel(Dot); -+ const MCExpr *OpExpr = Inst.getOperand(2).getExpr(); -+ const MCExpr *InstPC = MCSymbolRefExpr::Create(Dot, -+ MCSymbolRefExpr::VK_None, -+ getContext()); -+ const MCExpr *Const8 = MCConstantExpr::Create(8, getContext()); -+ const MCExpr *ReadPC = MCBinaryExpr::CreateAdd(InstPC, Const8, -+ getContext()); -+ const MCExpr *FixupAddr = MCBinaryExpr::CreateAdd(ReadPC, OpExpr, -+ getContext()); -+ TmpInst.addOperand(MCOperand::CreateExpr(FixupAddr)); -+ } - TmpInst.addOperand(Inst.getOperand(3)); - TmpInst.addOperand(Inst.getOperand(4)); - Inst = TmpInst; -@@ -8061,7 +8081,7 @@ bool ARMAsmParser::MatchAndEmitInstruction(SMLoc I - // encoding is selected. Loop on it while changes happen so the - // individual transformations can chain off each other. E.g., - // tPOP(r8)->t2LDMIA_UPD(sp,r8)->t2STR_POST(sp,r8) -- while (processInstruction(Inst, Operands)) -+ while (processInstruction(Inst, Operands, Out)) - ; - - // Only after the instruction is fully processed, we can validate it -Index: test/MC/ARM/basic-arm-instructions.s -=================================================================== ---- test/MC/ARM/basic-arm-instructions.s -+++ test/MC/ARM/basic-arm-instructions.s -@@ -191,8 +191,10 @@ Lforward: - - add r0, #-4 - add r4, r5, #-21 -- add r0, pc, #0xc0000000 -+ add r0, pc, #0xc0000000 - -+ add r0, pc, #(Lback - .) -+ - @ CHECK: add r4, r5, #61440 @ encoding: [0x0f,0x4a,0x85,0xe2] - @ CHECK: add r4, r5, r6 @ encoding: [0x06,0x40,0x85,0xe0] - @ CHECK: add r4, r5, r6, lsl #5 @ encoding: [0x86,0x42,0x85,0xe0] -@@ -222,7 +224,11 @@ Lforward: - - @ CHECK: sub r0, r0, #4 @ encoding: [0x04,0x00,0x40,0xe2] - @ CHECK: sub r4, r5, #21 @ encoding: [0x15,0x40,0x45,0xe2] --@ CHECK: adr r0, #-1073741824 @ encoding: [0x03,0x01,0x8f,0xe2] -+@ CHECK: adr r0, #-1073741824 @ encoding: [0x03,0x01,0x8f,0xe2] -+@ CHECK: Ltmp0: -+@ CHECK-NEXT: Ltmp1: -+@ CHECK-NEXT: adr r0, (Ltmp1+8)+(Lback-Ltmp0) @ encoding: [A,A,0x0f'A',0xe2'A'] -+@ CHECK-NEXT: @ fixup A - offset: 0, value: (Ltmp1+8)+(Lback-Ltmp0), kind: fixup_arm_adr_pcrel_12 - - @ Test right shift by 32, which is encoded as 0 - add r3, r1, r2, lsr #32 |