[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:
Sanjay Patel 2018-11-14 16:03:36 +00:00
parent 6df11868b5
commit 6072842770
2 changed files with 9 additions and 7 deletions

View File

@ -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;

View File

@ -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);