mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
SelectNodeTo now returns a SDNode*.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29901 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7a33db0b20
commit
95514bae73
@ -304,41 +304,41 @@ public:
|
|||||||
/// operands. Note that target opcodes are stored as
|
/// operands. Note that target opcodes are stored as
|
||||||
/// ISD::BUILTIN_OP_END+TargetOpcode in the node opcode field. The 0th value
|
/// ISD::BUILTIN_OP_END+TargetOpcode in the node opcode field. The 0th value
|
||||||
/// of the resultant node is returned.
|
/// of the resultant node is returned.
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT);
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1);
|
SDOperand Op1);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2);
|
SDOperand Op1, SDOperand Op2);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2, SDOperand Op3);
|
SDOperand Op1, SDOperand Op2, SDOperand Op3);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4);
|
SDOperand Op4);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4, SDOperand Op5);
|
SDOperand Op4, SDOperand Op5);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4, SDOperand Op5, SDOperand Op6);
|
SDOperand Op4, SDOperand Op5, SDOperand Op6);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4, SDOperand Op5, SDOperand Op6,
|
SDOperand Op4, SDOperand Op5, SDOperand Op6,
|
||||||
SDOperand Op7);
|
SDOperand Op7);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT,
|
||||||
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
SDOperand Op1, SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4, SDOperand Op5, SDOperand Op6,
|
SDOperand Op4, SDOperand Op5, SDOperand Op6,
|
||||||
SDOperand Op7, SDOperand Op8);
|
SDOperand Op7, SDOperand Op8);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
||||||
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2);
|
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
||||||
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2,
|
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2,
|
||||||
SDOperand Op3);
|
SDOperand Op3);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
||||||
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2,
|
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2,
|
||||||
SDOperand Op3, SDOperand Op4);
|
SDOperand Op3, SDOperand Op4);
|
||||||
SDOperand SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
SDNode *SelectNodeTo(SDNode *N, unsigned TargetOpc, MVT::ValueType VT1,
|
||||||
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2,
|
MVT::ValueType VT2, SDOperand Op1, SDOperand Op2,
|
||||||
SDOperand Op3, SDOperand Op4, SDOperand Op5);
|
SDOperand Op3, SDOperand Op4, SDOperand Op5);
|
||||||
|
|
||||||
/// getTargetNode - These are used for target selectors to create a new node
|
/// getTargetNode - These are used for target selectors to create a new node
|
||||||
/// with specified return type(s), target opcode, and operands.
|
/// with specified return type(s), target opcode, and operands.
|
||||||
|
@ -1834,13 +1834,13 @@ UpdateNodeOperands(SDOperand InN, SDOperand *Ops, unsigned NumOps) {
|
|||||||
/// Note that SelectNodeTo returns the resultant node. If there is already a
|
/// Note that SelectNodeTo returns the resultant node. If there is already a
|
||||||
/// node of the specified opcode and operands, it returns that node instead of
|
/// node of the specified opcode and operands, it returns that node instead of
|
||||||
/// the current one.
|
/// the current one.
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT) {
|
MVT::ValueType VT) {
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
|
|
||||||
@ -1848,35 +1848,35 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setValueTypes(VTs);
|
N->setValueTypes(VTs);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP);
|
CSEMap.InsertNode(N, IP);
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1) {
|
MVT::ValueType VT, SDOperand Op1) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs, Op1);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs, Op1);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
N->setValueTypes(VTs);
|
N->setValueTypes(VTs);
|
||||||
N->setOperands(Op1);
|
N->setOperands(Op1);
|
||||||
CSEMap.InsertNode(N, IP);
|
CSEMap.InsertNode(N, IP);
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2) {
|
SDOperand Op2) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs, Op1, Op2);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs, Op1, Op2);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -1884,19 +1884,19 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2);
|
N->setOperands(Op1, Op2);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2, SDOperand Op3) {
|
SDOperand Op2, SDOperand Op3) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs,
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs,
|
||||||
Op1, Op2, Op3);
|
Op1, Op2, Op3);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -1904,13 +1904,13 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3);
|
N->setOperands(Op1, Op2, Op3);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2, SDOperand Op3,
|
SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4) {
|
SDOperand Op4) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
@ -1920,7 +1920,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op4);
|
ID.AddOperand(Op4);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -1928,13 +1928,13 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4);
|
N->setOperands(Op1, Op2, Op3, Op4);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2, SDOperand Op3,
|
SDOperand Op2, SDOperand Op3,
|
||||||
SDOperand Op4, SDOperand Op5) {
|
SDOperand Op4, SDOperand Op5) {
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
ID.AddOperand(Op1);
|
ID.AddOperand(Op1);
|
||||||
@ -1944,7 +1944,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op5);
|
ID.AddOperand(Op5);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -1952,13 +1952,13 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4, Op5);
|
N->setOperands(Op1, Op2, Op3, Op4, Op5);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2, SDOperand Op3,SDOperand Op4,
|
SDOperand Op2, SDOperand Op3, SDOperand Op4,
|
||||||
SDOperand Op5, SDOperand Op6) {
|
SDOperand Op5, SDOperand Op6) {
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
ID.AddOperand(Op1);
|
ID.AddOperand(Op1);
|
||||||
@ -1969,7 +1969,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op6);
|
ID.AddOperand(Op6);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -1977,14 +1977,14 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4, Op5, Op6);
|
N->setOperands(Op1, Op2, Op3, Op4, Op5, Op6);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2, SDOperand Op3,SDOperand Op4,
|
SDOperand Op2, SDOperand Op3,SDOperand Op4,
|
||||||
SDOperand Op5, SDOperand Op6,
|
SDOperand Op5, SDOperand Op6,
|
||||||
SDOperand Op7) {
|
SDOperand Op7) {
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
@ -1997,7 +1997,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op7);
|
ID.AddOperand(Op7);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -2005,13 +2005,13 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4, Op5, Op6, Op7);
|
N->setOperands(Op1, Op2, Op3, Op4, Op5, Op6, Op7);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT, SDOperand Op1,
|
MVT::ValueType VT, SDOperand Op1,
|
||||||
SDOperand Op2, SDOperand Op3,SDOperand Op4,
|
SDOperand Op2, SDOperand Op3,SDOperand Op4,
|
||||||
SDOperand Op5, SDOperand Op6,
|
SDOperand Op5, SDOperand Op6,
|
||||||
SDOperand Op7, SDOperand Op8) {
|
SDOperand Op7, SDOperand Op8) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT);
|
SDVTList VTs = getVTList(VT);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
@ -2025,7 +2025,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op8);
|
ID.AddOperand(Op8);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -2033,17 +2033,17 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4, Op5, Op6, Op7, Op8);
|
N->setOperands(Op1, Op2, Op3, Op4, Op5, Op6, Op7, Op8);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT1, MVT::ValueType VT2,
|
MVT::ValueType VT1, MVT::ValueType VT2,
|
||||||
SDOperand Op1, SDOperand Op2) {
|
SDOperand Op1, SDOperand Op2) {
|
||||||
SDVTList VTs = getVTList(VT1, VT2);
|
SDVTList VTs = getVTList(VT1, VT2);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs, Op1, Op2);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs, Op1, Op2);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -2051,20 +2051,20 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2);
|
N->setOperands(Op1, Op2);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT1, MVT::ValueType VT2,
|
MVT::ValueType VT1, MVT::ValueType VT2,
|
||||||
SDOperand Op1, SDOperand Op2,
|
SDOperand Op1, SDOperand Op2,
|
||||||
SDOperand Op3) {
|
SDOperand Op3) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT1, VT2);
|
SDVTList VTs = getVTList(VT1, VT2);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs,
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs,
|
||||||
Op1, Op2, Op3);
|
Op1, Op2, Op3);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -2072,13 +2072,13 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3);
|
N->setOperands(Op1, Op2, Op3);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT1, MVT::ValueType VT2,
|
MVT::ValueType VT1, MVT::ValueType VT2,
|
||||||
SDOperand Op1, SDOperand Op2,
|
SDOperand Op1, SDOperand Op2,
|
||||||
SDOperand Op3, SDOperand Op4) {
|
SDOperand Op3, SDOperand Op4) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT1, VT2);
|
SDVTList VTs = getVTList(VT1, VT2);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
@ -2088,7 +2088,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op4);
|
ID.AddOperand(Op4);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -2096,14 +2096,14 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4);
|
N->setOperands(Op1, Op2, Op3, Op4);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
SDNode *SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
||||||
MVT::ValueType VT1, MVT::ValueType VT2,
|
MVT::ValueType VT1, MVT::ValueType VT2,
|
||||||
SDOperand Op1, SDOperand Op2,
|
SDOperand Op1, SDOperand Op2,
|
||||||
SDOperand Op3, SDOperand Op4,
|
SDOperand Op3, SDOperand Op4,
|
||||||
SDOperand Op5) {
|
SDOperand Op5) {
|
||||||
// If an identical node already exists, use it.
|
// If an identical node already exists, use it.
|
||||||
SDVTList VTs = getVTList(VT1, VT2);
|
SDVTList VTs = getVTList(VT1, VT2);
|
||||||
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
SelectionDAGCSEMap::NodeID ID(ISD::BUILTIN_OP_END+TargetOpc, VTs);
|
||||||
@ -2114,7 +2114,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
ID.AddOperand(Op5);
|
ID.AddOperand(Op5);
|
||||||
void *IP = 0;
|
void *IP = 0;
|
||||||
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
if (SDNode *ON = CSEMap.FindNodeOrInsertPos(ID, IP))
|
||||||
return SDOperand(ON, 0);
|
return ON;
|
||||||
|
|
||||||
RemoveNodeFromCSEMaps(N);
|
RemoveNodeFromCSEMaps(N);
|
||||||
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
N->MorphNodeTo(ISD::BUILTIN_OP_END+TargetOpc);
|
||||||
@ -2122,7 +2122,7 @@ SDOperand SelectionDAG::SelectNodeTo(SDNode *N, unsigned TargetOpc,
|
|||||||
N->setOperands(Op1, Op2, Op3, Op4, Op5);
|
N->setOperands(Op1, Op2, Op3, Op4, Op5);
|
||||||
|
|
||||||
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
CSEMap.InsertNode(N, IP); // Memoize the new node.
|
||||||
return SDOperand(N, 0);
|
return N;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// getTargetNode - These are used for target selectors to create a new node
|
/// getTargetNode - These are used for target selectors to create a new node
|
||||||
|
@ -199,7 +199,7 @@ SDNode *AlphaDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
||||||
return CurDAG->SelectNodeTo(N, Alpha::LDA, MVT::i64,
|
return CurDAG->SelectNodeTo(N, Alpha::LDA, MVT::i64,
|
||||||
CurDAG->getTargetFrameIndex(FI, MVT::i32),
|
CurDAG->getTargetFrameIndex(FI, MVT::i32),
|
||||||
getI64Imm(0)).Val;
|
getI64Imm(0));
|
||||||
}
|
}
|
||||||
case AlphaISD::GlobalBaseReg: {
|
case AlphaISD::GlobalBaseReg: {
|
||||||
SDOperand Result = getGlobalBaseReg();
|
SDOperand Result = getGlobalBaseReg();
|
||||||
@ -231,7 +231,7 @@ SDNode *AlphaDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
Chain, Chain.getValue(1));
|
Chain, Chain.getValue(1));
|
||||||
Chain = CurDAG->getCopyFromReg(Chain, Alpha::R27, MVT::i64,
|
Chain = CurDAG->getCopyFromReg(Chain, Alpha::R27, MVT::i64,
|
||||||
SDOperand(CNode, 1));
|
SDOperand(CNode, 1));
|
||||||
return CurDAG->SelectNodeTo(N, Alpha::BIS, MVT::i64, Chain, Chain).Val;
|
return CurDAG->SelectNodeTo(N, Alpha::BIS, MVT::i64, Chain, Chain);
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::READCYCLECOUNTER: {
|
case ISD::READCYCLECOUNTER: {
|
||||||
@ -268,7 +268,7 @@ SDNode *AlphaDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
SDNode *Tmp = CurDAG->getTargetNode(Alpha::LDAHr, MVT::i64, CPI,
|
SDNode *Tmp = CurDAG->getTargetNode(Alpha::LDAHr, MVT::i64, CPI,
|
||||||
getGlobalBaseReg());
|
getGlobalBaseReg());
|
||||||
return CurDAG->SelectNodeTo(N, Alpha::LDQr, MVT::i64, MVT::Other,
|
return CurDAG->SelectNodeTo(N, Alpha::LDQr, MVT::i64, MVT::Other,
|
||||||
CPI, SDOperand(Tmp, 0), CurDAG->getEntryNode()).Val;
|
CPI, SDOperand(Tmp, 0), CurDAG->getEntryNode());
|
||||||
}
|
}
|
||||||
case ISD::TargetConstantFP: {
|
case ISD::TargetConstantFP: {
|
||||||
ConstantFPSDNode *CN = cast<ConstantFPSDNode>(N);
|
ConstantFPSDNode *CN = cast<ConstantFPSDNode>(N);
|
||||||
@ -277,11 +277,11 @@ SDNode *AlphaDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
if (CN->isExactlyValue(+0.0)) {
|
if (CN->isExactlyValue(+0.0)) {
|
||||||
return CurDAG->SelectNodeTo(N, isDouble ? Alpha::CPYST : Alpha::CPYSS,
|
return CurDAG->SelectNodeTo(N, isDouble ? Alpha::CPYST : Alpha::CPYSS,
|
||||||
T, CurDAG->getRegister(Alpha::F31, T),
|
T, CurDAG->getRegister(Alpha::F31, T),
|
||||||
CurDAG->getRegister(Alpha::F31, T)).Val;
|
CurDAG->getRegister(Alpha::F31, T));
|
||||||
} else if ( CN->isExactlyValue(-0.0)) {
|
} else if ( CN->isExactlyValue(-0.0)) {
|
||||||
return CurDAG->SelectNodeTo(N, isDouble ? Alpha::CPYSNT : Alpha::CPYSNS,
|
return CurDAG->SelectNodeTo(N, isDouble ? Alpha::CPYSNT : Alpha::CPYSNS,
|
||||||
T, CurDAG->getRegister(Alpha::F31, T),
|
T, CurDAG->getRegister(Alpha::F31, T),
|
||||||
CurDAG->getRegister(Alpha::F31, T)).Val;
|
CurDAG->getRegister(Alpha::F31, T));
|
||||||
} else {
|
} else {
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
|
@ -408,10 +408,10 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
int FI = cast<FrameIndexSDNode>(N)->getIndex();
|
||||||
if (N->hasOneUse())
|
if (N->hasOneUse())
|
||||||
return CurDAG->SelectNodeTo(N, IA64::MOV, MVT::i64,
|
return CurDAG->SelectNodeTo(N, IA64::MOV, MVT::i64,
|
||||||
CurDAG->getTargetFrameIndex(FI, MVT::i64)).Val;
|
CurDAG->getTargetFrameIndex(FI, MVT::i64));
|
||||||
else
|
else
|
||||||
return SDOperand(CurDAG->getTargetNode(IA64::MOV, MVT::i64,
|
return CurDAG->getTargetNode(IA64::MOV, MVT::i64,
|
||||||
CurDAG->getTargetFrameIndex(FI, MVT::i64)), 0).Val;
|
CurDAG->getTargetFrameIndex(FI, MVT::i64));
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::ConstantPool: { // TODO: nuke the constant pool
|
case ISD::ConstantPool: { // TODO: nuke the constant pool
|
||||||
@ -464,7 +464,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
return CurDAG->SelectNodeTo(N, IA64::CMPNE, MVT::i1, MVT::Other,
|
return CurDAG->SelectNodeTo(N, IA64::CMPNE, MVT::i1, MVT::Other,
|
||||||
SDOperand(CurDAG->getTargetNode(Opc, MVT::i64, Address), 0),
|
SDOperand(CurDAG->getTargetNode(Opc, MVT::i64, Address), 0),
|
||||||
CurDAG->getRegister(IA64::r0, MVT::i64),
|
CurDAG->getRegister(IA64::r0, MVT::i64),
|
||||||
Chain).getValue(Op.ResNo).Val;
|
Chain);
|
||||||
}
|
}
|
||||||
/* otherwise, we want to load a bool into something bigger: LD1
|
/* otherwise, we want to load a bool into something bigger: LD1
|
||||||
will do that for us, so we just fall through */
|
will do that for us, so we just fall through */
|
||||||
@ -480,7 +480,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
|
|
||||||
// TODO: comment this
|
// TODO: comment this
|
||||||
return CurDAG->SelectNodeTo(N, Opc, N->getValueType(0), MVT::Other,
|
return CurDAG->SelectNodeTo(N, Opc, N->getValueType(0), MVT::Other,
|
||||||
Address, Chain).getValue(Op.ResNo).Val;
|
Address, Chain);
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::TRUNCSTORE:
|
case ISD::TRUNCSTORE:
|
||||||
@ -505,7 +505,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
Tmp = SDOperand(CurDAG->getTargetNode(IA64::TPCADDS, MVT::i64, Initial,
|
Tmp = SDOperand(CurDAG->getTargetNode(IA64::TPCADDS, MVT::i64, Initial,
|
||||||
CurDAG->getConstant(1, MVT::i64),
|
CurDAG->getConstant(1, MVT::i64),
|
||||||
Tmp), 0);
|
Tmp), 0);
|
||||||
return CurDAG->SelectNodeTo(N, Opc, MVT::Other, Address, Tmp, Chain).Val;
|
return CurDAG->SelectNodeTo(N, Opc, MVT::Other, Address, Tmp, Chain);
|
||||||
}
|
}
|
||||||
case MVT::i64: Opc = IA64::ST8; break;
|
case MVT::i64: Opc = IA64::ST8; break;
|
||||||
case MVT::f64: Opc = IA64::STF8; break;
|
case MVT::f64: Opc = IA64::STF8; break;
|
||||||
@ -524,7 +524,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
SDOperand N2 = N->getOperand(2);
|
SDOperand N2 = N->getOperand(2);
|
||||||
AddToISelQueue(N1);
|
AddToISelQueue(N1);
|
||||||
AddToISelQueue(N2);
|
AddToISelQueue(N2);
|
||||||
return CurDAG->SelectNodeTo(N, Opc, MVT::Other, N2, N1, Chain).Val;
|
return CurDAG->SelectNodeTo(N, Opc, MVT::Other, N2, N1, Chain);
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::BRCOND: {
|
case ISD::BRCOND: {
|
||||||
@ -536,7 +536,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
cast<BasicBlockSDNode>(N->getOperand(2))->getBasicBlock();
|
cast<BasicBlockSDNode>(N->getOperand(2))->getBasicBlock();
|
||||||
//FIXME - we do NOT need long branches all the time
|
//FIXME - we do NOT need long branches all the time
|
||||||
return CurDAG->SelectNodeTo(N, IA64::BRLCOND_NOTCALL, MVT::Other, CC,
|
return CurDAG->SelectNodeTo(N, IA64::BRLCOND_NOTCALL, MVT::Other, CC,
|
||||||
CurDAG->getBasicBlock(Dest), Chain).Val;
|
CurDAG->getBasicBlock(Dest), Chain);
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::CALLSEQ_START:
|
case ISD::CALLSEQ_START:
|
||||||
@ -546,7 +546,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
IA64::ADJUSTCALLSTACKDOWN : IA64::ADJUSTCALLSTACKUP;
|
IA64::ADJUSTCALLSTACKDOWN : IA64::ADJUSTCALLSTACKUP;
|
||||||
SDOperand N0 = N->getOperand(0);
|
SDOperand N0 = N->getOperand(0);
|
||||||
AddToISelQueue(N0);
|
AddToISelQueue(N0);
|
||||||
return CurDAG->SelectNodeTo(N, Opc, MVT::Other, getI64Imm(Amt), N0).Val;
|
return CurDAG->SelectNodeTo(N, Opc, MVT::Other, getI64Imm(Amt), N0);
|
||||||
}
|
}
|
||||||
|
|
||||||
case ISD::BR:
|
case ISD::BR:
|
||||||
@ -554,7 +554,7 @@ SDNode *IA64DAGToDAGISel::Select(SDOperand Op) {
|
|||||||
SDOperand N0 = N->getOperand(0);
|
SDOperand N0 = N->getOperand(0);
|
||||||
AddToISelQueue(N0);
|
AddToISelQueue(N0);
|
||||||
return CurDAG->SelectNodeTo(N, IA64::BRL_NOTCALL, MVT::Other,
|
return CurDAG->SelectNodeTo(N, IA64::BRL_NOTCALL, MVT::Other,
|
||||||
N->getOperand(1), N0).Val;
|
N->getOperand(1), N0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return SelectCode(Op);
|
return SelectCode(Op);
|
||||||
|
@ -812,23 +812,23 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDOperand Op) {
|
|||||||
case ISD::SETEQ:
|
case ISD::SETEQ:
|
||||||
Op = SDOperand(CurDAG->getTargetNode(PPC::CNTLZW, MVT::i32, Op), 0);
|
Op = SDOperand(CurDAG->getTargetNode(PPC::CNTLZW, MVT::i32, Op), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Op, getI32Imm(27),
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Op, getI32Imm(27),
|
||||||
getI32Imm(5), getI32Imm(31)).Val;
|
getI32Imm(5), getI32Imm(31));
|
||||||
case ISD::SETNE: {
|
case ISD::SETNE: {
|
||||||
SDOperand AD =
|
SDOperand AD =
|
||||||
SDOperand(CurDAG->getTargetNode(PPC::ADDIC, MVT::i32, MVT::Flag,
|
SDOperand(CurDAG->getTargetNode(PPC::ADDIC, MVT::i32, MVT::Flag,
|
||||||
Op, getI32Imm(~0U)), 0);
|
Op, getI32Imm(~0U)), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32, AD, Op,
|
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32, AD, Op,
|
||||||
AD.getValue(1)).Val;
|
AD.getValue(1));
|
||||||
}
|
}
|
||||||
case ISD::SETLT:
|
case ISD::SETLT:
|
||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Op, getI32Imm(1),
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Op, getI32Imm(1),
|
||||||
getI32Imm(31), getI32Imm(31)).Val;
|
getI32Imm(31), getI32Imm(31));
|
||||||
case ISD::SETGT: {
|
case ISD::SETGT: {
|
||||||
SDOperand T =
|
SDOperand T =
|
||||||
SDOperand(CurDAG->getTargetNode(PPC::NEG, MVT::i32, Op), 0);
|
SDOperand(CurDAG->getTargetNode(PPC::NEG, MVT::i32, Op), 0);
|
||||||
T = SDOperand(CurDAG->getTargetNode(PPC::ANDC, MVT::i32, T, Op), 0);
|
T = SDOperand(CurDAG->getTargetNode(PPC::ANDC, MVT::i32, T, Op), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, T, getI32Imm(1),
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, T, getI32Imm(1),
|
||||||
getI32Imm(31), getI32Imm(31)).Val;
|
getI32Imm(31), getI32Imm(31));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (Imm == ~0U) { // setcc op, -1
|
} else if (Imm == ~0U) { // setcc op, -1
|
||||||
@ -842,13 +842,13 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDOperand Op) {
|
|||||||
return CurDAG->SelectNodeTo(N, PPC::ADDZE, MVT::i32,
|
return CurDAG->SelectNodeTo(N, PPC::ADDZE, MVT::i32,
|
||||||
SDOperand(CurDAG->getTargetNode(PPC::LI, MVT::i32,
|
SDOperand(CurDAG->getTargetNode(PPC::LI, MVT::i32,
|
||||||
getI32Imm(0)), 0),
|
getI32Imm(0)), 0),
|
||||||
Op.getValue(1)).Val;
|
Op.getValue(1));
|
||||||
case ISD::SETNE: {
|
case ISD::SETNE: {
|
||||||
Op = SDOperand(CurDAG->getTargetNode(PPC::NOR, MVT::i32, Op, Op), 0);
|
Op = SDOperand(CurDAG->getTargetNode(PPC::NOR, MVT::i32, Op, Op), 0);
|
||||||
SDNode *AD = CurDAG->getTargetNode(PPC::ADDIC, MVT::i32, MVT::Flag,
|
SDNode *AD = CurDAG->getTargetNode(PPC::ADDIC, MVT::i32, MVT::Flag,
|
||||||
Op, getI32Imm(~0U));
|
Op, getI32Imm(~0U));
|
||||||
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32, SDOperand(AD, 0),
|
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32, SDOperand(AD, 0),
|
||||||
Op, SDOperand(AD, 1)).Val;
|
Op, SDOperand(AD, 1));
|
||||||
}
|
}
|
||||||
case ISD::SETLT: {
|
case ISD::SETLT: {
|
||||||
SDOperand AD = SDOperand(CurDAG->getTargetNode(PPC::ADDI, MVT::i32, Op,
|
SDOperand AD = SDOperand(CurDAG->getTargetNode(PPC::ADDI, MVT::i32, Op,
|
||||||
@ -856,14 +856,14 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDOperand Op) {
|
|||||||
SDOperand AN = SDOperand(CurDAG->getTargetNode(PPC::AND, MVT::i32, AD,
|
SDOperand AN = SDOperand(CurDAG->getTargetNode(PPC::AND, MVT::i32, AD,
|
||||||
Op), 0);
|
Op), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, AN, getI32Imm(1),
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, AN, getI32Imm(1),
|
||||||
getI32Imm(31), getI32Imm(31)).Val;
|
getI32Imm(31), getI32Imm(31));
|
||||||
}
|
}
|
||||||
case ISD::SETGT:
|
case ISD::SETGT:
|
||||||
Op = SDOperand(CurDAG->getTargetNode(PPC::RLWINM, MVT::i32, Op,
|
Op = SDOperand(CurDAG->getTargetNode(PPC::RLWINM, MVT::i32, Op,
|
||||||
getI32Imm(1), getI32Imm(31),
|
getI32Imm(1), getI32Imm(31),
|
||||||
getI32Imm(31)), 0);
|
getI32Imm(31)), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Op,
|
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Op,
|
||||||
getI32Imm(1)).Val;
|
getI32Imm(1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -889,13 +889,13 @@ SDNode *PPCDAGToDAGISel::SelectSETCC(SDOperand Op) {
|
|||||||
if (!Inv) {
|
if (!Inv) {
|
||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, IntCR,
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, IntCR,
|
||||||
getI32Imm((32-(3-Idx)) & 31),
|
getI32Imm((32-(3-Idx)) & 31),
|
||||||
getI32Imm(31), getI32Imm(31)).Val;
|
getI32Imm(31), getI32Imm(31));
|
||||||
} else {
|
} else {
|
||||||
SDOperand Tmp =
|
SDOperand Tmp =
|
||||||
SDOperand(CurDAG->getTargetNode(PPC::RLWINM, MVT::i32, IntCR,
|
SDOperand(CurDAG->getTargetNode(PPC::RLWINM, MVT::i32, IntCR,
|
||||||
getI32Imm((32-(3-Idx)) & 31),
|
getI32Imm((32-(3-Idx)) & 31),
|
||||||
getI32Imm(31),getI32Imm(31)), 0);
|
getI32Imm(31),getI32Imm(31)), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Tmp, getI32Imm(1)).Val;
|
return CurDAG->SelectNodeTo(N, PPC::XORI, MVT::i32, Tmp, getI32Imm(1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -921,7 +921,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
unsigned Opc = Op.getValueType() == MVT::i32 ? PPC::ADDI : PPC::ADDI8;
|
unsigned Opc = Op.getValueType() == MVT::i32 ? PPC::ADDI : PPC::ADDI8;
|
||||||
if (N->hasOneUse())
|
if (N->hasOneUse())
|
||||||
return CurDAG->SelectNodeTo(N, Opc, Op.getValueType(), TFI,
|
return CurDAG->SelectNodeTo(N, Opc, Op.getValueType(), TFI,
|
||||||
getSmallIPtrImm(0)).Val;
|
getSmallIPtrImm(0));
|
||||||
return CurDAG->getTargetNode(Opc, Op.getValueType(), TFI,
|
return CurDAG->getTargetNode(Opc, Op.getValueType(), TFI,
|
||||||
getSmallIPtrImm(0));
|
getSmallIPtrImm(0));
|
||||||
}
|
}
|
||||||
@ -952,7 +952,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
CurDAG->getTargetNode(PPC::SRAWI, MVT::i32, MVT::Flag,
|
CurDAG->getTargetNode(PPC::SRAWI, MVT::i32, MVT::Flag,
|
||||||
N0, getI32Imm(Log2_32(Imm)));
|
N0, getI32Imm(Log2_32(Imm)));
|
||||||
return CurDAG->SelectNodeTo(N, PPC::ADDZE, MVT::i32,
|
return CurDAG->SelectNodeTo(N, PPC::ADDZE, MVT::i32,
|
||||||
SDOperand(Op, 0), SDOperand(Op, 1)).Val;
|
SDOperand(Op, 0), SDOperand(Op, 1));
|
||||||
} else if ((signed)Imm < 0 && isPowerOf2_32(-Imm)) {
|
} else if ((signed)Imm < 0 && isPowerOf2_32(-Imm)) {
|
||||||
SDNode *Op =
|
SDNode *Op =
|
||||||
CurDAG->getTargetNode(PPC::SRAWI, MVT::i32, MVT::Flag,
|
CurDAG->getTargetNode(PPC::SRAWI, MVT::i32, MVT::Flag,
|
||||||
@ -961,7 +961,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
SDOperand(CurDAG->getTargetNode(PPC::ADDZE, MVT::i32,
|
SDOperand(CurDAG->getTargetNode(PPC::ADDZE, MVT::i32,
|
||||||
SDOperand(Op, 0), SDOperand(Op, 1)),
|
SDOperand(Op, 0), SDOperand(Op, 1)),
|
||||||
0);
|
0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::NEG, MVT::i32, PT).Val;
|
return CurDAG->SelectNodeTo(N, PPC::NEG, MVT::i32, PT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -992,7 +992,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
}
|
}
|
||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Val,
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32, Val,
|
||||||
getI32Imm(SH), getI32Imm(MB),
|
getI32Imm(SH), getI32Imm(MB),
|
||||||
getI32Imm(ME)).Val;
|
getI32Imm(ME));
|
||||||
}
|
}
|
||||||
// ISD::OR doesn't get all the bitfield insertion fun.
|
// ISD::OR doesn't get all the bitfield insertion fun.
|
||||||
// (and (or x, c1), c2) where isRunOfOnes(~(c1^c2)) is a bitfield insert
|
// (and (or x, c1), c2) where isRunOfOnes(~(c1^c2)) is a bitfield insert
|
||||||
@ -1029,7 +1029,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32,
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32,
|
||||||
N->getOperand(0).getOperand(0),
|
N->getOperand(0).getOperand(0),
|
||||||
getI32Imm(SH), getI32Imm(MB),
|
getI32Imm(SH), getI32Imm(MB),
|
||||||
getI32Imm(ME)).Val;
|
getI32Imm(ME));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Other cases are autogenerated.
|
// Other cases are autogenerated.
|
||||||
@ -1043,7 +1043,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32,
|
return CurDAG->SelectNodeTo(N, PPC::RLWINM, MVT::i32,
|
||||||
N->getOperand(0).getOperand(0),
|
N->getOperand(0).getOperand(0),
|
||||||
getI32Imm(SH), getI32Imm(MB),
|
getI32Imm(SH), getI32Imm(MB),
|
||||||
getI32Imm(ME)).Val;
|
getI32Imm(ME));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Other cases are autogenerated.
|
// Other cases are autogenerated.
|
||||||
@ -1066,7 +1066,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
N->getOperand(0), getI32Imm(~0U));
|
N->getOperand(0), getI32Imm(~0U));
|
||||||
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32,
|
return CurDAG->SelectNodeTo(N, PPC::SUBFE, MVT::i32,
|
||||||
SDOperand(Tmp, 0), N->getOperand(0),
|
SDOperand(Tmp, 0), N->getOperand(0),
|
||||||
SDOperand(Tmp, 1)).Val;
|
SDOperand(Tmp, 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
SDOperand CCReg = SelectCC(N->getOperand(0), N->getOperand(1), CC);
|
SDOperand CCReg = SelectCC(N->getOperand(0), N->getOperand(1), CC);
|
||||||
@ -1089,7 +1089,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
AddToISelQueue(N->getOperand(3));
|
AddToISelQueue(N->getOperand(3));
|
||||||
return CurDAG->SelectNodeTo(N, SelectCCOp, N->getValueType(0), CCReg,
|
return CurDAG->SelectNodeTo(N, SelectCCOp, N->getValueType(0), CCReg,
|
||||||
N->getOperand(2), N->getOperand(3),
|
N->getOperand(2), N->getOperand(3),
|
||||||
getI32Imm(BROpc)).Val;
|
getI32Imm(BROpc));
|
||||||
}
|
}
|
||||||
case ISD::BR_CC: {
|
case ISD::BR_CC: {
|
||||||
AddToISelQueue(N->getOperand(0));
|
AddToISelQueue(N->getOperand(0));
|
||||||
@ -1097,7 +1097,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
SDOperand CondCode = SelectCC(N->getOperand(2), N->getOperand(3), CC);
|
SDOperand CondCode = SelectCC(N->getOperand(2), N->getOperand(3), CC);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::COND_BRANCH, MVT::Other,
|
return CurDAG->SelectNodeTo(N, PPC::COND_BRANCH, MVT::Other,
|
||||||
CondCode, getI32Imm(getBCCForSetCC(CC)),
|
CondCode, getI32Imm(getBCCForSetCC(CC)),
|
||||||
N->getOperand(4), N->getOperand(0)).Val;
|
N->getOperand(4), N->getOperand(0));
|
||||||
}
|
}
|
||||||
case ISD::BRIND: {
|
case ISD::BRIND: {
|
||||||
// FIXME: Should custom lower this.
|
// FIXME: Should custom lower this.
|
||||||
@ -1108,7 +1108,7 @@ SDNode *PPCDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
unsigned Opc = Target.getValueType() == MVT::i32 ? PPC::MTCTR : PPC::MTCTR8;
|
unsigned Opc = Target.getValueType() == MVT::i32 ? PPC::MTCTR : PPC::MTCTR8;
|
||||||
Chain = SDOperand(CurDAG->getTargetNode(Opc, MVT::Other, Target,
|
Chain = SDOperand(CurDAG->getTargetNode(Opc, MVT::Other, Target,
|
||||||
Chain), 0);
|
Chain), 0);
|
||||||
return CurDAG->SelectNodeTo(N, PPC::BCTR, MVT::Other, Chain).Val;
|
return CurDAG->SelectNodeTo(N, PPC::BCTR, MVT::Other, Chain);
|
||||||
}
|
}
|
||||||
// FIXME: These are manually selected because tblgen isn't handling varargs
|
// FIXME: These are manually selected because tblgen isn't handling varargs
|
||||||
// nodes correctly.
|
// nodes correctly.
|
||||||
|
@ -1093,7 +1093,7 @@ SDNode *SparcDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
// FIXME: Handle div by immediate.
|
// FIXME: Handle div by immediate.
|
||||||
unsigned Opcode = N->getOpcode() == ISD::SDIV ? SP::SDIVrr : SP::UDIVrr;
|
unsigned Opcode = N->getOpcode() == ISD::SDIV ? SP::SDIVrr : SP::UDIVrr;
|
||||||
return CurDAG->SelectNodeTo(N, Opcode, MVT::i32, DivLHS, DivRHS,
|
return CurDAG->SelectNodeTo(N, Opcode, MVT::i32, DivLHS, DivRHS,
|
||||||
TopPart).Val;
|
TopPart);
|
||||||
}
|
}
|
||||||
case ISD::MULHU:
|
case ISD::MULHU:
|
||||||
case ISD::MULHS: {
|
case ISD::MULHS: {
|
||||||
@ -1106,7 +1106,7 @@ SDNode *SparcDAGToDAGISel::Select(SDOperand Op) {
|
|||||||
SDNode *Mul = CurDAG->getTargetNode(Opcode, MVT::i32, MVT::Flag,
|
SDNode *Mul = CurDAG->getTargetNode(Opcode, MVT::i32, MVT::Flag,
|
||||||
MulLHS, MulRHS);
|
MulLHS, MulRHS);
|
||||||
// The high part is in the Y register.
|
// The high part is in the Y register.
|
||||||
return CurDAG->SelectNodeTo(N, SP::RDY, MVT::i32, SDOperand(Mul, 1)).Val;
|
return CurDAG->SelectNodeTo(N, SP::RDY, MVT::i32, SDOperand(Mul, 1));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -658,7 +658,7 @@ SDNode *X86DAGToDAGISel::Select(SDOperand N) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (C.Val)
|
if (C.Val)
|
||||||
return CurDAG->SelectNodeTo(N.Val, X86::MOV32ri, MVT::i32, C).Val;
|
return CurDAG->SelectNodeTo(N.Val, X86::MOV32ri, MVT::i32, C);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Other cases are handled by auto-generated code.
|
// Other cases are handled by auto-generated code.
|
||||||
|
@ -2796,7 +2796,7 @@ public:
|
|||||||
Code += ", " + AllOps[i];
|
Code += ", " + AllOps[i];
|
||||||
if (NodeHasInFlag || HasImpInputs)
|
if (NodeHasInFlag || HasImpInputs)
|
||||||
Code += ", InFlag";
|
Code += ", InFlag";
|
||||||
emitCode(Code + ").Val;");
|
emitCode(Code + ");");
|
||||||
emitOpcode(II.Namespace + "::" + II.TheDef->getName());
|
emitOpcode(II.Namespace + "::" + II.TheDef->getName());
|
||||||
if (N->getTypeNum(0) != MVT::isVoid)
|
if (N->getTypeNum(0) != MVT::isVoid)
|
||||||
emitVT(getEnumName(N->getTypeNum(0)));
|
emitVT(getEnumName(N->getTypeNum(0)));
|
||||||
|
Loading…
Reference in New Issue
Block a user