Add support for target-specific 32-bit custom-lowered

jump table entries.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94505 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2010-01-26 04:05:28 +00:00
parent c690aab230
commit 85fe07866a
5 changed files with 25 additions and 7 deletions

View File

@ -60,7 +60,11 @@ public:
/// If the .set directive is supported, this is emitted as: /// If the .set directive is supported, this is emitted as:
/// .set L4_5_set_123, LBB123 - LJTI1_2 /// .set L4_5_set_123, LBB123 - LJTI1_2
/// .word L4_5_set_123 /// .word L4_5_set_123
EK_LabelDifference32 EK_LabelDifference32,
/// EK_Custom32 - Each entry is a 32-bit value that is custom lowered by the
/// TargetLowering::LowerCustomJumpTableEntry hook.
EK_Custom32
}; };
private: private:
JTEntryKind EntryKind; JTEntryKind EntryKind;

View File

@ -46,7 +46,10 @@ namespace llvm {
class MachineFunction; class MachineFunction;
class MachineFrameInfo; class MachineFrameInfo;
class MachineInstr; class MachineInstr;
class MachineJumpTableInfo;
class MachineModuleInfo; class MachineModuleInfo;
class MCContext;
class MCExpr;
class DwarfWriter; class DwarfWriter;
class SDNode; class SDNode;
class SDValue; class SDValue;
@ -757,10 +760,17 @@ public:
/// MachineJumpTableInfo::JTEntryKind enum. /// MachineJumpTableInfo::JTEntryKind enum.
virtual unsigned getJumpTableEncoding() const; virtual unsigned getJumpTableEncoding() const;
virtual const MCExpr *
LowerCustomJumpTableEntry(const MachineJumpTableInfo *MJTI,
const MachineBasicBlock *MBB, unsigned uid,
MCContext &Ctx) {
assert(0 && "Need to implement this hook if target has custom JTIs");
}
/// getPICJumpTableRelocaBase - Returns relocation base for the given PIC /// getPICJumpTableRelocaBase - Returns relocation base for the given PIC
/// jumptable. /// jumptable.
virtual SDValue getPICJumpTableRelocBase(SDValue Table, virtual SDValue getPICJumpTableRelocBase(SDValue Table,
SelectionDAG &DAG) const; SelectionDAG &DAG) const;
/// isOffsetFoldingLegal - Return true if folding a constant offset /// isOffsetFoldingLegal - Return true if folding a constant offset
/// with the given GlobalAddress is legal. It is frequently not legal in /// with the given GlobalAddress is legal. It is frequently not legal in

View File

@ -479,12 +479,10 @@ void AsmPrinter::EmitJumpTableInfo(MachineFunction &MF) {
// Pick the directive to use to print the jump table entries, and switch to // Pick the directive to use to print the jump table entries, and switch to
// the appropriate section. // the appropriate section.
TargetLowering *LoweringInfo = TM.getTargetLowering();
const Function *F = MF.getFunction(); const Function *F = MF.getFunction();
bool JTInDiffSection = false; bool JTInDiffSection = false;
if (F->isWeakForLinker() || if (F->isWeakForLinker() ||
(IsPic && !LoweringInfo->usesGlobalOffsetTable())) { (IsPic && !TM.getTargetLowering()->usesGlobalOffsetTable())) {
// In PIC mode, we need to emit the jump table to the same section as the // In PIC mode, we need to emit the jump table to the same section as the
// function body itself, otherwise the label differences won't make sense. // function body itself, otherwise the label differences won't make sense.
// We should also do if the section name is NULL or function is declared in // We should also do if the section name is NULL or function is declared in
@ -546,12 +544,15 @@ void AsmPrinter::printPICJumpTableEntry(const MachineJumpTableInfo *MJTI,
unsigned uid) const { unsigned uid) const {
const MCExpr *Value = 0; const MCExpr *Value = 0;
switch (MJTI->getEntryKind()) { switch (MJTI->getEntryKind()) {
case MachineJumpTableInfo::EK_Custom32:
Value = TM.getTargetLowering()->LowerCustomJumpTableEntry(MJTI, MBB, uid,
OutContext);
break;
case MachineJumpTableInfo::EK_BlockAddress: case MachineJumpTableInfo::EK_BlockAddress:
// EK_BlockAddress - Each entry is a plain address of block, e.g.: // EK_BlockAddress - Each entry is a plain address of block, e.g.:
// .word LBB123 // .word LBB123
Value = MCSymbolRefExpr::Create(GetMBBSymbol(MBB->getNumber()), OutContext); Value = MCSymbolRefExpr::Create(GetMBBSymbol(MBB->getNumber()), OutContext);
break; break;
case MachineJumpTableInfo::EK_GPRel32BlockAddress: { case MachineJumpTableInfo::EK_GPRel32BlockAddress: {
// EK_GPRel32BlockAddress - Each entry is an address of block, encoded // EK_GPRel32BlockAddress - Each entry is an address of block, encoded
// with a relocation as gp-relative, e.g.: // with a relocation as gp-relative, e.g.:
@ -560,7 +561,7 @@ void AsmPrinter::printPICJumpTableEntry(const MachineJumpTableInfo *MJTI,
OutStreamer.EmitGPRel32Value(MCSymbolRefExpr::Create(MBBSym, OutContext)); OutStreamer.EmitGPRel32Value(MCSymbolRefExpr::Create(MBBSym, OutContext));
return; return;
} }
case MachineJumpTableInfo::EK_LabelDifference32: { case MachineJumpTableInfo::EK_LabelDifference32: {
// EK_LabelDifference32 - Each entry is the address of the block minus // EK_LabelDifference32 - Each entry is the address of the block minus
// the address of the jump table. This is used for PIC jump tables where // the address of the jump table. This is used for PIC jump tables where

View File

@ -544,6 +544,7 @@ unsigned MachineJumpTableInfo::getEntrySize(const TargetData &TD) const {
return TD.getPointerSize(); return TD.getPointerSize();
case MachineJumpTableInfo::EK_GPRel32BlockAddress: case MachineJumpTableInfo::EK_GPRel32BlockAddress:
case MachineJumpTableInfo::EK_LabelDifference32: case MachineJumpTableInfo::EK_LabelDifference32:
case MachineJumpTableInfo::EK_Custom32:
return 4; return 4;
} }
assert(0 && "Unknown jump table encoding!"); assert(0 && "Unknown jump table encoding!");
@ -560,6 +561,7 @@ unsigned MachineJumpTableInfo::getEntryAlignment(const TargetData &TD) const {
return TD.getPointerABIAlignment(); return TD.getPointerABIAlignment();
case MachineJumpTableInfo::EK_GPRel32BlockAddress: case MachineJumpTableInfo::EK_GPRel32BlockAddress:
case MachineJumpTableInfo::EK_LabelDifference32: case MachineJumpTableInfo::EK_LabelDifference32:
case MachineJumpTableInfo::EK_Custom32:
return TD.getABIIntegerTypeAlignment(32); return TD.getABIIntegerTypeAlignment(32);
} }
assert(0 && "Unknown jump table encoding!"); assert(0 && "Unknown jump table encoding!");

View File

@ -1445,6 +1445,7 @@ void JITEmitter::emitJumpTableInfo(MachineJumpTableInfo *MJTI) {
break; break;
} }
case MachineJumpTableInfo::EK_Custom32:
case MachineJumpTableInfo::EK_GPRel32BlockAddress: case MachineJumpTableInfo::EK_GPRel32BlockAddress:
case MachineJumpTableInfo::EK_LabelDifference32: { case MachineJumpTableInfo::EK_LabelDifference32: {
assert(MJTI->getEntrySize(*TheJIT->getTargetData()) == 4&&"Cross JIT'ing?"); assert(MJTI->getEntrySize(*TheJIT->getTargetData()) == 4&&"Cross JIT'ing?");