From 1aca2492526c0a1aa464f2993084f9b30b53c009 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 25 Jan 2010 21:22:22 +0000 Subject: [PATCH] mcize the non-gprel cases of AsmPrinter::printPICJumpTableEntry git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94450 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index a0048e17dbf..d75210d0723 100644 --- a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -525,6 +525,8 @@ void AsmPrinter::EmitJumpTableInfo(MachineJumpTableInfo *MJTI, OutStreamer.EmitLabel(GetJTISymbol(i)); if (!IsPic) { + // In non-pic mode, the entries in the jump table are direct references + // to the basic blocks. unsigned EntrySize = MJTI->getEntrySize(); for (unsigned ii = 0, ee = JTBBs.size(); ii != ee; ++ii) { MCSymbol *MBBSym = GetMBBSymbol(JTBBs[ii]->getNumber()); @@ -546,25 +548,23 @@ void AsmPrinter::printPICJumpTableEntry(const MachineJumpTableInfo *MJTI, O << GPRel32Dir << *GetMBBSymbol(MBB->getNumber()) << '\n'; return; } - - const char *JTEntryDirective = MJTI->getEntrySize() == 4 ? - MAI->getData32bitsDirective() : MAI->getData64bitsDirective(); - O << JTEntryDirective << ' '; - + // If we have emitted set directives for the jump table entries, print // them rather than the entries themselves. If we're emitting PIC, then // emit the table entries as differences between two text section labels. - // If we're emitting non-PIC code, then emit the entries as direct - // references to the target basic blocks. + const MCExpr *Val; if (MAI->getSetDirective()) { - O << *GetJTSetSymbol(uid, MBB->getNumber()); + // If we used .set, reference the .set's symbol. + Val = MCSymbolRefExpr::Create(GetJTSetSymbol(uid, MBB->getNumber()), + OutContext); } else { - O << *GetMBBSymbol(MBB->getNumber()); - // If the arch uses custom Jump Table directives, don't calc relative to - // JT. - O << '-' << *GetJTISymbol(uid); + // Otherwise, use the difference as the jump table entry. + Val = MCSymbolRefExpr::Create(GetMBBSymbol(MBB->getNumber()), OutContext); + const MCExpr *JTI = MCSymbolRefExpr::Create(GetJTISymbol(uid), OutContext); + Val = MCBinaryExpr::CreateSub(Val, JTI, OutContext); } - O << '\n'; + + OutStreamer.EmitValue(Val, MJTI->getEntrySize(), /*addrspace*/0); }