mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-06 09:44:39 +00:00
Add a missing case to the dag combiner.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25723 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0ff5c27a00
commit
61af66e687
@ -1035,9 +1035,10 @@ SDOperand DAGCombiner::visitAND(SDNode *N) {
|
||||
WorkList.push_back(ANDNode.Val);
|
||||
return DAG.getNode(ISD::ZERO_EXTEND, VT, ANDNode);
|
||||
}
|
||||
// fold (and (shl/srl x), (shl/srl y)) -> (shl/srl (and x, y))
|
||||
// fold (and (shl/srl/sra x), (shl/srl/sra y)) -> (shl/srl/sra (and x, y))
|
||||
if (((N0.getOpcode() == ISD::SHL && N1.getOpcode() == ISD::SHL) ||
|
||||
(N0.getOpcode() == ISD::SRL && N1.getOpcode() == ISD::SRL)) &&
|
||||
(N0.getOpcode() == ISD::SRL && N1.getOpcode() == ISD::SRL) ||
|
||||
(N0.getOpcode() == ISD::SRA && N1.getOpcode() == ISD::SRA)) &&
|
||||
N0.getOperand(1) == N1.getOperand(1)) {
|
||||
SDOperand ANDNode = DAG.getNode(ISD::AND, N0.getOperand(0).getValueType(),
|
||||
N0.getOperand(0), N1.getOperand(0));
|
||||
|
Loading…
x
Reference in New Issue
Block a user