mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-09 11:25:55 +00:00
Jimptables working again on alpha.
As a bonus, use the GOT node instead of the AlphaISD::GOT for internal stuff. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30873 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -82,8 +82,8 @@ namespace ISD {
|
|||||||
Constant, ConstantFP,
|
Constant, ConstantFP,
|
||||||
GlobalAddress, FrameIndex, JumpTable, ConstantPool, ExternalSymbol,
|
GlobalAddress, FrameIndex, JumpTable, ConstantPool, ExternalSymbol,
|
||||||
|
|
||||||
// The relocation value to add to the value loaded from a jump table
|
// The address of the GOT
|
||||||
JumpTableRelocBase,
|
GLOBAL_OFFSET_TABLE,
|
||||||
|
|
||||||
// TargetConstant* - Like Constant*, but the DAG does not do any folding or
|
// TargetConstant* - Like Constant*, but the DAG does not do any folding or
|
||||||
// simplification of the constant.
|
// simplification of the constant.
|
||||||
|
@@ -204,7 +204,7 @@ void AsmPrinter::EmitJumpTableInfo(MachineJumpTableInfo *MJTI,
|
|||||||
TargetLowering *LoweringInfo = TM.getTargetLowering();
|
TargetLowering *LoweringInfo = TM.getTargetLowering();
|
||||||
if (LoweringInfo && LoweringInfo->usesGlobalOffsetTable()) {
|
if (LoweringInfo && LoweringInfo->usesGlobalOffsetTable()) {
|
||||||
SwitchToDataSection(TAI->getJumpTableDataSection(), 0);
|
SwitchToDataSection(TAI->getJumpTableDataSection(), 0);
|
||||||
if (TD->getPointerSize() == 8)
|
if (TD->getPointerSize() == 8 && !JTEntryDirective)
|
||||||
JTEntryDirective = TAI->getData64bitsDirective();
|
JTEntryDirective = TAI->getData64bitsDirective();
|
||||||
} else {
|
} else {
|
||||||
// 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
|
||||||
|
@@ -534,6 +534,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||||||
case ISD::SRCVALUE:
|
case ISD::SRCVALUE:
|
||||||
case ISD::STRING:
|
case ISD::STRING:
|
||||||
case ISD::CONDCODE:
|
case ISD::CONDCODE:
|
||||||
|
case ISD::GLOBAL_OFFSET_TABLE:
|
||||||
// Primitives must all be legal.
|
// Primitives must all be legal.
|
||||||
assert(TLI.isOperationLegal(Node->getValueType(0), Node->getValueType(0)) &&
|
assert(TLI.isOperationLegal(Node->getValueType(0), Node->getValueType(0)) &&
|
||||||
"This must be legal!");
|
"This must be legal!");
|
||||||
@@ -558,17 +559,6 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||||||
#endif
|
#endif
|
||||||
assert(0 && "Do not know how to legalize this operator!");
|
assert(0 && "Do not know how to legalize this operator!");
|
||||||
abort();
|
abort();
|
||||||
case ISD::JumpTableRelocBase:
|
|
||||||
switch (TLI.getOperationAction(Node->getOpcode(), Node->getValueType(0))) {
|
|
||||||
case TargetLowering::Custom:
|
|
||||||
Tmp1 = TLI.LowerOperation(Op, DAG);
|
|
||||||
if (Tmp1.Val) Result = Tmp1;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
Result = LegalizeOp(Node->getOperand(0));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case ISD::GlobalAddress:
|
case ISD::GlobalAddress:
|
||||||
case ISD::ExternalSymbol:
|
case ISD::ExternalSymbol:
|
||||||
case ISD::ConstantPool:
|
case ISD::ConstantPool:
|
||||||
|
@@ -2454,7 +2454,7 @@ const char *SDNode::getOperationName(const SelectionDAG *G) const {
|
|||||||
case ISD::GlobalAddress: return "GlobalAddress";
|
case ISD::GlobalAddress: return "GlobalAddress";
|
||||||
case ISD::FrameIndex: return "FrameIndex";
|
case ISD::FrameIndex: return "FrameIndex";
|
||||||
case ISD::JumpTable: return "JumpTable";
|
case ISD::JumpTable: return "JumpTable";
|
||||||
case ISD::JumpTableRelocBase: return "JumpTableRelocBase";
|
case ISD::GLOBAL_OFFSET_TABLE: return "GLOBAL_OFFSET_TABLE";
|
||||||
case ISD::ConstantPool: return "ConstantPool";
|
case ISD::ConstantPool: return "ConstantPool";
|
||||||
case ISD::ExternalSymbol: return "ExternalSymbol";
|
case ISD::ExternalSymbol: return "ExternalSymbol";
|
||||||
case ISD::INTRINSIC_WO_CHAIN: {
|
case ISD::INTRINSIC_WO_CHAIN: {
|
||||||
|
@@ -864,7 +864,11 @@ void SelectionDAGLowering::visitJumpTable(SelectionDAGISel::JumpTable &JT) {
|
|||||||
// For Pic, the sequence is:
|
// For Pic, the sequence is:
|
||||||
// BRIND(load(Jumptable + index) + RelocBase)
|
// BRIND(load(Jumptable + index) + RelocBase)
|
||||||
// RelocBase is the JumpTable on PPC and X86, GOT on Alpha
|
// RelocBase is the JumpTable on PPC and X86, GOT on Alpha
|
||||||
SDOperand Reloc = DAG.getNode(ISD::JumpTableRelocBase, PTy, TAB);
|
SDOperand Reloc;
|
||||||
|
if (TLI.usesGlobalOffsetTable())
|
||||||
|
Reloc = DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, PTy);
|
||||||
|
else
|
||||||
|
Reloc = TAB;
|
||||||
ADD = DAG.getNode(ISD::ADD, PTy,
|
ADD = DAG.getNode(ISD::ADD, PTy,
|
||||||
((PTy != MVT::i32) ? DAG.getNode(ISD::SIGN_EXTEND, PTy, LD) : LD), Reloc);
|
((PTy != MVT::i32) ? DAG.getNode(ISD::SIGN_EXTEND, PTy, LD) : LD), Reloc);
|
||||||
DAG.setRoot(DAG.getNode(ISD::BRIND, MVT::Other, LD.getValue(1), ADD));
|
DAG.setRoot(DAG.getNode(ISD::BRIND, MVT::Other, LD.getValue(1), ADD));
|
||||||
|
@@ -99,7 +99,8 @@ namespace {
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
AlphaDAGToDAGISel(TargetMachine &TM)
|
AlphaDAGToDAGISel(TargetMachine &TM)
|
||||||
: SelectionDAGISel(AlphaLowering), AlphaLowering(TM)
|
: SelectionDAGISel(AlphaLowering),
|
||||||
|
AlphaLowering(*(AlphaTargetLowering*)(TM.getTargetLowering()))
|
||||||
{}
|
{}
|
||||||
|
|
||||||
/// getI64Imm - Return a target constant with the specified value, of type
|
/// getI64Imm - Return a target constant with the specified value, of type
|
||||||
@@ -201,7 +202,7 @@ SDNode *AlphaDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
CurDAG->getTargetFrameIndex(FI, MVT::i32),
|
CurDAG->getTargetFrameIndex(FI, MVT::i32),
|
||||||
getI64Imm(0));
|
getI64Imm(0));
|
||||||
}
|
}
|
||||||
case AlphaISD::GlobalBaseReg: {
|
case ISD::GLOBAL_OFFSET_TABLE: {
|
||||||
SDOperand Result = getGlobalBaseReg();
|
SDOperand Result = getGlobalBaseReg();
|
||||||
ReplaceUses(Op, Result);
|
ReplaceUses(Op, Result);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@@ -132,7 +132,6 @@ AlphaTargetLowering::AlphaTargetLowering(TargetMachine &TM) : TargetLowering(TM)
|
|||||||
|
|
||||||
setOperationAction(ISD::JumpTable, MVT::i64, Custom);
|
setOperationAction(ISD::JumpTable, MVT::i64, Custom);
|
||||||
setOperationAction(ISD::JumpTable, MVT::i32, Custom);
|
setOperationAction(ISD::JumpTable, MVT::i32, Custom);
|
||||||
setOperationAction(ISD::JumpTableRelocBase, MVT::i64, Custom);
|
|
||||||
|
|
||||||
setStackPointerRegisterToSaveRestore(Alpha::R30);
|
setStackPointerRegisterToSaveRestore(Alpha::R30);
|
||||||
|
|
||||||
@@ -160,7 +159,6 @@ const char *AlphaTargetLowering::getTargetNodeName(unsigned Opcode) const {
|
|||||||
case AlphaISD::GPRelHi: return "Alpha::GPRelHi";
|
case AlphaISD::GPRelHi: return "Alpha::GPRelHi";
|
||||||
case AlphaISD::GPRelLo: return "Alpha::GPRelLo";
|
case AlphaISD::GPRelLo: return "Alpha::GPRelLo";
|
||||||
case AlphaISD::RelLit: return "Alpha::RelLit";
|
case AlphaISD::RelLit: return "Alpha::RelLit";
|
||||||
case AlphaISD::GlobalBaseReg: return "Alpha::GlobalBaseReg";
|
|
||||||
case AlphaISD::GlobalRetAddr: return "Alpha::GlobalRetAddr";
|
case AlphaISD::GlobalRetAddr: return "Alpha::GlobalRetAddr";
|
||||||
case AlphaISD::CALL: return "Alpha::CALL";
|
case AlphaISD::CALL: return "Alpha::CALL";
|
||||||
case AlphaISD::DivCall: return "Alpha::DivCall";
|
case AlphaISD::DivCall: return "Alpha::DivCall";
|
||||||
@@ -177,7 +175,7 @@ static SDOperand LowerJumpTable(SDOperand Op, SelectionDAG &DAG) {
|
|||||||
const TargetMachine &TM = DAG.getTarget();
|
const TargetMachine &TM = DAG.getTarget();
|
||||||
|
|
||||||
SDOperand Hi = DAG.getNode(AlphaISD::GPRelHi, MVT::i64, JTI,
|
SDOperand Hi = DAG.getNode(AlphaISD::GPRelHi, MVT::i64, JTI,
|
||||||
DAG.getNode(AlphaISD::GlobalBaseReg, MVT::i64));
|
DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, MVT::i64));
|
||||||
SDOperand Lo = DAG.getNode(AlphaISD::GPRelLo, MVT::i64, JTI, Hi);
|
SDOperand Lo = DAG.getNode(AlphaISD::GPRelLo, MVT::i64, JTI, Hi);
|
||||||
return Lo;
|
return Lo;
|
||||||
}
|
}
|
||||||
@@ -414,8 +412,6 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
|||||||
GP, RA);
|
GP, RA);
|
||||||
case ISD::RET: return LowerRET(Op,DAG, getVRegRA());
|
case ISD::RET: return LowerRET(Op,DAG, getVRegRA());
|
||||||
case ISD::JumpTable: return LowerJumpTable(Op, DAG);
|
case ISD::JumpTable: return LowerJumpTable(Op, DAG);
|
||||||
case ISD::JumpTableRelocBase:
|
|
||||||
return DAG.getNode(AlphaISD::GlobalBaseReg, MVT::i64);
|
|
||||||
|
|
||||||
case ISD::SINT_TO_FP: {
|
case ISD::SINT_TO_FP: {
|
||||||
assert(MVT::i64 == Op.getOperand(0).getValueType() &&
|
assert(MVT::i64 == Op.getOperand(0).getValueType() &&
|
||||||
@@ -462,7 +458,7 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
|||||||
SDOperand CPI = DAG.getTargetConstantPool(C, MVT::i64, CP->getAlignment());
|
SDOperand CPI = DAG.getTargetConstantPool(C, MVT::i64, CP->getAlignment());
|
||||||
|
|
||||||
SDOperand Hi = DAG.getNode(AlphaISD::GPRelHi, MVT::i64, CPI,
|
SDOperand Hi = DAG.getNode(AlphaISD::GPRelHi, MVT::i64, CPI,
|
||||||
DAG.getNode(AlphaISD::GlobalBaseReg, MVT::i64));
|
DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, MVT::i64));
|
||||||
SDOperand Lo = DAG.getNode(AlphaISD::GPRelLo, MVT::i64, CPI, Hi);
|
SDOperand Lo = DAG.getNode(AlphaISD::GPRelLo, MVT::i64, CPI, Hi);
|
||||||
return Lo;
|
return Lo;
|
||||||
}
|
}
|
||||||
@@ -474,16 +470,18 @@ SDOperand AlphaTargetLowering::LowerOperation(SDOperand Op, SelectionDAG &DAG) {
|
|||||||
// if (!GV->hasWeakLinkage() && !GV->isExternal() && !GV->hasLinkOnceLinkage()) {
|
// if (!GV->hasWeakLinkage() && !GV->isExternal() && !GV->hasLinkOnceLinkage()) {
|
||||||
if (GV->hasInternalLinkage()) {
|
if (GV->hasInternalLinkage()) {
|
||||||
SDOperand Hi = DAG.getNode(AlphaISD::GPRelHi, MVT::i64, GA,
|
SDOperand Hi = DAG.getNode(AlphaISD::GPRelHi, MVT::i64, GA,
|
||||||
DAG.getNode(AlphaISD::GlobalBaseReg, MVT::i64));
|
DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, MVT::i64));
|
||||||
SDOperand Lo = DAG.getNode(AlphaISD::GPRelLo, MVT::i64, GA, Hi);
|
SDOperand Lo = DAG.getNode(AlphaISD::GPRelLo, MVT::i64, GA, Hi);
|
||||||
return Lo;
|
return Lo;
|
||||||
} else
|
} else
|
||||||
return DAG.getNode(AlphaISD::RelLit, MVT::i64, GA, DAG.getNode(AlphaISD::GlobalBaseReg, MVT::i64));
|
return DAG.getNode(AlphaISD::RelLit, MVT::i64, GA,
|
||||||
|
DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, MVT::i64));
|
||||||
}
|
}
|
||||||
case ISD::ExternalSymbol: {
|
case ISD::ExternalSymbol: {
|
||||||
return DAG.getNode(AlphaISD::RelLit, MVT::i64,
|
return DAG.getNode(AlphaISD::RelLit, MVT::i64,
|
||||||
DAG.getTargetExternalSymbol(cast<ExternalSymbolSDNode>(Op)->getSymbol(), MVT::i64),
|
DAG.getTargetExternalSymbol(cast<ExternalSymbolSDNode>(Op)
|
||||||
DAG.getNode(AlphaISD::GlobalBaseReg, MVT::i64));
|
->getSymbol(), MVT::i64),
|
||||||
|
DAG.getNode(ISD::GLOBAL_OFFSET_TABLE, MVT::i64));
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::UREM:
|
case ISD::UREM:
|
||||||
|
@@ -36,9 +36,6 @@ namespace llvm {
|
|||||||
/// RetLit - Literal Relocation of a Global
|
/// RetLit - Literal Relocation of a Global
|
||||||
RelLit,
|
RelLit,
|
||||||
|
|
||||||
/// GlobalBaseReg - used to restore the GOT ptr
|
|
||||||
GlobalBaseReg,
|
|
||||||
|
|
||||||
/// GlobalRetAddr - used to restore the return address
|
/// GlobalRetAddr - used to restore the return address
|
||||||
GlobalRetAddr,
|
GlobalRetAddr,
|
||||||
|
|
||||||
|
@@ -58,7 +58,8 @@ AlphaTargetMachine::AlphaTargetMachine(const Module &M, const std::string &FS)
|
|||||||
: DataLayout("e"),
|
: DataLayout("e"),
|
||||||
FrameInfo(TargetFrameInfo::StackGrowsDown, 16, 0),
|
FrameInfo(TargetFrameInfo::StackGrowsDown, 16, 0),
|
||||||
JITInfo(*this),
|
JITInfo(*this),
|
||||||
Subtarget(M, FS) {
|
Subtarget(M, FS),
|
||||||
|
TLInfo(*this) {
|
||||||
setRelocationModel(Reloc::PIC_);
|
setRelocationModel(Reloc::PIC_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -19,6 +19,7 @@
|
|||||||
#include "llvm/Target/TargetFrameInfo.h"
|
#include "llvm/Target/TargetFrameInfo.h"
|
||||||
#include "AlphaInstrInfo.h"
|
#include "AlphaInstrInfo.h"
|
||||||
#include "AlphaJITInfo.h"
|
#include "AlphaJITInfo.h"
|
||||||
|
#include "AlphaISelLowering.h"
|
||||||
#include "AlphaSubtarget.h"
|
#include "AlphaSubtarget.h"
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
@@ -31,6 +32,7 @@ class AlphaTargetMachine : public LLVMTargetMachine {
|
|||||||
TargetFrameInfo FrameInfo;
|
TargetFrameInfo FrameInfo;
|
||||||
AlphaJITInfo JITInfo;
|
AlphaJITInfo JITInfo;
|
||||||
AlphaSubtarget Subtarget;
|
AlphaSubtarget Subtarget;
|
||||||
|
AlphaTargetLowering TLInfo;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual const TargetAsmInfo *createTargetAsmInfo() const;
|
virtual const TargetAsmInfo *createTargetAsmInfo() const;
|
||||||
@@ -44,6 +46,9 @@ public:
|
|||||||
virtual const MRegisterInfo *getRegisterInfo() const {
|
virtual const MRegisterInfo *getRegisterInfo() const {
|
||||||
return &InstrInfo.getRegisterInfo();
|
return &InstrInfo.getRegisterInfo();
|
||||||
}
|
}
|
||||||
|
virtual TargetLowering* getTargetLowering() const {
|
||||||
|
return const_cast<AlphaTargetLowering*>(&TLInfo);
|
||||||
|
}
|
||||||
virtual const TargetData *getTargetData() const { return &DataLayout; }
|
virtual const TargetData *getTargetData() const { return &DataLayout; }
|
||||||
virtual TargetJITInfo* getJITInfo() {
|
virtual TargetJITInfo* getJITInfo() {
|
||||||
return &JITInfo;
|
return &JITInfo;
|
||||||
|
@@ -4,8 +4,6 @@
|
|||||||
; RUN: llvm-as < %s | llc -march=alpha | grep 'ldl' &&
|
; RUN: llvm-as < %s | llc -march=alpha | grep 'ldl' &&
|
||||||
; RUN: llvm-as < %s | llc -march=alpha | grep 'rodata'
|
; RUN: llvm-as < %s | llc -march=alpha | grep 'rodata'
|
||||||
|
|
||||||
; XFAIL: *
|
|
||||||
|
|
||||||
target endian = little
|
target endian = little
|
||||||
target pointersize = 64
|
target pointersize = 64
|
||||||
target triple = "alphaev67-unknown-linux-gnu"
|
target triple = "alphaev67-unknown-linux-gnu"
|
||||||
|
Reference in New Issue
Block a user