mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
- Added VConstant as an abstract version of ConstantVec.
- All abstrct vector nodes must have # of elements and element type as their first two operands. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26432 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ce531a4eff
commit
1ab7d859cf
@ -63,10 +63,10 @@ namespace ISD {
|
|||||||
AssertSext, AssertZext,
|
AssertSext, AssertZext,
|
||||||
|
|
||||||
// Various leaf nodes.
|
// Various leaf nodes.
|
||||||
Constant, ConstantFP, STRING,
|
STRING, BasicBlock, VALUETYPE, CONDCODE, Register,
|
||||||
GlobalAddress, FrameIndex, ConstantPool,
|
Constant, ConstantFP,
|
||||||
BasicBlock, ExternalSymbol, VALUETYPE, CONDCODE, Register,
|
GlobalAddress, FrameIndex, ConstantPool, ExternalSymbol,
|
||||||
|
|
||||||
// ConstantVec works like Constant or ConstantFP, except that it is not a
|
// ConstantVec works like Constant or ConstantFP, except that it is not a
|
||||||
// leaf node. All operands are either Constant or ConstantFP nodes.
|
// leaf node. All operands are either Constant or ConstantFP nodes.
|
||||||
ConstantVec,
|
ConstantVec,
|
||||||
@ -85,6 +85,11 @@ namespace ISD {
|
|||||||
TargetConstantPool,
|
TargetConstantPool,
|
||||||
TargetExternalSymbol,
|
TargetExternalSymbol,
|
||||||
|
|
||||||
|
// Abstract version of ConstantVec with abstract Vector type. The first node
|
||||||
|
// is a constant element count, the second is a value type indicating the
|
||||||
|
// type of the elements.
|
||||||
|
VConstant,
|
||||||
|
|
||||||
// CopyToReg - This node has three operands: a chain, a register number to
|
// CopyToReg - This node has three operands: a chain, a register number to
|
||||||
// set to this value, and a value.
|
// set to this value, and a value.
|
||||||
CopyToReg,
|
CopyToReg,
|
||||||
@ -139,9 +144,9 @@ namespace ISD {
|
|||||||
// Simple abstract vector operators. Unlike the integer and floating point
|
// Simple abstract vector operators. Unlike the integer and floating point
|
||||||
// binary operators, these nodes also take two additional operands:
|
// binary operators, these nodes also take two additional operands:
|
||||||
// a constant element count, and a value type node indicating the type of
|
// a constant element count, and a value type node indicating the type of
|
||||||
// the elements. The order is op0, op1, count, type. All vector opcodes,
|
// the elements. The order is count, type, op0, op1. All vector opcodes,
|
||||||
// including VLOAD, must currently have count and type as their 3rd and 4th
|
// including VLOAD and VConstant must currently have count and type as
|
||||||
// arguments.
|
// their 1st and 2nd arguments.
|
||||||
VADD, VSUB, VMUL,
|
VADD, VSUB, VMUL,
|
||||||
|
|
||||||
// MULHU/MULHS - Multiply high - Multiply two integers of type iN, producing
|
// MULHU/MULHS - Multiply high - Multiply two integers of type iN, producing
|
||||||
@ -243,9 +248,9 @@ namespace ISD {
|
|||||||
// SRCVALUE node that provides alias analysis information.
|
// SRCVALUE node that provides alias analysis information.
|
||||||
LOAD, STORE,
|
LOAD, STORE,
|
||||||
|
|
||||||
// Abstract vector version of LOAD. VLOAD has a token chain as the first
|
// Abstract vector version of LOAD. VLOAD has a constant element count as
|
||||||
// operand, followed by a pointer operand, a constant element count, a value
|
// the first operand, followed by a value type node indicating the type of
|
||||||
// type node indicating the type of the elements, and a SRCVALUE node.
|
// the elements, a token chain, a pointer operand, and a SRCVALUE node.
|
||||||
VLOAD,
|
VLOAD,
|
||||||
|
|
||||||
// EXTLOAD, SEXTLOAD, ZEXTLOAD - These three operators all load a value from
|
// EXTLOAD, SEXTLOAD, ZEXTLOAD - These three operators all load a value from
|
||||||
|
@ -1400,10 +1400,10 @@ SDOperand SelectionDAG::getVecLoad(unsigned Count, MVT::ValueType EVT,
|
|||||||
if (N) return SDOperand(N, 0);
|
if (N) return SDOperand(N, 0);
|
||||||
std::vector<SDOperand> Ops;
|
std::vector<SDOperand> Ops;
|
||||||
Ops.reserve(5);
|
Ops.reserve(5);
|
||||||
Ops.push_back(Chain);
|
|
||||||
Ops.push_back(Ptr);
|
|
||||||
Ops.push_back(getConstant(Count, MVT::i32));
|
Ops.push_back(getConstant(Count, MVT::i32));
|
||||||
Ops.push_back(getValueType(EVT));
|
Ops.push_back(getValueType(EVT));
|
||||||
|
Ops.push_back(Chain);
|
||||||
|
Ops.push_back(Ptr);
|
||||||
Ops.push_back(SV);
|
Ops.push_back(SV);
|
||||||
std::vector<MVT::ValueType> VTs;
|
std::vector<MVT::ValueType> VTs;
|
||||||
VTs.reserve(2);
|
VTs.reserve(2);
|
||||||
@ -2557,26 +2557,33 @@ const char *SDNode::getOperationName(const SelectionDAG *G) const {
|
|||||||
case ISD::PCMARKER: return "PCMarker";
|
case ISD::PCMARKER: return "PCMarker";
|
||||||
case ISD::READCYCLECOUNTER: return "ReadCycleCounter";
|
case ISD::READCYCLECOUNTER: return "ReadCycleCounter";
|
||||||
case ISD::SRCVALUE: return "SrcValue";
|
case ISD::SRCVALUE: return "SrcValue";
|
||||||
case ISD::VALUETYPE: return "ValueType";
|
|
||||||
case ISD::STRING: return "String";
|
|
||||||
case ISD::EntryToken: return "EntryToken";
|
case ISD::EntryToken: return "EntryToken";
|
||||||
case ISD::TokenFactor: return "TokenFactor";
|
case ISD::TokenFactor: return "TokenFactor";
|
||||||
case ISD::AssertSext: return "AssertSext";
|
case ISD::AssertSext: return "AssertSext";
|
||||||
case ISD::AssertZext: return "AssertZext";
|
case ISD::AssertZext: return "AssertZext";
|
||||||
case ISD::Constant: return "Constant";
|
|
||||||
case ISD::TargetConstant: return "TargetConstant";
|
case ISD::STRING: return "String";
|
||||||
case ISD::ConstantFP: return "ConstantFP";
|
|
||||||
case ISD::ConstantVec: return "ConstantVec";
|
|
||||||
case ISD::GlobalAddress: return "GlobalAddress";
|
|
||||||
case ISD::TargetGlobalAddress: return "TargetGlobalAddress";
|
|
||||||
case ISD::FrameIndex: return "FrameIndex";
|
|
||||||
case ISD::TargetFrameIndex: return "TargetFrameIndex";
|
|
||||||
case ISD::BasicBlock: return "BasicBlock";
|
case ISD::BasicBlock: return "BasicBlock";
|
||||||
|
case ISD::VALUETYPE: return "ValueType";
|
||||||
case ISD::Register: return "Register";
|
case ISD::Register: return "Register";
|
||||||
case ISD::ExternalSymbol: return "ExternalSymbol";
|
|
||||||
case ISD::TargetExternalSymbol: return "TargetExternalSymbol";
|
case ISD::Constant: return "Constant";
|
||||||
|
case ISD::ConstantFP: return "ConstantFP";
|
||||||
|
case ISD::GlobalAddress: return "GlobalAddress";
|
||||||
|
case ISD::FrameIndex: return "FrameIndex";
|
||||||
case ISD::ConstantPool: return "ConstantPool";
|
case ISD::ConstantPool: return "ConstantPool";
|
||||||
|
case ISD::ExternalSymbol: return "ExternalSymbol";
|
||||||
|
|
||||||
|
case ISD::ConstantVec: return "ConstantVec";
|
||||||
|
case ISD::TargetConstant: return "TargetConstant";
|
||||||
|
case ISD::TargetConstantFP:return "TargetConstantFP";
|
||||||
|
case ISD::TargetConstantVec:return "TargetConstantVec";
|
||||||
|
case ISD::TargetGlobalAddress: return "TargetGlobalAddress";
|
||||||
|
case ISD::TargetFrameIndex: return "TargetFrameIndex";
|
||||||
case ISD::TargetConstantPool: return "TargetConstantPool";
|
case ISD::TargetConstantPool: return "TargetConstantPool";
|
||||||
|
case ISD::TargetExternalSymbol: return "TargetExternalSymbol";
|
||||||
|
case ISD::VConstant: return "VConstant";
|
||||||
|
|
||||||
case ISD::CopyToReg: return "CopyToReg";
|
case ISD::CopyToReg: return "CopyToReg";
|
||||||
case ISD::CopyFromReg: return "CopyFromReg";
|
case ISD::CopyFromReg: return "CopyFromReg";
|
||||||
case ISD::UNDEF: return "undef";
|
case ISD::UNDEF: return "undef";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user