From: Krzysztof Parzyszek Date: Thu, 2 Feb 2017 20:35:12 +0000 (+0000) Subject: [Hexagon] Adding opExtentBits and opExtentAlign to GPrel instructions X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e14e1120edbcabf41657228b4cdd836bc3cd6c4a;p=llvm [Hexagon] Adding opExtentBits and opExtentAlign to GPrel instructions Patch by Colin LeMahieu. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@293933 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp b/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp index becc086c81b..b6201ebf038 100644 --- a/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp +++ b/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp @@ -1756,8 +1756,8 @@ int HexagonAsmParser::processInstruction(MCInst &Inst, TmpInst.setOpcode(Hexagon::L2_loadrdgp); TmpInst.addOperand(MO_0); - TmpInst.addOperand( - MCOperand::createExpr(MCSymbolRefExpr::create(Sym, getContext()))); + TmpInst.addOperand(MCOperand::createExpr(HexagonMCExpr::create( + MCSymbolRefExpr::create(Sym, getContext()), getContext()))); Inst = TmpInst; } } diff --git a/lib/Target/Hexagon/HexagonInstrInfoV4.td b/lib/Target/Hexagon/HexagonInstrInfoV4.td index 500f5f340f9..85d57baecd8 100644 --- a/lib/Target/Hexagon/HexagonInstrInfoV4.td +++ b/lib/Target/Hexagon/HexagonInstrInfoV4.td @@ -2543,6 +2543,14 @@ class T_StoreAbsGP MajOp> !if (!eq(ImmOpStr, "u16_2Imm"), addr{17-2}, !if (!eq(ImmOpStr, "u16_1Imm"), addr{16-1}, /* u16_0Imm */ addr{15-0}))); + let opExtentBits = !if (!eq(ImmOpStr, "u16_3Imm"), 19, + !if (!eq(ImmOpStr, "u16_2Imm"), 18, + !if (!eq(ImmOpStr, "u16_1Imm"), 17, + /* u16_0Imm */ 16))); + let opExtentAlign = !if (!eq(ImmOpStr, "u16_3Imm"), 3, + !if (!eq(ImmOpStr, "u16_2Imm"), 2, + !if (!eq(ImmOpStr, "u16_1Imm"), 1, + /* u16_0Imm */ 0))); let IClass = 0b0100; let Inst{27} = 1; @@ -2822,6 +2838,14 @@ class T_LoadAbsGP (Expr); return HExpr.mustNotExtend(); } +void HexagonMCInstrInfo::setS23_2_reloc(MCExpr const &Expr, bool Val) { + HexagonMCExpr &HExpr = + const_cast(*llvm::cast(&Expr)); + HExpr.setS23_2_reloc(Val); +} +bool HexagonMCInstrInfo::s23_2_reloc(MCExpr const &Expr) { + HexagonMCExpr const *HExpr = llvm::dyn_cast(&Expr); + if (!HExpr) + return false; + return HExpr->s23_2_reloc(); +} void HexagonMCInstrInfo::padEndloop(MCContext &Context, MCInst &MCB) { MCInst Nop; @@ -772,15 +783,6 @@ void HexagonMCInstrInfo::setMemStoreReorderEnabled(MCInst &MCI) { Operand.setImm(Operand.getImm() | memStoreReorderEnabledMask); assert(isMemStoreReorderEnabled(MCI)); } -void HexagonMCInstrInfo::setS23_2_reloc(MCExpr const &Expr, bool Val) { - HexagonMCExpr &HExpr = - const_cast(*llvm::cast(&Expr)); - HExpr.setS23_2_reloc(Val); -} -bool HexagonMCInstrInfo::s23_2_reloc(MCExpr const &Expr) { - HexagonMCExpr const &HExpr = *llvm::cast(&Expr); - return HExpr.s23_2_reloc(); -} void HexagonMCInstrInfo::setOuterLoop(MCInst &MCI) { assert(isBundle(MCI)); diff --git a/test/MC/Hexagon/relocations.s b/test/MC/Hexagon/relocations.s index 8b90bc7c0cd..d52c37a66cc 100644 --- a/test/MC/Hexagon/relocations.s +++ b/test/MC/Hexagon/relocations.s @@ -30,19 +30,19 @@ r_hex_8: # CHECK: R_HEX_GPREL16_0 r_hex_gprel16_0: -{ r0 = memb (#undefined@gotrel) } +{ r0 = memb (gp+#undefined) } # CHECK: R_HEX_GPREL16_1 r_hex_gprel16_1: -{ r0 = memh (#undefined@gotrel) } +{ r0 = memh (gp+#undefined) } # CHECK: R_HEX_GPREL16_2 r_hex_gprel16_2: -{ r0 = memw (#undefined@gotrel) } +{ r0 = memw (gp+#undefined) } # CHECK: R_HEX_GPREL16_3 r_hex_gprel16_3: -{ r1:0 = memd (#undefined@gotrel) } +{ r1:0 = memd (gp+#undefined) } # CHECK: R_HEX_B13_PCREL r_hex_b13_pcrel: