mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-14 07:31:53 +00:00
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:
parent
c690aab230
commit
85fe07866a
@ -60,7 +60,11 @@ public:
|
||||
/// If the .set directive is supported, this is emitted as:
|
||||
/// .set L4_5_set_123, LBB123 - LJTI1_2
|
||||
/// .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:
|
||||
JTEntryKind EntryKind;
|
||||
|
@ -46,7 +46,10 @@ namespace llvm {
|
||||
class MachineFunction;
|
||||
class MachineFrameInfo;
|
||||
class MachineInstr;
|
||||
class MachineJumpTableInfo;
|
||||
class MachineModuleInfo;
|
||||
class MCContext;
|
||||
class MCExpr;
|
||||
class DwarfWriter;
|
||||
class SDNode;
|
||||
class SDValue;
|
||||
@ -757,10 +760,17 @@ public:
|
||||
/// MachineJumpTableInfo::JTEntryKind enum.
|
||||
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
|
||||
/// jumptable.
|
||||
virtual SDValue getPICJumpTableRelocBase(SDValue Table,
|
||||
SelectionDAG &DAG) const;
|
||||
SelectionDAG &DAG) const;
|
||||
|
||||
/// isOffsetFoldingLegal - Return true if folding a constant offset
|
||||
/// with the given GlobalAddress is legal. It is frequently not legal in
|
||||
|
@ -479,12 +479,10 @@ void AsmPrinter::EmitJumpTableInfo(MachineFunction &MF) {
|
||||
|
||||
// Pick the directive to use to print the jump table entries, and switch to
|
||||
// the appropriate section.
|
||||
TargetLowering *LoweringInfo = TM.getTargetLowering();
|
||||
|
||||
const Function *F = MF.getFunction();
|
||||
bool JTInDiffSection = false;
|
||||
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
|
||||
// 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
|
||||
@ -546,12 +544,15 @@ void AsmPrinter::printPICJumpTableEntry(const MachineJumpTableInfo *MJTI,
|
||||
unsigned uid) const {
|
||||
const MCExpr *Value = 0;
|
||||
switch (MJTI->getEntryKind()) {
|
||||
case MachineJumpTableInfo::EK_Custom32:
|
||||
Value = TM.getTargetLowering()->LowerCustomJumpTableEntry(MJTI, MBB, uid,
|
||||
OutContext);
|
||||
break;
|
||||
case MachineJumpTableInfo::EK_BlockAddress:
|
||||
// EK_BlockAddress - Each entry is a plain address of block, e.g.:
|
||||
// .word LBB123
|
||||
Value = MCSymbolRefExpr::Create(GetMBBSymbol(MBB->getNumber()), OutContext);
|
||||
break;
|
||||
|
||||
case MachineJumpTableInfo::EK_GPRel32BlockAddress: {
|
||||
// EK_GPRel32BlockAddress - Each entry is an address of block, encoded
|
||||
// with a relocation as gp-relative, e.g.:
|
||||
@ -560,7 +561,7 @@ void AsmPrinter::printPICJumpTableEntry(const MachineJumpTableInfo *MJTI,
|
||||
OutStreamer.EmitGPRel32Value(MCSymbolRefExpr::Create(MBBSym, OutContext));
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
case MachineJumpTableInfo::EK_LabelDifference32: {
|
||||
// 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
|
||||
|
@ -544,6 +544,7 @@ unsigned MachineJumpTableInfo::getEntrySize(const TargetData &TD) const {
|
||||
return TD.getPointerSize();
|
||||
case MachineJumpTableInfo::EK_GPRel32BlockAddress:
|
||||
case MachineJumpTableInfo::EK_LabelDifference32:
|
||||
case MachineJumpTableInfo::EK_Custom32:
|
||||
return 4;
|
||||
}
|
||||
assert(0 && "Unknown jump table encoding!");
|
||||
@ -560,6 +561,7 @@ unsigned MachineJumpTableInfo::getEntryAlignment(const TargetData &TD) const {
|
||||
return TD.getPointerABIAlignment();
|
||||
case MachineJumpTableInfo::EK_GPRel32BlockAddress:
|
||||
case MachineJumpTableInfo::EK_LabelDifference32:
|
||||
case MachineJumpTableInfo::EK_Custom32:
|
||||
return TD.getABIIntegerTypeAlignment(32);
|
||||
}
|
||||
assert(0 && "Unknown jump table encoding!");
|
||||
|
@ -1445,6 +1445,7 @@ void JITEmitter::emitJumpTableInfo(MachineJumpTableInfo *MJTI) {
|
||||
break;
|
||||
}
|
||||
|
||||
case MachineJumpTableInfo::EK_Custom32:
|
||||
case MachineJumpTableInfo::EK_GPRel32BlockAddress:
|
||||
case MachineJumpTableInfo::EK_LabelDifference32: {
|
||||
assert(MJTI->getEntrySize(*TheJIT->getTargetData()) == 4&&"Cross JIT'ing?");
|
||||
|
Loading…
Reference in New Issue
Block a user