constant fold sign_extend_inreg

llvm-svn: 28151
This commit is contained in:
Chris Lattner 2006-05-06 23:05:41 +00:00
parent 2a4d7b845b
commit 751817c54f
1 changed files with 9 additions and 1 deletions

View File

@ -1335,6 +1335,14 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT,
ConstantSDNode *N1C = dyn_cast<ConstantSDNode>(N1.Val); ConstantSDNode *N1C = dyn_cast<ConstantSDNode>(N1.Val);
ConstantSDNode *N2C = dyn_cast<ConstantSDNode>(N2.Val); ConstantSDNode *N2C = dyn_cast<ConstantSDNode>(N2.Val);
if (N1C) { if (N1C) {
if (Opcode == ISD::SIGN_EXTEND_INREG) {
int64_t Val = N1C->getValue();
unsigned FromBits = MVT::getSizeInBits(cast<VTSDNode>(N2)->getVT());
Val <<= 64-FromBits;
Val >>= 64-FromBits;
return getConstant(Val, VT);
}
if (N2C) { if (N2C) {
uint64_t C1 = N1C->getValue(), C2 = N2C->getValue(); uint64_t C1 = N1C->getValue(), C2 = N2C->getValue();
switch (Opcode) { switch (Opcode) {
@ -1441,7 +1449,7 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT,
} }
} }
// Fold a bunch of operators that // Fold a bunch of operators when the RHS is undef.
if (N2.getOpcode() == ISD::UNDEF) { if (N2.getOpcode() == ISD::UNDEF) {
switch (Opcode) { switch (Opcode) {
case ISD::ADD: case ISD::ADD: