forked from OSchip/llvm-project
[InstCombine] fix formatting for matchBSwap(); NFC
We should have a similar function for matching rotate and/or funnel shift, so tidy up the related existing call. llvm-svn: 346871
This commit is contained in:
parent
6df11868b5
commit
6072842770
|
@ -1762,10 +1762,9 @@ Instruction *InstCombiner::visitAnd(BinaryOperator &I) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Given an OR instruction, check to see if this is a bswap idiom. If so,
|
Instruction *InstCombiner::matchBSwap(BinaryOperator &Or) {
|
||||||
/// insert the new intrinsic and return it.
|
assert(Or.getOpcode() == Instruction::Or && "bswap requires an 'or'");
|
||||||
Instruction *InstCombiner::MatchBSwap(BinaryOperator &I) {
|
Value *Op0 = Or.getOperand(0), *Op1 = Or.getOperand(1);
|
||||||
Value *Op0 = I.getOperand(0), *Op1 = I.getOperand(1);
|
|
||||||
|
|
||||||
// Look through zero extends.
|
// Look through zero extends.
|
||||||
if (Instruction *Ext = dyn_cast<ZExtInst>(Op0))
|
if (Instruction *Ext = dyn_cast<ZExtInst>(Op0))
|
||||||
|
@ -1801,7 +1800,7 @@ Instruction *InstCombiner::MatchBSwap(BinaryOperator &I) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
SmallVector<Instruction*, 4> Insts;
|
SmallVector<Instruction*, 4> Insts;
|
||||||
if (!recognizeBSwapOrBitReverseIdiom(&I, true, false, Insts))
|
if (!recognizeBSwapOrBitReverseIdiom(&Or, true, false, Insts))
|
||||||
return nullptr;
|
return nullptr;
|
||||||
Instruction *LastInst = Insts.pop_back_val();
|
Instruction *LastInst = Insts.pop_back_val();
|
||||||
LastInst->removeFromParent();
|
LastInst->removeFromParent();
|
||||||
|
@ -2168,7 +2167,7 @@ Instruction *InstCombiner::visitOr(BinaryOperator &I) {
|
||||||
if (Instruction *FoldedLogic = foldBinOpIntoSelectOrPhi(I))
|
if (Instruction *FoldedLogic = foldBinOpIntoSelectOrPhi(I))
|
||||||
return FoldedLogic;
|
return FoldedLogic;
|
||||||
|
|
||||||
if (Instruction *BSwap = MatchBSwap(I))
|
if (Instruction *BSwap = matchBSwap(I))
|
||||||
return BSwap;
|
return BSwap;
|
||||||
|
|
||||||
Value *X, *Y;
|
Value *X, *Y;
|
||||||
|
|
|
@ -919,9 +919,12 @@ private:
|
||||||
Value *insertRangeTest(Value *V, const APInt &Lo, const APInt &Hi,
|
Value *insertRangeTest(Value *V, const APInt &Lo, const APInt &Hi,
|
||||||
bool isSigned, bool Inside);
|
bool isSigned, bool Inside);
|
||||||
Instruction *PromoteCastOfAllocation(BitCastInst &CI, AllocaInst &AI);
|
Instruction *PromoteCastOfAllocation(BitCastInst &CI, AllocaInst &AI);
|
||||||
Instruction *MatchBSwap(BinaryOperator &I);
|
|
||||||
bool mergeStoreIntoSuccessor(StoreInst &SI);
|
bool mergeStoreIntoSuccessor(StoreInst &SI);
|
||||||
|
|
||||||
|
/// Given an 'or' instruction, check to see if it is part of a bswap idiom.
|
||||||
|
/// If so, return the equivalent bswap intrinsic.
|
||||||
|
Instruction *matchBSwap(BinaryOperator &Or);
|
||||||
|
|
||||||
Instruction *SimplifyAnyMemTransfer(AnyMemTransferInst *MI);
|
Instruction *SimplifyAnyMemTransfer(AnyMemTransferInst *MI);
|
||||||
Instruction *SimplifyAnyMemSet(AnyMemSetInst *MI);
|
Instruction *SimplifyAnyMemSet(AnyMemSetInst *MI);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue