LLVM 23.0.0git
AggressiveInstCombine.cpp
Go to the documentation of this file.
1//===- AggressiveInstCombine.cpp ------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file implements the aggressive expression pattern combiner classes.
10// Currently, it handles expression patterns for:
11// * Truncate instruction
12//
13//===----------------------------------------------------------------------===//
14
17#include "llvm/ADT/Statistic.h"
27#include "llvm/IR/DataLayout.h"
28#include "llvm/IR/Dominators.h"
29#include "llvm/IR/Function.h"
30#include "llvm/IR/IRBuilder.h"
31#include "llvm/IR/Instruction.h"
32#include "llvm/IR/MDBuilder.h"
40
41using namespace llvm;
42using namespace PatternMatch;
43
44#define DEBUG_TYPE "aggressive-instcombine"
45
46namespace llvm {
48}
49
50STATISTIC(NumAnyOrAllBitsSet, "Number of any/all-bits-set patterns folded");
51STATISTIC(NumGuardedRotates,
52 "Number of guarded rotates transformed into funnel shifts");
53STATISTIC(NumGuardedFunnelShifts,
54 "Number of guarded funnel shifts transformed into funnel shifts");
55STATISTIC(NumPopCountRecognized, "Number of popcount idioms recognized");
56STATISTIC(NumSelectCTTZFolded,
57 "Number of select-based split cttz patterns folded");
58STATISTIC(NumSelectCTLZFolded,
59 "Number of select-based split ctlz patterns folded");
60
62 "aggressive-instcombine-max-scan-instrs", cl::init(64), cl::Hidden,
63 cl::desc("Max number of instructions to scan for aggressive instcombine."));
64
66 "strncmp-inline-threshold", cl::init(3), cl::Hidden,
67 cl::desc("The maximum length of a constant string for a builtin string cmp "
68 "call eligible for inlining. The default value is 3."));
69
71 MemChrInlineThreshold("memchr-inline-threshold", cl::init(3), cl::Hidden,
72 cl::desc("The maximum length of a constant string to "
73 "inline a memchr call."));
74
75/// Try to fold a select-based split cttz pattern into a single full-width cttz.
76///
77/// %lo = trunc iN %val to i(N/2)
78/// %cmp = icmp eq i(N/2) %lo, 0
79/// %shr = lshr iN %val, N/2
80/// %hi = trunc iN %shr to i(N/2)
81/// %cttz_hi = call i(N/2) @llvm.cttz.i(N/2)(i(N/2) %hi, ...)
82/// %hi_plus = add/or_disjoint i(N/2) %cttz_hi, N/2
83/// %cttz_lo = call i(N/2) @llvm.cttz.i(N/2)(i(N/2) %lo, ...)
84/// %result = select i1 %cmp, i(N/2) %hi_plus, i(N/2) %cttz_lo
85/// -->
86/// %cttz_wide = call iN @llvm.cttz.iN(iN %val, i1 false)
87/// %result = trunc iN %cttz_wide to i(N/2)
88/// Alive proof (for i64/i32): https://alive2.llvm.org/ce/z/-s14-s
90 Value *Cond, *TrueVal, *FalseVal;
91 if (!match(&I, m_Select(m_Value(Cond), m_Value(TrueVal), m_Value(FalseVal))))
92 return false;
93
94 Type *HalfTy = I.getType();
95 if (!HalfTy->isIntegerTy())
96 return false;
97 unsigned HalfWidth = HalfTy->getIntegerBitWidth();
98
99 // Bail out on very small types (i1, i2): the full-width cttz can return
100 // values not representable in the half type (e.g., cttz.i4 can return 4,
101 // which doesn't fit in i2).
102 if (HalfWidth <= 2)
103 return false;
104
105 unsigned FullWidth = HalfWidth * 2;
106
107 // select (icmp eq (trunc SrcVal to i(N/2)), 0), HiResult, LoResult
108 // Or select (icmp ne ...), LoResult, HiResult
109 Value *LoTrunc;
110 Value *HiResult, *LoResult;
111 if (match(Cond,
113 HiResult = TrueVal;
114 LoResult = FalseVal;
115 } else if (match(Cond, m_SpecificICmp(CmpInst::ICMP_NE, m_Value(LoTrunc),
116 m_ZeroInt()))) {
117 HiResult = FalseVal;
118 LoResult = TrueVal;
119 } else {
120 return false;
121 }
122
123 // LoTrunc: trunc iN SrcVal to i(N/2)
124 Value *SrcVal;
125 if (!match(LoTrunc, m_Trunc(m_Value(SrcVal))))
126 return false;
127 if (!SrcVal->getType()->isIntegerTy(FullWidth))
128 return false;
129
130 // LoResult: cttz(trunc(SrcVal), _), must use same truncated value
131 if (!match(LoResult, m_OneUse(m_Cttz(m_Specific(LoTrunc), m_Value()))))
132 return false;
133
134 // HiResult: add/or_disjoint(cttz(trunc(lshr(SrcVal, N/2)), _), N/2)
135 Value *CttzHiCall;
136 if (!match(HiResult, m_OneUse(m_AddLike(m_Value(CttzHiCall),
137 m_SpecificInt(HalfWidth)))))
138 return false;
139
140 Value *HiCttzArg;
141 if (!match(CttzHiCall, m_OneUse(m_Cttz(m_Value(HiCttzArg), m_Value()))))
142 return false;
143
144 if (!match(HiCttzArg,
145 m_Trunc(m_LShr(m_Specific(SrcVal), m_SpecificInt(HalfWidth)))))
146 return false;
147
148 // Match successful.
149 IRBuilder<> Builder(&I);
150 Value *CttzWide = Builder.CreateIntrinsic(
151 Intrinsic::cttz, {SrcVal->getType()}, {SrcVal, Builder.getFalse()});
152 Value *Trunc = Builder.CreateTrunc(CttzWide, HalfTy);
153
154 I.replaceAllUsesWith(Trunc);
155 ++NumSelectCTTZFolded;
156 return true;
157}
158
159/// Same as foldSelectSplitCTTZ but for leading zeros (ctlz).
160///
161/// %shr = lshr iN %val, N/2
162/// %hi = trunc iN %shr to i(N/2)
163/// %cmp = icmp eq i(N/2) %hi, 0 (or icmp eq iN %shr, 0)
164/// %lo = trunc iN %val to i(N/2)
165/// %ctlz_lo = call i(N/2) @llvm.ctlz.i(N/2)(i(N/2) %lo, ...)
166/// %lo_plus = add/or_disjoint i(N/2) %ctlz_lo, N/2
167/// %ctlz_hi = call i(N/2) @llvm.ctlz.i(N/2)(i(N/2) %hi, ...)
168/// %result = select i1 %cmp, i(N/2) %lo_plus, i(N/2) %ctlz_hi
169/// -->
170/// %ctlz_wide = call iN @llvm.ctlz.iN(iN %val, i1 false)
171/// %result = trunc iN %ctlz_wide to i(N/2)
172///
173/// Alive proof (for i64/i32): https://alive2.llvm.org/ce/z/WfQepH
175 Value *Cond, *TrueVal, *FalseVal;
176 if (!match(&I, m_Select(m_Value(Cond), m_Value(TrueVal), m_Value(FalseVal))))
177 return false;
178
179 Type *HalfTy = I.getType();
180 if (!HalfTy->isIntegerTy())
181 return false;
182 unsigned HalfWidth = HalfTy->getIntegerBitWidth();
183
184 // Bail out on very small types (i1, i2): the full-width ctlz can return
185 // values not representable in the half type (e.g., ctlz.i4 can return 4,
186 // which doesn't fit in i2).
187 if (HalfWidth <= 2)
188 return false;
189
190 unsigned FullWidth = HalfWidth * 2;
191
192 // select (icmp eq HiPart, 0), LoResult, HiResult
193 // HiPart could be (trunc (lshr SrcVal, N/2) to i(N/2)) or (lshr SrcVal, N/2)
194 Value *HiPart;
195 Value *LoResult, *HiResult;
196 if (match(Cond,
198 LoResult = TrueVal; // upper is zero: count in lower + N/2
199 HiResult = FalseVal; // upper non-zero: count in upper
200 } else if (match(Cond, m_SpecificICmp(CmpInst::ICMP_NE, m_Value(HiPart),
201 m_ZeroInt()))) {
202 LoResult = FalseVal;
203 HiResult = TrueVal;
204 } else {
205 return false;
206 }
207
208 // Extract SrcVal from HiPart: either trunc(lshr(SrcVal, N/2)) or
209 // lshr(SrcVal, N/2)
210 Value *SrcVal;
211 if (match(HiPart,
212 m_Trunc(m_LShr(m_Value(SrcVal), m_SpecificInt(HalfWidth))))) {
213 // HiPart is trunc(lshr(SrcVal, N/2))
214 } else if (match(HiPart, m_LShr(m_Value(SrcVal), m_SpecificInt(HalfWidth)))) {
215 // HiPart is lshr(SrcVal, N/2)
216 } else {
217 return false;
218 }
219 if (!SrcVal->getType()->isIntegerTy(FullWidth))
220 return false;
221
222 // HiResult: ctlz(trunc(lshr(SrcVal, N/2)), _)
223 Value *HiCtlzArg;
224 if (!match(HiResult, m_OneUse(m_Ctlz(m_Value(HiCtlzArg), m_Value()))))
225 return false;
226
227 if (!match(HiCtlzArg,
228 m_Trunc(m_LShr(m_Specific(SrcVal), m_SpecificInt(HalfWidth)))))
229 return false;
230
231 // LoResult: add/or_disjoint(ctlz(trunc(SrcVal), _), N/2)
232 Value *CtlzLoCall;
233 if (!match(LoResult, m_OneUse(m_AddLike(m_Value(CtlzLoCall),
234 m_SpecificInt(HalfWidth)))))
235 return false;
236
237 Value *LoCtlzArg;
238 if (!match(CtlzLoCall, m_OneUse(m_Ctlz(m_Value(LoCtlzArg), m_Value()))))
239 return false;
240
241 if (!match(LoCtlzArg, m_Trunc(m_Specific(SrcVal))))
242 return false;
243
244 // Match successful.
245 IRBuilder<> Builder(&I);
246 Value *CtlzWide = Builder.CreateIntrinsic(
247 Intrinsic::ctlz, {SrcVal->getType()}, {SrcVal, Builder.getFalse()});
248 Value *Trunc = Builder.CreateTrunc(CtlzWide, HalfTy);
249
250 I.replaceAllUsesWith(Trunc);
251 ++NumSelectCTLZFolded;
252 return true;
253}
254
255/// Match a pattern for a bitwise funnel/rotate operation that partially guards
256/// against undefined behavior by branching around the funnel-shift/rotation
257/// when the shift amount is 0.
259 if (I.getOpcode() != Instruction::PHI || I.getNumOperands() != 2)
260 return false;
261
262 // As with the one-use checks below, this is not strictly necessary, but we
263 // are being cautious to avoid potential perf regressions on targets that
264 // do not actually have a funnel/rotate instruction (where the funnel shift
265 // would be expanded back into math/shift/logic ops).
266 if (!isPowerOf2_32(I.getType()->getScalarSizeInBits()))
267 return false;
268
269 // Match V to funnel shift left/right and capture the source operands and
270 // shift amount.
271 auto matchFunnelShift = [](Value *V, Value *&ShVal0, Value *&ShVal1,
272 Value *&ShAmt) {
273 unsigned Width = V->getType()->getScalarSizeInBits();
274
275 // fshl(ShVal0, ShVal1, ShAmt)
276 // == (ShVal0 << ShAmt) | (ShVal1 >> (Width -ShAmt))
277 if (match(V, m_OneUse(m_c_Or(
278 m_Shl(m_Value(ShVal0), m_Value(ShAmt)),
279 m_LShr(m_Value(ShVal1), m_Sub(m_SpecificInt(Width),
280 m_Deferred(ShAmt))))))) {
281 return Intrinsic::fshl;
282 }
283
284 // fshr(ShVal0, ShVal1, ShAmt)
285 // == (ShVal0 >> ShAmt) | (ShVal1 << (Width - ShAmt))
286 if (match(V,
288 m_Value(ShAmt))),
289 m_LShr(m_Value(ShVal1), m_Deferred(ShAmt)))))) {
290 return Intrinsic::fshr;
291 }
292
294 };
295
296 // One phi operand must be a funnel/rotate operation, and the other phi
297 // operand must be the source value of that funnel/rotate operation:
298 // phi [ rotate(RotSrc, ShAmt), FunnelBB ], [ RotSrc, GuardBB ]
299 // phi [ fshl(ShVal0, ShVal1, ShAmt), FunnelBB ], [ ShVal0, GuardBB ]
300 // phi [ fshr(ShVal0, ShVal1, ShAmt), FunnelBB ], [ ShVal1, GuardBB ]
301 PHINode &Phi = cast<PHINode>(I);
302 unsigned FunnelOp = 0, GuardOp = 1;
303 Value *P0 = Phi.getOperand(0), *P1 = Phi.getOperand(1);
304 Value *ShVal0, *ShVal1, *ShAmt;
305 Intrinsic::ID IID = matchFunnelShift(P0, ShVal0, ShVal1, ShAmt);
306 if (IID == Intrinsic::not_intrinsic ||
307 (IID == Intrinsic::fshl && ShVal0 != P1) ||
308 (IID == Intrinsic::fshr && ShVal1 != P1)) {
309 IID = matchFunnelShift(P1, ShVal0, ShVal1, ShAmt);
310 if (IID == Intrinsic::not_intrinsic ||
311 (IID == Intrinsic::fshl && ShVal0 != P0) ||
312 (IID == Intrinsic::fshr && ShVal1 != P0))
313 return false;
314 assert((IID == Intrinsic::fshl || IID == Intrinsic::fshr) &&
315 "Pattern must match funnel shift left or right");
316 std::swap(FunnelOp, GuardOp);
317 }
318
319 // The incoming block with our source operand must be the "guard" block.
320 // That must contain a cmp+branch to avoid the funnel/rotate when the shift
321 // amount is equal to 0. The other incoming block is the block with the
322 // funnel/rotate.
323 BasicBlock *GuardBB = Phi.getIncomingBlock(GuardOp);
324 BasicBlock *FunnelBB = Phi.getIncomingBlock(FunnelOp);
325 Instruction *TermI = GuardBB->getTerminator();
326
327 // Ensure that the shift values dominate each block.
328 if (!DT.dominates(ShVal0, TermI) || !DT.dominates(ShVal1, TermI))
329 return false;
330
331 BasicBlock *PhiBB = Phi.getParent();
333 m_ZeroInt()),
334 m_SpecificBB(PhiBB), m_SpecificBB(FunnelBB))))
335 return false;
336
337 IRBuilder<> Builder(PhiBB, PhiBB->getFirstInsertionPt());
338
339 if (ShVal0 == ShVal1)
340 ++NumGuardedRotates;
341 else
342 ++NumGuardedFunnelShifts;
343
344 // If this is not a rotate then the select was blocking poison from the
345 // 'shift-by-zero' non-TVal, but a funnel shift won't - so freeze it.
346 bool IsFshl = IID == Intrinsic::fshl;
347 if (ShVal0 != ShVal1) {
348 if (IsFshl && !llvm::isGuaranteedNotToBePoison(ShVal1))
349 ShVal1 = Builder.CreateFreeze(ShVal1);
350 else if (!IsFshl && !llvm::isGuaranteedNotToBePoison(ShVal0))
351 ShVal0 = Builder.CreateFreeze(ShVal0);
352 }
353
354 // We matched a variation of this IR pattern:
355 // GuardBB:
356 // %cmp = icmp eq i32 %ShAmt, 0
357 // br i1 %cmp, label %PhiBB, label %FunnelBB
358 // FunnelBB:
359 // %sub = sub i32 32, %ShAmt
360 // %shr = lshr i32 %ShVal1, %sub
361 // %shl = shl i32 %ShVal0, %ShAmt
362 // %fsh = or i32 %shr, %shl
363 // br label %PhiBB
364 // PhiBB:
365 // %cond = phi i32 [ %fsh, %FunnelBB ], [ %ShVal0, %GuardBB ]
366 // -->
367 // llvm.fshl.i32(i32 %ShVal0, i32 %ShVal1, i32 %ShAmt)
368 Phi.replaceAllUsesWith(
369 Builder.CreateIntrinsic(IID, Phi.getType(), {ShVal0, ShVal1, ShAmt}));
370 return true;
371}
372
373/// This is used by foldAnyOrAllBitsSet() to capture a source value (Root) and
374/// the bit indexes (Mask) needed by a masked compare. If we're matching a chain
375/// of 'and' ops, then we also need to capture the fact that we saw an
376/// "and X, 1", so that's an extra return value for that case.
377namespace {
378struct MaskOps {
379 Value *Root = nullptr;
380 APInt Mask;
381 bool MatchAndChain;
382 bool FoundAnd1 = false;
383
384 MaskOps(unsigned BitWidth, bool MatchAnds)
385 : Mask(APInt::getZero(BitWidth)), MatchAndChain(MatchAnds) {}
386};
387} // namespace
388
389/// This is a recursive helper for foldAnyOrAllBitsSet() that walks through a
390/// chain of 'and' or 'or' instructions looking for shift ops of a common source
391/// value. Examples:
392/// or (or (or X, (X >> 3)), (X >> 5)), (X >> 8)
393/// returns { X, 0x129 }
394/// and (and (X >> 1), 1), (X >> 4)
395/// returns { X, 0x12 }
396static bool matchAndOrChain(Value *V, MaskOps &MOps) {
397 Value *Op0, *Op1;
398 if (MOps.MatchAndChain) {
399 // Recurse through a chain of 'and' operands. This requires an extra check
400 // vs. the 'or' matcher: we must find an "and X, 1" instruction somewhere
401 // in the chain to know that all of the high bits are cleared.
402 if (match(V, m_And(m_Value(Op0), m_One()))) {
403 MOps.FoundAnd1 = true;
404 return matchAndOrChain(Op0, MOps);
405 }
406 if (match(V, m_And(m_Value(Op0), m_Value(Op1))))
407 return matchAndOrChain(Op0, MOps) && matchAndOrChain(Op1, MOps);
408 } else {
409 // Recurse through a chain of 'or' operands.
410 if (match(V, m_Or(m_Value(Op0), m_Value(Op1))))
411 return matchAndOrChain(Op0, MOps) && matchAndOrChain(Op1, MOps);
412 }
413
414 // We need a shift-right or a bare value representing a compare of bit 0 of
415 // the original source operand.
416 Value *Candidate;
417 const APInt *BitIndex = nullptr;
418 if (!match(V, m_LShr(m_Value(Candidate), m_APInt(BitIndex))))
419 Candidate = V;
420
421 // Initialize result source operand.
422 if (!MOps.Root)
423 MOps.Root = Candidate;
424
425 // The shift constant is out-of-range? This code hasn't been simplified.
426 if (BitIndex && BitIndex->uge(MOps.Mask.getBitWidth()))
427 return false;
428
429 // Fill in the mask bit derived from the shift constant.
430 MOps.Mask.setBit(BitIndex ? BitIndex->getZExtValue() : 0);
431 return MOps.Root == Candidate;
432}
433
434/// Match patterns that correspond to "any-bits-set" and "all-bits-set".
435/// These will include a chain of 'or' or 'and'-shifted bits from a
436/// common source value:
437/// and (or (lshr X, C), ...), 1 --> (X & CMask) != 0
438/// and (and (lshr X, C), ...), 1 --> (X & CMask) == CMask
439/// Note: "any-bits-clear" and "all-bits-clear" are variations of these patterns
440/// that differ only with a final 'not' of the result. We expect that final
441/// 'not' to be folded with the compare that we create here (invert predicate).
443 // The 'any-bits-set' ('or' chain) pattern is simpler to match because the
444 // final "and X, 1" instruction must be the final op in the sequence.
445 bool MatchAllBitsSet;
446 bool MatchTrunc;
447 Value *X;
448 if (I.getType()->isIntOrIntVectorTy(1)) {
449 if (match(&I, m_Trunc(m_OneUse(m_And(m_Value(), m_Value())))))
450 MatchAllBitsSet = true;
451 else if (match(&I, m_Trunc(m_OneUse(m_Or(m_Value(), m_Value())))))
452 MatchAllBitsSet = false;
453 else
454 return false;
455 MatchTrunc = true;
456 X = I.getOperand(0);
457 } else {
458 if (match(&I, m_c_And(m_OneUse(m_And(m_Value(), m_Value())), m_Value()))) {
459 X = &I;
460 MatchAllBitsSet = true;
461 } else if (match(&I,
462 m_And(m_OneUse(m_Or(m_Value(), m_Value())), m_One()))) {
463 X = I.getOperand(0);
464 MatchAllBitsSet = false;
465 } else
466 return false;
467 MatchTrunc = false;
468 }
469 Type *Ty = X->getType();
470
471 MaskOps MOps(Ty->getScalarSizeInBits(), MatchAllBitsSet);
472 if (!matchAndOrChain(X, MOps) ||
473 (MatchAllBitsSet && !MatchTrunc && !MOps.FoundAnd1))
474 return false;
475
476 // The pattern was found. Create a masked compare that replaces all of the
477 // shift and logic ops.
478 IRBuilder<> Builder(&I);
479 Constant *Mask = ConstantInt::get(Ty, MOps.Mask);
480 Value *And = Builder.CreateAnd(MOps.Root, Mask);
481 Value *Cmp = MatchAllBitsSet ? Builder.CreateICmpEQ(And, Mask)
482 : Builder.CreateIsNotNull(And);
483 Value *Zext = MatchTrunc ? Cmp : Builder.CreateZExt(Cmp, Ty);
484 I.replaceAllUsesWith(Zext);
485 ++NumAnyOrAllBitsSet;
486 return true;
487}
488
489/// Helper function to replace an instruction with a popcount intrinsic.
490/// This creates the ctpop intrinsic with an optional truncation appended at the
491/// end, and replaces all uses of the instruction.
493 LLVM_DEBUG(dbgs() << "Recognized popcount intrinsic\n");
494 Type *RootTy = Root->getType();
495 Type *OrigTy = I.getType();
496
497 IRBuilder<> Builder(&I);
498 Value *NewVal = Builder.CreateIntrinsic(Intrinsic::ctpop, RootTy, {Root});
499 if (OrigTy != RootTy) {
500 assert(RootTy->getScalarSizeInBits() > OrigTy->getScalarSizeInBits() &&
501 "Only truncation is supported for now");
502 NewVal = Builder.CreateTrunc(NewVal, OrigTy);
503 }
504 I.replaceAllUsesWith(NewVal);
505 ++NumPopCountRecognized;
506}
507
508// Try to recognize below function as popcount intrinsic.
509// This is the "best" algorithm from
510// http://graphics.stanford.edu/~seander/bithacks.html#CountBitsSetParallel
511// Also used in TargetLowering::expandCTPOP().
512//
513// int popcount(unsigned int i) {
514// i = i - ((i >> 1) & 0x55555555);
515// i = (i & 0x33333333) + ((i >> 2) & 0x33333333);
516// i = ((i + (i >> 4)) & 0x0F0F0F0F);
517// return (i * 0x01010101) >> 24;
518// }
520 if (I.getOpcode() != Instruction::LShr)
521 return false;
522
523 Type *Ty = I.getType();
524 if (!Ty->isIntOrIntVectorTy())
525 return false;
526
527 unsigned Len = Ty->getScalarSizeInBits();
528 // FIXME: fix Len == 8 and other irregular type lengths.
529 if (!(Len <= 128 && Len > 8 && Len % 8 == 0))
530 return false;
531
532 APInt Mask55 = APInt::getSplat(Len, APInt(8, 0x55));
533 APInt Mask33 = APInt::getSplat(Len, APInt(8, 0x33));
534 APInt Mask0F = APInt::getSplat(Len, APInt(8, 0x0F));
535 APInt Mask01 = APInt::getSplat(Len, APInt(8, 0x01));
536 APInt MaskShift = APInt(Len, Len - 8);
537
538 Value *Op0 = I.getOperand(0);
539 Value *Op1 = I.getOperand(1);
540 Value *MulOp0;
541 // Matching "(i * 0x01010101...) >> 24".
542 if ((match(Op0, m_Mul(m_Value(MulOp0), m_SpecificInt(Mask01)))) &&
544 Value *ShiftOp0;
545 // Matching "((i + (i >> 4)) & 0x0F0F0F0F...)".
546 if (match(MulOp0, m_And(m_c_Add(m_LShr(m_Value(ShiftOp0), m_SpecificInt(4)),
547 m_Deferred(ShiftOp0)),
548 m_SpecificInt(Mask0F)))) {
549 Value *AndOp0;
550 // Matching "(i & 0x33333333...) + ((i >> 2) & 0x33333333...)".
551 if (match(ShiftOp0,
552 m_c_Add(m_And(m_Value(AndOp0), m_SpecificInt(Mask33)),
554 m_SpecificInt(Mask33))))) {
555 Value *Root, *SubOp1;
556 // Matching "i - ((i >> 1) & 0x55555555...)".
557 const APInt *AndMask;
558 if (match(AndOp0, m_Sub(m_Value(Root), m_Value(SubOp1))) &&
559 match(SubOp1, m_And(m_LShr(m_Specific(Root), m_SpecificInt(1)),
560 m_APInt(AndMask)))) {
561 auto CheckAndMask = [&]() {
562 if (*AndMask == Mask55)
563 return true;
564
565 // Exact match failed, see if any bits are known to be 0 where we
566 // expect a 1 in the mask.
567 if (!AndMask->isSubsetOf(Mask55))
568 return false;
569
570 APInt NeededMask = Mask55 & ~*AndMask;
571 return MaskedValueIsZero(cast<Instruction>(SubOp1)->getOperand(0),
572 NeededMask,
573 SimplifyQuery(I.getDataLayout()));
574 };
575
576 if (CheckAndMask()) {
577 replaceWithPopCount(I, Root);
578 return true;
579 }
580 }
581 }
582 }
583 }
584
585 return false;
586}
587
588// Try to recognize below function as popcount intrinsic.
589// Ref. Hacker Delights
590// int popcount32(unsigned int i) {
591// uWord = (uWord & 0x55555555) + ((uWord>>1) & 0x55555555);
592// uWord = (uWord & 0x33333333) + ((uWord>>2) & 0x33333333);
593// uWord = (uWord & 0x0F0F0F0F) + ((uWord>>4) & 0x0F0F0F0F);
594// uWord = (uWord & 0x00FF00FF) + ((uWord>>8) & 0x00FF00FF);
595// return (uWord & 0x0000FFFF) + (uWord>>16);
596// }
597// int popcount64(unsigned long i) {
598// uWord = (uWord & 0x5555555555555555) + ((uWord>>1) & 0x5555555555555555);
599// uWord = (uWord & 0x3333333333333333) + ((uWord>>2) & 0x3333333333333333);
600// uWord = (uWord & 0x0F0F0F0F0F0F0F0F) + ((uWord>>4) & 0x0F0F0F0F0F0F0F0F);
601// uWord = (uWord & 0x00FF00FF00FF00FF) + ((uWord>>8) & 0x00FF00FF00FF00FF);
602// uWord = (uWord & 0x0000FFFF0000FFFF) + ((uWord>>16) & 0x0000FFFF0000FFFF);
603// return (uWord & 0x00000000FFFFFFFF) + (uWord>>32) & 0x00000000FFFFFFFF;
604// }
605//
606// InstCombine may narrow AND masks when it can prove the removed bits are
607// known zero (e.g. 0x0F0F0F0F -> 0x07070707). We accept such narrowed masks
608// by checking they are subsets of the expected masks and verifying the missing
609// bits are known zero via MaskedValueIsZero.
611 if (I.getOpcode() != Instruction::Add)
612 return false;
613
614 Type *Ty = I.getType();
615 if (!Ty->isIntOrIntVectorTy())
616 return false;
617
618 unsigned Len = Ty->getScalarSizeInBits();
619 if (Len > 64 || Len <= 8 || Len % 8 != 0)
620 return false;
621
622 // Len should be a power of 2 for the loop to work correctly
623 if (!isPowerOf2_32(Len))
624 return false;
625
626 APInt Mask55 = APInt::getSplat(Len, APInt(8, 0x55));
627 APInt Mask33 = APInt::getSplat(Len, APInt(8, 0x33));
628
629 SimplifyQuery SQ(I.getDataLayout());
630
631 // Check if CapturedMask is a valid (possibly narrowed) version of
632 // ExpectedMask for the given Operand. Returns true if the masks match
633 // exactly, or if CapturedMask is a subset and the missing bits are
634 // known zero in the Operand.
635 auto isValidNarrowedMask = [&](const APInt &CapturedMask,
636 const APInt &ExpectedMask,
637 Value *Operand) -> bool {
638 if (CapturedMask == ExpectedMask)
639 return true;
640 if (!CapturedMask.isSubsetOf(ExpectedMask))
641 return false;
642 APInt NeededMask = ExpectedMask & ~CapturedMask;
643 return MaskedValueIsZero(Operand, NeededMask, SQ);
644 };
645
646 // For "(x & M) + ((x >> S) & M)" patterns, both AND masks may be narrowed.
647 // Require subsets of BaseMask and prove any implied missing bits are zero.
648 auto narrowAddPairMasksOk = [&](const APInt &BaseMask, unsigned ShiftAmt,
649 Value *Val, const APInt &AndMask1,
650 const APInt &AndMask2) -> bool {
651 if (!AndMask1.isSubsetOf(BaseMask) || !AndMask2.isSubsetOf(BaseMask))
652 return false;
653 APInt NeededShifted = (BaseMask & ~AndMask1).shl(ShiftAmt);
654 APInt NeededUnshifted = BaseMask & ~AndMask2;
655 APInt AllNeeded = NeededShifted | NeededUnshifted;
656 return AllNeeded.isZero() || MaskedValueIsZero(Val, AllNeeded, SQ);
657 };
658
659 Value *ShiftOp;
660 Value *Start = &I;
661 for (unsigned I = Len; I >= 8; I = I / 2) {
662 APInt Mask = APInt::getSplat(Len, APInt::getLowBitsSet(I, I / 2));
663 const APInt *AndMask1 = nullptr, *AndMask2 = nullptr;
664
665 // Matching "(uWord & Mask) + ((uWord>>I/2) & Mask)".
666 // Both masks might have been narrowed by InstCombine.
667 if (match(Start,
668 m_c_Add(m_And(m_LShr(m_Value(ShiftOp), m_SpecificInt(I / 2)),
669 m_APInt(AndMask1)),
670 m_And(m_Deferred(ShiftOp), m_APInt(AndMask2))))) {
671 if (!narrowAddPairMasksOk(Mask, I / 2, ShiftOp, *AndMask1, *AndMask2))
672 return false;
673 }
674 // Matching "(uWord & Mask) + (uWord>>I/2)".
675 // The mask might have been narrowed by InstCombine.
676 else if (match(Start,
677 m_c_Add(m_LShr(m_Value(ShiftOp), m_SpecificInt(I / 2)),
678 m_And(m_Deferred(ShiftOp), m_APInt(AndMask1))))) {
679 if (!isValidNarrowedMask(*AndMask1, Mask, ShiftOp))
680 return false;
681 } else
682 return false;
683 Start = ShiftOp;
684 }
685
686 // Matching "uWord = (uWord & Mask33) + ((uWord>>2) & Mask33)".
687 const APInt *AndMask1 = nullptr, *AndMask2 = nullptr;
688 if (!match(Start, m_c_Add(m_And(m_LShr(m_Value(ShiftOp), m_SpecificInt(2)),
689 m_APInt(AndMask1)),
690 m_And(m_Deferred(ShiftOp), m_APInt(AndMask2)))))
691 return false;
692 if (!narrowAddPairMasksOk(Mask33, 2, ShiftOp, *AndMask1, *AndMask2))
693 return false;
694
695 Start = ShiftOp;
696 Value *Root;
697 // Matching "uWord = (uWord & Mask55) + ((uWord>>1) & Mask55)".
698 AndMask1 = nullptr;
699 AndMask2 = nullptr;
700 if (!match(Start, m_c_Add(m_And(m_LShr(m_Value(Root), m_SpecificInt(1)),
701 m_APInt(AndMask1)),
702 m_And(m_Deferred(Root), m_APInt(AndMask2)))))
703 return false;
704 if (!narrowAddPairMasksOk(Mask55, 1, Root, *AndMask1, *AndMask2))
705 return false;
706
707 replaceWithPopCount(I, Root);
708 return true;
709}
710
711// Try to recognize below function as popcount intrinsic.
712// Ref. Hackers Delight
713// int popcnt(unsigned x) {
714// x = x - ((x >> 1) & 0x55555555);
715// x = (x & 0x33333333) + ((x >> 2) & 0x33333333);
716// x = (x + (x >> 4)) & 0x0F0F0F0F;
717// x = x + (x >> 8);
718// x = x + (x >> 16);
719// return x & 0x0000003F;
720// }
721
722// int popcnt(unsigned x) {
723// x = x - ((x >> 1) & 0x55555555);
724// x = x - 3*((x >> 2) & 0x33333333);
725// x = (x + (x >> 4)) & 0x0F0F0F0F;
726// x = x + (x >> 8);
727// x = x + (x >> 16);
728// return x & 0x0000003F;
729// }
730
732 if (I.getOpcode() != Instruction::And)
733 return false;
734
735 Type *Ty = I.getType();
736 if (!Ty->isIntOrIntVectorTy())
737 return false;
738
739 unsigned Len = Ty->getScalarSizeInBits();
740 Value *Add1;
741 const APInt *MaskRes;
742 if (!match(&I, m_And(m_Value(Add1), m_APInt(MaskRes))))
743 return false;
744
745 // Since `(trunc (and x, C))` might be canonicalized into `(and (trunc x), C)`
746 // we might loose the opportunity to recognize `(trunc (popcount y))`. The
747 // following block tries to capture such truncation, update `Len`, and append
748 // the truncation at the end of the emitting popcount, if there is any.
749 Value *TruncSrc;
750 if (match(Add1, m_OneUse(m_Trunc(m_Value(TruncSrc))))) {
751 Add1 = TruncSrc;
752 Len = Add1->getType()->getScalarSizeInBits();
753 }
754
755 if (Len > 64 || Len <= 8 || Len % 8 != 0)
756 return false;
757
758 // Len should be a power of 2 for the loop to work correctly
759 if (!isPowerOf2_32(Len))
760 return false;
761
762 APInt Mask55 = APInt::getSplat(Len, APInt(8, 0x55));
763 APInt Mask33 = APInt::getSplat(Len, APInt(8, 0x33));
764 APInt Mask0F = APInt::getSplat(Len, APInt(8, 0x0F));
765
766 // Number of bits needed to represent Len.
767 unsigned NumLenBits = Log2_32(Len) + 1;
768 // The "mask" here really only needs to fulfill two conditions:
769 // (1) All ones for the lower NumLenBits-bits
770 // (2) Zeros from bit 8 and onward.
771 // Condition (1) is straightforward. The reason behind condition
772 // (2) is that we don't care any 8-bit chunks but the first one
773 // in the original divide-and-conquer algorithm.
774 if (MaskRes->countTrailingOnes() < NumLenBits || MaskRes->getActiveBits() > 8)
775 return false;
776
777 Value *Add2;
778 for (unsigned I = Len; I >= 16; I = I / 2) {
779 // Matching "x = x + (x >> I/2)" for I-bit.
780 if (!match(Add1, m_c_Add(m_LShr(m_Value(Add2), m_SpecificInt(I / 2)),
781 m_Deferred(Add2))))
782 return false;
783 Add1 = Add2;
784 }
785
786 Value *And1 = Add1;
787 // Matching "x = (x + (x >> 4)) & 0x0F0F0F0F".
788 if (!match(And1, m_And(m_c_Add(m_LShr(m_Value(Add2), m_SpecificInt(4)),
789 m_Deferred(Add2)),
790 m_SpecificInt(Mask0F))))
791 return false;
792
793 Value *Sub1;
794 llvm::APInt NegThree(/*BitWidth=*/Len, /*Value=*/-3,
795 /*isSigned=*/true);
796 // x = (x & 0x33333333) + ((x >> 2) & 0x33333333)".
797 if (!match(Add2, m_c_Add(m_And(m_LShr(m_Value(Sub1), m_SpecificInt(2)),
798 m_SpecificInt(Mask33)),
799 m_And(m_Deferred(Sub1), m_SpecificInt(Mask33)))) &&
800 // Matching "x = x - 3*((x >> 2) & 0x33333333)".
802 m_SpecificInt(Mask33)),
803 m_SpecificInt(NegThree)),
804 m_Deferred(Sub1))))
805 return false;
806
807 Value *Root;
808 // x = x - ((x >> 1) & 0x55555555);
809 if (!match(Sub1, m_Sub(m_Value(Root),
811 m_SpecificInt(Mask55)))))
812 return false;
813
814 replaceWithPopCount(I, Root);
815 return true;
816}
817
818/// Fold smin(smax(fptosi(x), C1), C2) to llvm.fptosi.sat(x), providing C1 and
819/// C2 saturate the value of the fp conversion. The transform is not reversable
820/// as the fptosi.sat is more defined than the input - all values produce a
821/// valid value for the fptosi.sat, where as some produce poison for original
822/// that were out of range of the integer conversion. The reversed pattern may
823/// use fmax and fmin instead. As we cannot directly reverse the transform, and
824/// it is not always profitable, we make it conditional on the cost being
825/// reported as lower by TTI.
827 // Look for min(max(fptosi, converting to fptosi_sat.
828 Value *In;
829 const APInt *MinC, *MaxC;
831 m_APInt(MinC))),
832 m_APInt(MaxC))) &&
834 m_APInt(MaxC))),
835 m_APInt(MinC))))
836 return false;
837
838 // Check that the constants clamp a saturate.
839 if (!(*MinC + 1).isPowerOf2() || -*MaxC != *MinC + 1)
840 return false;
841
842 Type *IntTy = I.getType();
843 Type *FpTy = In->getType();
844 Type *SatTy =
845 IntegerType::get(IntTy->getContext(), (*MinC + 1).exactLogBase2() + 1);
846 if (auto *VecTy = dyn_cast<VectorType>(IntTy))
847 SatTy = VectorType::get(SatTy, VecTy->getElementCount());
848
849 // Get the cost of the intrinsic, and check that against the cost of
850 // fptosi+smin+smax
851 InstructionCost SatCost = TTI.getIntrinsicInstrCost(
852 IntrinsicCostAttributes(Intrinsic::fptosi_sat, SatTy, {In}, {FpTy}),
854 SatCost += TTI.getCastInstrCost(Instruction::SExt, IntTy, SatTy,
857
858 InstructionCost MinMaxCost = TTI.getCastInstrCost(
859 Instruction::FPToSI, IntTy, FpTy, TTI::CastContextHint::None,
861 MinMaxCost += TTI.getIntrinsicInstrCost(
862 IntrinsicCostAttributes(Intrinsic::smin, IntTy, {IntTy}),
864 MinMaxCost += TTI.getIntrinsicInstrCost(
865 IntrinsicCostAttributes(Intrinsic::smax, IntTy, {IntTy}),
867
868 if (SatCost >= MinMaxCost)
869 return false;
870
871 IRBuilder<> Builder(&I);
872 Value *Sat =
873 Builder.CreateIntrinsic(Intrinsic::fptosi_sat, {SatTy, FpTy}, In);
874 I.replaceAllUsesWith(Builder.CreateSExt(Sat, IntTy));
875 return true;
876}
877
878/// Try to replace a mathlib call to sqrt with the LLVM intrinsic. This avoids
879/// pessimistic codegen that has to account for setting errno and can enable
880/// vectorization.
881static bool foldSqrt(CallInst *Call, LibFunc Func, TargetTransformInfo &TTI,
883 DominatorTree &DT) {
884 // If (1) this is a sqrt libcall, (2) we can assume that NAN is not created
885 // (because NNAN or the operand arg must not be less than -0.0) and (2) we
886 // would not end up lowering to a libcall anyway (which could change the value
887 // of errno), then:
888 // (1) errno won't be set.
889 // (2) it is safe to convert this to an intrinsic call.
890 Type *Ty = Call->getType();
891 Value *Arg = Call->getArgOperand(0);
892 if (TTI.haveFastSqrt(Ty) &&
893 (Call->hasNoNaNs() ||
895 Arg, SimplifyQuery(Call->getDataLayout(), &TLI, &DT, &AC, Call)))) {
896 IRBuilder<> Builder(Call);
897 Value *NewSqrt =
898 Builder.CreateIntrinsic(Intrinsic::sqrt, Ty, Arg, Call, "sqrt");
899 Call->replaceAllUsesWith(NewSqrt);
900
901 // Explicitly erase the old call because a call with side effects is not
902 // trivially dead.
903 Call->eraseFromParent();
904 return true;
905 }
906
907 return false;
908}
909
910// Check if this array of constants represents a cttz table.
911// Iterate over the elements from \p Table by trying to find/match all
912// the numbers from 0 to \p InputBits that should represent cttz results.
913static bool isCTTZTable(Constant *Table, const APInt &Mul, const APInt &Shift,
914 const APInt &AndMask, Type *AccessTy,
915 unsigned InputBits, const APInt &GEPIdxFactor,
916 const DataLayout &DL) {
917 for (unsigned Idx = 0; Idx < InputBits; Idx++) {
918 APInt Index =
919 (APInt::getOneBitSet(InputBits, Idx) * Mul).lshr(Shift) & AndMask;
921 ConstantFoldLoadFromConst(Table, AccessTy, Index * GEPIdxFactor, DL));
922 if (!C || C->getValue() != Idx)
923 return false;
924 }
925
926 return true;
927}
928
929// Try to recognize table-based ctz implementation.
930// E.g., an example in C (for more cases please see the llvm/tests):
931// int f(unsigned x) {
932// static const char table[32] =
933// {0, 1, 28, 2, 29, 14, 24, 3, 30,
934// 22, 20, 15, 25, 17, 4, 8, 31, 27,
935// 13, 23, 21, 19, 16, 7, 26, 12, 18, 6, 11, 5, 10, 9};
936// return table[((unsigned)((x & -x) * 0x077CB531U)) >> 27];
937// }
938// this can be lowered to `cttz` instruction.
939// There is also a special case when the element is 0.
940//
941// The (x & -x) sets the lowest non-zero bit to 1. The multiply is a de-bruijn
942// sequence that contains each pattern of bits in it. The shift extracts
943// the top bits after the multiply, and that index into the table should
944// represent the number of trailing zeros in the original number.
945//
946// Here are some examples or LLVM IR for a 64-bit target:
947//
948// CASE 1:
949// %sub = sub i32 0, %x
950// %and = and i32 %sub, %x
951// %mul = mul i32 %and, 125613361
952// %shr = lshr i32 %mul, 27
953// %idxprom = zext i32 %shr to i64
954// %arrayidx = getelementptr inbounds [32 x i8], [32 x i8]* @ctz1.table, i64 0,
955// i64 %idxprom
956// %0 = load i8, i8* %arrayidx, align 1, !tbaa !8
957//
958// CASE 2:
959// %sub = sub i32 0, %x
960// %and = and i32 %sub, %x
961// %mul = mul i32 %and, 72416175
962// %shr = lshr i32 %mul, 26
963// %idxprom = zext i32 %shr to i64
964// %arrayidx = getelementptr inbounds [64 x i16], [64 x i16]* @ctz2.table,
965// i64 0, i64 %idxprom
966// %0 = load i16, i16* %arrayidx, align 2, !tbaa !8
967//
968// CASE 3:
969// %sub = sub i32 0, %x
970// %and = and i32 %sub, %x
971// %mul = mul i32 %and, 81224991
972// %shr = lshr i32 %mul, 27
973// %idxprom = zext i32 %shr to i64
974// %arrayidx = getelementptr inbounds [32 x i32], [32 x i32]* @ctz3.table,
975// i64 0, i64 %idxprom
976// %0 = load i32, i32* %arrayidx, align 4, !tbaa !8
977//
978// CASE 4:
979// %sub = sub i64 0, %x
980// %and = and i64 %sub, %x
981// %mul = mul i64 %and, 283881067100198605
982// %shr = lshr i64 %mul, 58
983// %arrayidx = getelementptr inbounds [64 x i8], [64 x i8]* @table, i64 0,
984// i64 %shr
985// %0 = load i8, i8* %arrayidx, align 1, !tbaa !8
986//
987// All these can be lowered to @llvm.cttz.i32/64 intrinsics.
990 if (!LI)
991 return false;
992
993 Type *AccessType = LI->getType();
994 if (!AccessType->isIntegerTy())
995 return false;
996
998 if (!GEP || !GEP->hasNoUnsignedSignedWrap())
999 return false;
1000
1001 GlobalVariable *GVTable = dyn_cast<GlobalVariable>(GEP->getPointerOperand());
1002 if (!GVTable || !GVTable->hasInitializer() || !GVTable->isConstant())
1003 return false;
1004
1005 unsigned BW = DL.getIndexTypeSizeInBits(GEP->getType());
1006 APInt ModOffset(BW, 0);
1008 if (!GEP->collectOffset(DL, BW, VarOffsets, ModOffset) ||
1009 VarOffsets.size() != 1 || ModOffset != 0)
1010 return false;
1011 auto [GepIdx, GEPScale] = VarOffsets.front();
1012
1013 Value *X1;
1014 const APInt *MulConst, *ShiftConst, *AndCst = nullptr;
1015 // Check that the gep variable index is ((x & -x) * MulConst) >> ShiftConst.
1016 // This might be extended to the pointer index type, and if the gep index type
1017 // has been replaced with an i8 then a new And (and different ShiftConst) will
1018 // be present.
1019 auto MatchInner = m_LShr(
1020 m_Mul(m_c_And(m_Neg(m_Value(X1)), m_Deferred(X1)), m_APInt(MulConst)),
1021 m_APInt(ShiftConst));
1022 if (!match(GepIdx, m_CastOrSelf(MatchInner)) &&
1023 !match(GepIdx, m_CastOrSelf(m_And(MatchInner, m_APInt(AndCst)))))
1024 return false;
1025
1026 unsigned InputBits = X1->getType()->getScalarSizeInBits();
1027 if (InputBits != 16 && InputBits != 32 && InputBits != 64 && InputBits != 128)
1028 return false;
1029
1030 if (!GEPScale.isIntN(InputBits) ||
1031 !isCTTZTable(GVTable->getInitializer(), *MulConst, *ShiftConst,
1032 AndCst ? *AndCst : APInt::getAllOnes(InputBits), AccessType,
1033 InputBits, GEPScale.zextOrTrunc(InputBits), DL))
1034 return false;
1035
1036 ConstantInt *ZeroTableElem = cast<ConstantInt>(
1037 ConstantFoldLoadFromConst(GVTable->getInitializer(), AccessType, DL));
1038 bool DefinedForZero = ZeroTableElem->getZExtValue() == InputBits;
1039
1040 IRBuilder<> B(LI);
1041 ConstantInt *BoolConst = B.getInt1(!DefinedForZero);
1042 Type *XType = X1->getType();
1043 auto Cttz = B.CreateIntrinsic(Intrinsic::cttz, {XType}, {X1, BoolConst});
1044 Value *ZExtOrTrunc = nullptr;
1045
1046 if (DefinedForZero) {
1047 ZExtOrTrunc = B.CreateZExtOrTrunc(Cttz, AccessType);
1048 } else {
1049 // If the value in elem 0 isn't the same as InputBits, we still want to
1050 // produce the value from the table.
1051 auto Cmp = B.CreateICmpEQ(X1, ConstantInt::get(XType, 0));
1052 auto Select = B.CreateSelect(Cmp, B.CreateZExt(ZeroTableElem, XType), Cttz);
1053
1054 // The true branch of select handles the cttz(0) case, which is rare.
1057 SelectI->setMetadata(
1058 LLVMContext::MD_prof,
1059 MDBuilder(SelectI->getContext()).createUnlikelyBranchWeights());
1060 }
1061
1062 // NOTE: If the table[0] is 0, but the cttz(0) is defined by the Target
1063 // it should be handled as: `cttz(x) & (typeSize - 1)`.
1064
1065 ZExtOrTrunc = B.CreateZExtOrTrunc(Select, AccessType);
1066 }
1067
1068 LI->replaceAllUsesWith(ZExtOrTrunc);
1069
1070 return true;
1071}
1072
1073// Check if this array of constants represents a log2 table.
1074// Iterate over the elements from \p Table by trying to find/match all
1075// the numbers from 0 to \p InputBits that should represent log2 results.
1076static bool isLog2Table(Constant *Table, const APInt &Mul, const APInt &Shift,
1077 Type *AccessTy, unsigned InputBits,
1078 const APInt &GEPIdxFactor, const DataLayout &DL) {
1079 for (unsigned Idx = 0; Idx < InputBits; Idx++) {
1080 APInt Index = (APInt::getLowBitsSet(InputBits, Idx + 1) * Mul).lshr(Shift);
1082 ConstantFoldLoadFromConst(Table, AccessTy, Index * GEPIdxFactor, DL));
1083 if (!C || C->getValue() != Idx)
1084 return false;
1085 }
1086
1087 // Verify that an input of zero will select table index 0.
1088 APInt ZeroIndex = Mul.lshr(Shift);
1089 if (!ZeroIndex.isZero())
1090 return false;
1091
1092 return true;
1093}
1094
1095// Try to recognize table-based log2 implementation.
1096// E.g., an example in C (for more cases please the llvm/tests):
1097// int f(unsigned v) {
1098// static const char table[32] =
1099// {0, 9, 1, 10, 13, 21, 2, 29, 11, 14, 16, 18, 22, 25, 3, 30,
1100// 8, 12, 20, 28, 15, 17, 24, 7, 19, 27, 23, 6, 26, 5, 4, 31};
1101//
1102// v |= v >> 1; // first round down to one less than a power of 2
1103// v |= v >> 2;
1104// v |= v >> 4;
1105// v |= v >> 8;
1106// v |= v >> 16;
1107//
1108// return table[(unsigned)(v * 0x07C4ACDDU) >> 27];
1109// }
1110// this can be lowered to `ctlz` instruction.
1111// There is also a special case when the element is 0.
1112//
1113// The >> and |= sequence sets all bits below the most significant set bit. The
1114// multiply is a de-bruijn sequence that contains each pattern of bits in it.
1115// The shift extracts the top bits after the multiply, and that index into the
1116// table should represent the floor log base 2 of the original number.
1117//
1118// Here are some examples of LLVM IR for a 64-bit target.
1119//
1120// CASE 1:
1121// %shr = lshr i32 %v, 1
1122// %or = or i32 %shr, %v
1123// %shr1 = lshr i32 %or, 2
1124// %or2 = or i32 %shr1, %or
1125// %shr3 = lshr i32 %or2, 4
1126// %or4 = or i32 %shr3, %or2
1127// %shr5 = lshr i32 %or4, 8
1128// %or6 = or i32 %shr5, %or4
1129// %shr7 = lshr i32 %or6, 16
1130// %or8 = or i32 %shr7, %or6
1131// %mul = mul i32 %or8, 130329821
1132// %shr9 = lshr i32 %mul, 27
1133// %idxprom = zext nneg i32 %shr9 to i64
1134// %arrayidx = getelementptr inbounds i8, ptr @table, i64 %idxprom
1135// %0 = load i8, ptr %arrayidx, align 1
1136//
1137// CASE 2:
1138// %shr = lshr i64 %v, 1
1139// %or = or i64 %shr, %v
1140// %shr1 = lshr i64 %or, 2
1141// %or2 = or i64 %shr1, %or
1142// %shr3 = lshr i64 %or2, 4
1143// %or4 = or i64 %shr3, %or2
1144// %shr5 = lshr i64 %or4, 8
1145// %or6 = or i64 %shr5, %or4
1146// %shr7 = lshr i64 %or6, 16
1147// %or8 = or i64 %shr7, %or6
1148// %shr9 = lshr i64 %or8, 32
1149// %or10 = or i64 %shr9, %or8
1150// %mul = mul i64 %or10, 285870213051386505
1151// %shr11 = lshr i64 %mul, 58
1152// %arrayidx = getelementptr inbounds i8, ptr @table, i64 %shr11
1153// %0 = load i8, ptr %arrayidx, align 1
1154//
1155// All these can be lowered to @llvm.ctlz.i32/64 intrinsics and a subtract.
1159 if (!LI)
1160 return false;
1161
1162 Type *AccessType = LI->getType();
1163 if (!AccessType->isIntegerTy())
1164 return false;
1165
1167 if (!GEP || !GEP->hasNoUnsignedSignedWrap())
1168 return false;
1169
1170 GlobalVariable *GVTable = dyn_cast<GlobalVariable>(GEP->getPointerOperand());
1171 if (!GVTable || !GVTable->hasInitializer() || !GVTable->isConstant())
1172 return false;
1173
1174 unsigned BW = DL.getIndexTypeSizeInBits(GEP->getType());
1175 APInt ModOffset(BW, 0);
1177 if (!GEP->collectOffset(DL, BW, VarOffsets, ModOffset) ||
1178 VarOffsets.size() != 1 || ModOffset != 0)
1179 return false;
1180 auto [GepIdx, GEPScale] = VarOffsets.front();
1181
1182 Value *X;
1183 const APInt *MulConst, *ShiftConst;
1184 // Check that the gep variable index is (x * MulConst) >> ShiftConst.
1185 auto MatchInner =
1186 m_LShr(m_Mul(m_Value(X), m_APInt(MulConst)), m_APInt(ShiftConst));
1187 if (!match(GepIdx, m_CastOrSelf(MatchInner)))
1188 return false;
1189
1190 unsigned InputBits = X->getType()->getScalarSizeInBits();
1191 if (InputBits != 16 && InputBits != 32 && InputBits != 64 && InputBits != 128)
1192 return false;
1193
1194 // Verify shift amount.
1195 // TODO: Allow other shift amounts when we have proper test coverage.
1196 if (*ShiftConst != InputBits - Log2_32(InputBits))
1197 return false;
1198
1199 // Match the sequence of OR operations with right shifts by powers of 2.
1200 for (unsigned ShiftAmt = InputBits / 2; ShiftAmt != 0; ShiftAmt /= 2) {
1201 Value *Y;
1202 if (!match(X, m_c_Or(m_LShr(m_Value(Y), m_SpecificInt(ShiftAmt)),
1203 m_Deferred(Y))))
1204 return false;
1205 X = Y;
1206 }
1207
1208 if (!GEPScale.isIntN(InputBits) ||
1209 !isLog2Table(GVTable->getInitializer(), *MulConst, *ShiftConst,
1210 AccessType, InputBits, GEPScale.zextOrTrunc(InputBits), DL))
1211 return false;
1212
1213 ConstantInt *ZeroTableElem = cast<ConstantInt>(
1214 ConstantFoldLoadFromConst(GVTable->getInitializer(), AccessType, DL));
1215
1216 // Use InputBits - 1 - ctlz(X) to compute log2(X).
1217 IRBuilder<> B(LI);
1218 ConstantInt *BoolConst = B.getTrue();
1219 Type *XType = X->getType();
1220
1221 // Check the the backend has an efficient ctlz instruction.
1222 // FIXME: Teach the backend to emit the original code when ctlz isn't
1223 // supported like we do for cttz.
1225 Intrinsic::ctlz, XType,
1226 {PoisonValue::get(XType), /*is_zero_poison=*/BoolConst});
1227 InstructionCost Cost =
1228 TTI.getIntrinsicInstrCost(Attrs, TargetTransformInfo::TCK_SizeAndLatency);
1230 return false;
1231
1232 Value *Ctlz = B.CreateIntrinsic(Intrinsic::ctlz, {XType}, {X, BoolConst});
1233
1234 Constant *InputBitsM1 = ConstantInt::get(XType, InputBits - 1);
1235 Value *Sub = B.CreateSub(InputBitsM1, Ctlz);
1236
1237 // The table won't produce a sensible result for 0.
1238 Value *Cmp = B.CreateICmpEQ(X, ConstantInt::get(XType, 0));
1239 Value *Select = B.CreateSelect(Cmp, B.CreateZExt(ZeroTableElem, XType), Sub);
1240
1241 // The true branch of select handles the log2(0) case, which is rare.
1244 SelectI->setMetadata(
1245 LLVMContext::MD_prof,
1246 MDBuilder(SelectI->getContext()).createUnlikelyBranchWeights());
1247 }
1248
1249 Value *ZExtOrTrunc = B.CreateZExtOrTrunc(Select, AccessType);
1250
1251 LI->replaceAllUsesWith(ZExtOrTrunc);
1252
1253 return true;
1254}
1255
1256/// This is used by foldLoadsRecursive() to capture a Root Load node which is
1257/// of type or(load, load) and recursively build the wide load. Also capture the
1258/// shift amount, zero extend type and loadSize.
1268
1269// Identify and Merge consecutive loads recursively which is of the form
1270// (ZExt(L1) << shift1) | (ZExt(L2) << shift2) -> ZExt(L3) << shift1
1271// (ZExt(L1) << shift1) | ZExt(L2) -> ZExt(L3)
1272static bool foldLoadsRecursive(Value *V, LoadOps &LOps, const DataLayout &DL,
1273 AliasAnalysis &AA, bool IsRoot = false) {
1274 uint64_t ShAmt2;
1275 Value *X;
1276 Instruction *L1, *L2;
1277
1278 // For the root instruction, allow multiple uses since the final result
1279 // may legitimately be used in multiple places. For intermediate values,
1280 // require single use to avoid creating duplicate loads.
1281 if (!IsRoot && !V->hasOneUse())
1282 return false;
1283
1284 if (!match(V, m_c_Or(m_Value(X),
1286 ShAmt2)))))
1287 return false;
1288
1289 if (!foldLoadsRecursive(X, LOps, DL, AA, /*IsRoot=*/false) && LOps.FoundRoot)
1290 // Avoid Partial chain merge.
1291 return false;
1292
1293 // Check if the pattern has loads
1294 LoadInst *LI1 = LOps.Root;
1295 uint64_t ShAmt1 = LOps.Shift;
1296 if (LOps.FoundRoot == false &&
1297 match(X, m_OneUse(
1298 m_ShlOrSelf(m_OneUse(m_ZExt(m_Instruction(L1))), ShAmt1)))) {
1299 LI1 = dyn_cast<LoadInst>(L1);
1300 }
1301 LoadInst *LI2 = dyn_cast<LoadInst>(L2);
1302
1303 // Check if loads are same, atomic, volatile and having same address space.
1304 if (LI1 == LI2 || !LI1 || !LI2 || !LI1->isSimple() || !LI2->isSimple() ||
1306 return false;
1307
1308 // Check if Loads come from same BB.
1309 if (LI1->getParent() != LI2->getParent())
1310 return false;
1311
1312 // Find the data layout
1313 bool IsBigEndian = DL.isBigEndian();
1314
1315 // Check if loads are consecutive and same size.
1316 Value *Load1Ptr = LI1->getPointerOperand();
1317 APInt Offset1(DL.getIndexTypeSizeInBits(Load1Ptr->getType()), 0);
1318 Load1Ptr =
1319 Load1Ptr->stripAndAccumulateConstantOffsets(DL, Offset1,
1320 /* AllowNonInbounds */ true);
1321
1322 Value *Load2Ptr = LI2->getPointerOperand();
1323 APInt Offset2(DL.getIndexTypeSizeInBits(Load2Ptr->getType()), 0);
1324 Load2Ptr =
1325 Load2Ptr->stripAndAccumulateConstantOffsets(DL, Offset2,
1326 /* AllowNonInbounds */ true);
1327
1328 // Verify if both loads have same base pointers
1329 uint64_t LoadSize1 = LI1->getType()->getPrimitiveSizeInBits();
1330 uint64_t LoadSize2 = LI2->getType()->getPrimitiveSizeInBits();
1331 if (Load1Ptr != Load2Ptr)
1332 return false;
1333
1334 // Make sure that there are no padding bits.
1335 if (!DL.typeSizeEqualsStoreSize(LI1->getType()) ||
1336 !DL.typeSizeEqualsStoreSize(LI2->getType()))
1337 return false;
1338
1339 // Alias Analysis to check for stores b/w the loads.
1340 LoadInst *Start = LOps.FoundRoot ? LOps.RootInsert : LI1, *End = LI2;
1342 if (!Start->comesBefore(End)) {
1343 std::swap(Start, End);
1344 // If LOps.RootInsert comes after LI2, since we use LI2 as the new insert
1345 // point, we should make sure whether the memory region accessed by LOps
1346 // isn't modified.
1347 if (LOps.FoundRoot)
1349 LOps.Root->getPointerOperand(),
1350 LocationSize::precise(DL.getTypeStoreSize(
1351 IntegerType::get(LI1->getContext(), LOps.LoadSize))),
1352 LOps.AATags);
1353 else
1354 Loc = MemoryLocation::get(End);
1355 } else
1356 Loc = MemoryLocation::get(End);
1357 unsigned NumScanned = 0;
1358 for (Instruction &Inst :
1359 make_range(Start->getIterator(), End->getIterator())) {
1360 if (Inst.mayWriteToMemory() && isModSet(AA.getModRefInfo(&Inst, Loc)))
1361 return false;
1362
1363 if (++NumScanned > MaxInstrsToScan)
1364 return false;
1365 }
1366
1367 // Make sure Load with lower Offset is at LI1
1368 bool Reverse = false;
1369 if (Offset2.slt(Offset1)) {
1370 std::swap(LI1, LI2);
1371 std::swap(ShAmt1, ShAmt2);
1372 std::swap(Offset1, Offset2);
1373 std::swap(Load1Ptr, Load2Ptr);
1374 std::swap(LoadSize1, LoadSize2);
1375 Reverse = true;
1376 }
1377
1378 // Big endian swap the shifts
1379 if (IsBigEndian)
1380 std::swap(ShAmt1, ShAmt2);
1381
1382 // First load is always LI1. This is where we put the new load.
1383 // Use the merged load size available from LI1 for forward loads.
1384 if (LOps.FoundRoot) {
1385 if (!Reverse)
1386 LoadSize1 = LOps.LoadSize;
1387 else
1388 LoadSize2 = LOps.LoadSize;
1389 }
1390
1391 // Verify if shift amount and load index aligns and verifies that loads
1392 // are consecutive.
1393 uint64_t ShiftDiff = IsBigEndian ? LoadSize2 : LoadSize1;
1394 uint64_t PrevSize =
1395 DL.getTypeStoreSize(IntegerType::get(LI1->getContext(), LoadSize1));
1396 if ((ShAmt2 - ShAmt1) != ShiftDiff || (Offset2 - Offset1) != PrevSize)
1397 return false;
1398
1399 // Update LOps
1400 AAMDNodes AATags1 = LOps.AATags;
1401 AAMDNodes AATags2 = LI2->getAAMetadata();
1402 if (LOps.FoundRoot == false) {
1403 LOps.FoundRoot = true;
1404 AATags1 = LI1->getAAMetadata();
1405 }
1406 LOps.LoadSize = LoadSize1 + LoadSize2;
1407 LOps.RootInsert = Start;
1408
1409 // Concatenate the AATags of the Merged Loads.
1410 LOps.AATags = AATags1.concat(AATags2);
1411
1412 LOps.Root = LI1;
1413 LOps.Shift = ShAmt1;
1414 LOps.ZextType = X->getType();
1415 return true;
1416}
1417
1418// For a given BB instruction, evaluate all loads in the chain that form a
1419// pattern which suggests that the loads can be combined. The one and only use
1420// of the loads is to form a wider load.
1423 const DominatorTree &DT) {
1424 // Only consider load chains of scalar values.
1425 if (isa<VectorType>(I.getType()))
1426 return false;
1427
1428 LoadOps LOps;
1429 if (!foldLoadsRecursive(&I, LOps, DL, AA, /*IsRoot=*/true) || !LOps.FoundRoot)
1430 return false;
1431
1432 IRBuilder<> Builder(&I);
1433 LoadInst *NewLoad = nullptr, *LI1 = LOps.Root;
1434
1435 IntegerType *WiderType = IntegerType::get(I.getContext(), LOps.LoadSize);
1436 // TTI based checks if we want to proceed with wider load
1437 bool Allowed = TTI.isTypeLegal(WiderType);
1438 if (!Allowed)
1439 return false;
1440
1441 unsigned AS = LI1->getPointerAddressSpace();
1442 unsigned Fast = 0;
1443 Allowed = TTI.allowsMisalignedMemoryAccesses(I.getContext(), LOps.LoadSize,
1444 AS, LI1->getAlign(), &Fast);
1445 if (!Allowed || !Fast)
1446 return false;
1447
1448 // Get the Index and Ptr for the new GEP.
1449 Value *Load1Ptr = LI1->getPointerOperand();
1450 Builder.SetInsertPoint(LOps.RootInsert);
1451 if (!DT.dominates(Load1Ptr, LOps.RootInsert)) {
1452 APInt Offset1(DL.getIndexTypeSizeInBits(Load1Ptr->getType()), 0);
1453 Load1Ptr = Load1Ptr->stripAndAccumulateConstantOffsets(
1454 DL, Offset1, /* AllowNonInbounds */ true);
1455 Load1Ptr = Builder.CreatePtrAdd(Load1Ptr, Builder.getInt(Offset1));
1456 }
1457 // Generate wider load.
1458 NewLoad = Builder.CreateAlignedLoad(WiderType, Load1Ptr, LI1->getAlign(),
1459 LI1->isVolatile(), "");
1460 NewLoad->takeName(LI1);
1461 // Set the New Load AATags Metadata.
1462 if (LOps.AATags)
1463 NewLoad->setAAMetadata(LOps.AATags);
1464
1465 Value *NewOp = NewLoad;
1466 // Check if zero extend needed.
1467 if (LOps.ZextType)
1468 NewOp = Builder.CreateZExt(NewOp, LOps.ZextType);
1469
1470 // Check if shift needed. We need to shift with the amount of load1
1471 // shift if not zero.
1472 if (LOps.Shift)
1473 NewOp = Builder.CreateShl(NewOp, LOps.Shift);
1474 I.replaceAllUsesWith(NewOp);
1475
1476 return true;
1477}
1478
1479/// ValWidth bits starting at ValOffset of Val stored at PtrBase+PtrOffset.
1487
1488 bool isCompatibleWith(const PartStore &Other) const {
1489 return PtrBase == Other.PtrBase && Val == Other.Val;
1490 }
1491
1492 bool operator<(const PartStore &Other) const {
1493 return PtrOffset.slt(Other.PtrOffset);
1494 }
1495};
1496
1497static std::optional<PartStore> matchPartStore(Instruction &I,
1498 const DataLayout &DL) {
1499 auto *Store = dyn_cast<StoreInst>(&I);
1500 if (!Store || !Store->isSimple())
1501 return std::nullopt;
1502
1503 Value *StoredVal = Store->getValueOperand();
1504 Type *StoredTy = StoredVal->getType();
1505 if (!StoredTy->isIntegerTy() || !DL.typeSizeEqualsStoreSize(StoredTy))
1506 return std::nullopt;
1507
1508 uint64_t ValWidth = StoredTy->getPrimitiveSizeInBits();
1509 uint64_t ValOffset;
1510 Value *Val;
1511 if (!match(StoredVal, m_Trunc(m_LShrOrSelf(m_Value(Val), ValOffset))))
1512 return std::nullopt;
1513
1514 Value *Ptr = Store->getPointerOperand();
1515 APInt PtrOffset(DL.getIndexTypeSizeInBits(Ptr->getType()), 0);
1517 DL, PtrOffset, /*AllowNonInbounds=*/true);
1518 return {{PtrBase, PtrOffset, Val, ValOffset, ValWidth, Store}};
1519}
1520
1522 unsigned Width, const DataLayout &DL,
1524 if (Parts.size() < 2)
1525 return false;
1526
1527 // Check whether combining the stores is profitable.
1528 // FIXME: We could generate smaller stores if we can't produce a large one.
1529 const PartStore &First = Parts.front();
1530 LLVMContext &Ctx = First.Store->getContext();
1531 Type *NewTy = Type::getIntNTy(Ctx, Width);
1532 unsigned Fast = 0;
1533 if (!TTI.isTypeLegal(NewTy) ||
1534 !TTI.allowsMisalignedMemoryAccesses(Ctx, Width,
1535 First.Store->getPointerAddressSpace(),
1536 First.Store->getAlign(), &Fast) ||
1537 !Fast)
1538 return false;
1539
1540 // Generate the combined store.
1541 IRBuilder<> Builder(First.Store);
1542 Value *Val = First.Val;
1543 if (First.ValOffset != 0)
1544 Val = Builder.CreateLShr(Val, First.ValOffset);
1545 Val = Builder.CreateZExtOrTrunc(Val, NewTy);
1546 StoreInst *Store = Builder.CreateAlignedStore(
1547 Val, First.Store->getPointerOperand(), First.Store->getAlign());
1548
1549 // Merge various metadata onto the new store.
1550 AAMDNodes AATags = First.Store->getAAMetadata();
1551 SmallVector<Instruction *> Stores = {First.Store};
1552 Stores.reserve(Parts.size());
1553 SmallVector<DebugLoc> DbgLocs = {First.Store->getDebugLoc()};
1554 DbgLocs.reserve(Parts.size());
1555 for (const PartStore &Part : drop_begin(Parts)) {
1556 AATags = AATags.concat(Part.Store->getAAMetadata());
1557 Stores.push_back(Part.Store);
1558 DbgLocs.push_back(Part.Store->getDebugLoc());
1559 }
1560 Store->setAAMetadata(AATags);
1561 Store->mergeDIAssignID(Stores);
1562 Store->setDebugLoc(DebugLoc::getMergedLocations(DbgLocs));
1563
1564 // Remove the old stores.
1565 for (const PartStore &Part : Parts)
1566 Part.Store->eraseFromParent();
1567
1568 return true;
1569}
1570
1573 if (Parts.size() < 2)
1574 return false;
1575
1576 // We now have multiple parts of the same value stored to the same pointer.
1577 // Sort the parts by pointer offset, and make sure they are consistent with
1578 // the value offsets. Also check that the value is fully covered without
1579 // overlaps.
1580 bool Changed = false;
1581 llvm::sort(Parts);
1582 int64_t LastEndOffsetFromFirst = 0;
1583 const PartStore *First = &Parts[0];
1584 for (const PartStore &Part : Parts) {
1585 APInt PtrOffsetFromFirst = Part.PtrOffset - First->PtrOffset;
1586 int64_t ValOffsetFromFirst = Part.ValOffset - First->ValOffset;
1587 if (PtrOffsetFromFirst * 8 != ValOffsetFromFirst ||
1588 LastEndOffsetFromFirst != ValOffsetFromFirst) {
1590 LastEndOffsetFromFirst, DL, TTI);
1591 First = &Part;
1592 LastEndOffsetFromFirst = Part.ValWidth;
1593 continue;
1594 }
1595
1596 LastEndOffsetFromFirst = ValOffsetFromFirst + Part.ValWidth;
1597 }
1598
1600 LastEndOffsetFromFirst, DL, TTI);
1601 return Changed;
1602}
1603
1606 // FIXME: Add big endian support.
1607 if (DL.isBigEndian())
1608 return false;
1609
1610 BatchAAResults BatchAA(AA);
1612 bool MadeChange = false;
1613 for (Instruction &I : make_early_inc_range(BB)) {
1614 if (std::optional<PartStore> Part = matchPartStore(I, DL)) {
1615 if (Parts.empty() || Part->isCompatibleWith(Parts[0])) {
1616 Parts.push_back(std::move(*Part));
1617 continue;
1618 }
1619
1620 MadeChange |= mergePartStores(Parts, DL, TTI);
1621 Parts.clear();
1622 Parts.push_back(std::move(*Part));
1623 continue;
1624 }
1625
1626 if (Parts.empty())
1627 continue;
1628
1629 if (I.mayThrow() ||
1630 (I.mayReadOrWriteMemory() &&
1632 &I, MemoryLocation::getBeforeOrAfter(Parts[0].PtrBase))))) {
1633 MadeChange |= mergePartStores(Parts, DL, TTI);
1634 Parts.clear();
1635 continue;
1636 }
1637 }
1638
1639 MadeChange |= mergePartStores(Parts, DL, TTI);
1640 return MadeChange;
1641}
1642
1643/// Combine away instructions providing they are still equivalent when compared
1644/// against 0. i.e do they have any bits set.
1646 auto *I = dyn_cast<Instruction>(V);
1647 if (!I || I->getOpcode() != Instruction::Or || !I->hasOneUse())
1648 return nullptr;
1649
1650 Value *A;
1651
1652 // Look deeper into the chain of or's, combining away shl (so long as they are
1653 // nuw or nsw).
1654 Value *Op0 = I->getOperand(0);
1655 if (match(Op0, m_CombineOr(m_NSWShl(m_Value(A), m_Value()),
1656 m_NUWShl(m_Value(A), m_Value()))))
1657 Op0 = A;
1658 else if (auto *NOp = optimizeShiftInOrChain(Op0, Builder))
1659 Op0 = NOp;
1660
1661 Value *Op1 = I->getOperand(1);
1662 if (match(Op1, m_CombineOr(m_NSWShl(m_Value(A), m_Value()),
1663 m_NUWShl(m_Value(A), m_Value()))))
1664 Op1 = A;
1665 else if (auto *NOp = optimizeShiftInOrChain(Op1, Builder))
1666 Op1 = NOp;
1667
1668 if (Op0 != I->getOperand(0) || Op1 != I->getOperand(1))
1669 return Builder.CreateOr(Op0, Op1);
1670 return nullptr;
1671}
1672
1675 const DominatorTree &DT) {
1676 CmpPredicate Pred;
1677 Value *Op0;
1678 if (!match(&I, m_ICmp(Pred, m_Value(Op0), m_Zero())) ||
1679 !ICmpInst::isEquality(Pred))
1680 return false;
1681
1682 // If the chain or or's matches a load, combine to that before attempting to
1683 // remove shifts.
1684 if (auto OpI = dyn_cast<Instruction>(Op0))
1685 if (OpI->getOpcode() == Instruction::Or)
1686 if (foldConsecutiveLoads(*OpI, DL, TTI, AA, DT))
1687 return true;
1688
1689 IRBuilder<> Builder(&I);
1690 // icmp eq/ne or(shl(a), b), 0 -> icmp eq/ne or(a, b), 0
1691 if (auto *Res = optimizeShiftInOrChain(Op0, Builder)) {
1692 I.replaceAllUsesWith(Builder.CreateICmp(Pred, Res, I.getOperand(1)));
1693 return true;
1694 }
1695
1696 return false;
1697}
1698
1699// Calculate GEP Stride and accumulated const ModOffset. Return Stride and
1700// ModOffset
1701static std::pair<APInt, APInt>
1703 unsigned BW = DL.getIndexTypeSizeInBits(PtrOp->getType());
1704 std::optional<APInt> Stride;
1705 APInt ModOffset(BW, 0);
1706 // Return a minimum gep stride, greatest common divisor of consective gep
1707 // index scales(c.f. Bézout's identity).
1708 while (auto *GEP = dyn_cast<GEPOperator>(PtrOp)) {
1710 if (!GEP->collectOffset(DL, BW, VarOffsets, ModOffset))
1711 break;
1712
1713 for (auto [V, Scale] : VarOffsets) {
1714 // Only keep a power of two factor for non-inbounds
1715 if (!GEP->hasNoUnsignedSignedWrap())
1716 Scale = APInt::getOneBitSet(Scale.getBitWidth(), Scale.countr_zero());
1717
1718 if (!Stride)
1719 Stride = Scale;
1720 else
1721 Stride = APIntOps::GreatestCommonDivisor(*Stride, Scale);
1722 }
1723
1724 PtrOp = GEP->getPointerOperand();
1725 }
1726
1727 // Check whether pointer arrives back at Global Variable via at least one GEP.
1728 // Even if it doesn't, we can check by alignment.
1729 if (!isa<GlobalVariable>(PtrOp) || !Stride)
1730 return {APInt(BW, 1), APInt(BW, 0)};
1731
1732 // In consideration of signed GEP indices, non-negligible offset become
1733 // remainder of division by minimum GEP stride.
1734 ModOffset = ModOffset.srem(*Stride);
1735 if (ModOffset.isNegative())
1736 ModOffset += *Stride;
1737
1738 return {*Stride, ModOffset};
1739}
1740
1741/// If C is a constant patterned array and all valid loaded results for given
1742/// alignment are same to a constant, return that constant.
1744 auto *LI = dyn_cast<LoadInst>(&I);
1745 if (!LI || LI->isVolatile())
1746 return false;
1747
1748 // We can only fold the load if it is from a constant global with definitive
1749 // initializer. Skip expensive logic if this is not the case.
1750 auto *PtrOp = LI->getPointerOperand();
1752 if (!GV || !GV->isConstant() || !GV->hasDefinitiveInitializer())
1753 return false;
1754
1755 // Bail for large initializers in excess of 4K to avoid too many scans.
1756 Constant *C = GV->getInitializer();
1757 uint64_t GVSize = DL.getTypeAllocSize(C->getType());
1758 if (!GVSize || 4096 < GVSize)
1759 return false;
1760
1761 Type *LoadTy = LI->getType();
1762 unsigned BW = DL.getIndexTypeSizeInBits(PtrOp->getType());
1763 auto [Stride, ConstOffset] = getStrideAndModOffsetOfGEP(PtrOp, DL);
1764
1765 // Any possible offset could be multiple of GEP stride. And any valid
1766 // offset is multiple of load alignment, so checking only multiples of bigger
1767 // one is sufficient to say results' equality.
1768 if (auto LA = LI->getAlign();
1769 LA <= GV->getAlign().valueOrOne() && Stride.getZExtValue() < LA.value()) {
1770 ConstOffset = APInt(BW, 0);
1771 Stride = APInt(BW, LA.value());
1772 }
1773
1774 Constant *Ca = ConstantFoldLoadFromConst(C, LoadTy, ConstOffset, DL);
1775 if (!Ca)
1776 return false;
1777
1778 unsigned E = GVSize - DL.getTypeStoreSize(LoadTy);
1779 for (; ConstOffset.getZExtValue() <= E; ConstOffset += Stride)
1780 if (Ca != ConstantFoldLoadFromConst(C, LoadTy, ConstOffset, DL))
1781 return false;
1782
1783 I.replaceAllUsesWith(Ca);
1784
1785 return true;
1786}
1787
1788namespace {
1789class StrNCmpInliner {
1790public:
1791 StrNCmpInliner(CallInst *CI, LibFunc Func, DomTreeUpdater *DTU,
1792 const DataLayout &DL)
1793 : CI(CI), Func(Func), DTU(DTU), DL(DL) {}
1794
1795 bool optimizeStrNCmp();
1796
1797private:
1798 void inlineCompare(Value *LHS, StringRef RHS, uint64_t N, bool Swapped);
1799
1800 CallInst *CI;
1801 LibFunc Func;
1802 DomTreeUpdater *DTU;
1803 const DataLayout &DL;
1804};
1805
1806} // namespace
1807
1808/// First we normalize calls to strncmp/strcmp to the form of
1809/// compare(s1, s2, N), which means comparing first N bytes of s1 and s2
1810/// (without considering '\0').
1811///
1812/// Examples:
1813///
1814/// \code
1815/// strncmp(s, "a", 3) -> compare(s, "a", 2)
1816/// strncmp(s, "abc", 3) -> compare(s, "abc", 3)
1817/// strncmp(s, "a\0b", 3) -> compare(s, "a\0b", 2)
1818/// strcmp(s, "a") -> compare(s, "a", 2)
1819///
1820/// char s2[] = {'a'}
1821/// strncmp(s, s2, 3) -> compare(s, s2, 3)
1822///
1823/// char s2[] = {'a', 'b', 'c', 'd'}
1824/// strncmp(s, s2, 3) -> compare(s, s2, 3)
1825/// \endcode
1826///
1827/// We only handle cases where N and exactly one of s1 and s2 are constant.
1828/// Cases that s1 and s2 are both constant are already handled by the
1829/// instcombine pass.
1830///
1831/// We do not handle cases where N > StrNCmpInlineThreshold.
1832///
1833/// We also do not handles cases where N < 2, which are already
1834/// handled by the instcombine pass.
1835///
1836bool StrNCmpInliner::optimizeStrNCmp() {
1837 if (StrNCmpInlineThreshold < 2)
1838 return false;
1839
1841 return false;
1842
1843 Value *Str1P = CI->getArgOperand(0);
1844 Value *Str2P = CI->getArgOperand(1);
1845 // Should be handled elsewhere.
1846 if (Str1P == Str2P)
1847 return false;
1848
1849 StringRef Str1, Str2;
1850 bool HasStr1 = getConstantStringInfo(Str1P, Str1, /*TrimAtNul=*/false);
1851 bool HasStr2 = getConstantStringInfo(Str2P, Str2, /*TrimAtNul=*/false);
1852 if (HasStr1 == HasStr2)
1853 return false;
1854
1855 // Note that '\0' and characters after it are not trimmed.
1856 StringRef Str = HasStr1 ? Str1 : Str2;
1857 Value *StrP = HasStr1 ? Str2P : Str1P;
1858
1859 size_t Idx = Str.find('\0');
1860 uint64_t N = Idx == StringRef::npos ? UINT64_MAX : Idx + 1;
1861 if (Func == LibFunc_strncmp) {
1862 if (auto *ConstInt = dyn_cast<ConstantInt>(CI->getArgOperand(2)))
1863 N = std::min(N, ConstInt->getZExtValue());
1864 else
1865 return false;
1866 }
1867 // Now N means how many bytes we need to compare at most.
1868 if (N > Str.size() || N < 2 || N > StrNCmpInlineThreshold)
1869 return false;
1870
1871 // Cases where StrP has two or more dereferenceable bytes might be better
1872 // optimized elsewhere.
1873 bool CanBeNull = false, CanBeFreed = false;
1874 if (StrP->getPointerDereferenceableBytes(DL, CanBeNull, CanBeFreed) > 1)
1875 return false;
1876 inlineCompare(StrP, Str, N, HasStr1);
1877 return true;
1878}
1879
1880/// Convert
1881///
1882/// \code
1883/// ret = compare(s1, s2, N)
1884/// \endcode
1885///
1886/// into
1887///
1888/// \code
1889/// ret = (int)s1[0] - (int)s2[0]
1890/// if (ret != 0)
1891/// goto NE
1892/// ...
1893/// ret = (int)s1[N-2] - (int)s2[N-2]
1894/// if (ret != 0)
1895/// goto NE
1896/// ret = (int)s1[N-1] - (int)s2[N-1]
1897/// NE:
1898/// \endcode
1899///
1900/// CFG before and after the transformation:
1901///
1902/// (before)
1903/// BBCI
1904///
1905/// (after)
1906/// BBCI -> BBSubs[0] (sub,icmp) --NE-> BBNE -> BBTail
1907/// | ^
1908/// E |
1909/// | |
1910/// BBSubs[1] (sub,icmp) --NE-----+
1911/// ... |
1912/// BBSubs[N-1] (sub) ---------+
1913///
1914void StrNCmpInliner::inlineCompare(Value *LHS, StringRef RHS, uint64_t N,
1915 bool Swapped) {
1916 auto &Ctx = CI->getContext();
1917 IRBuilder<> B(Ctx);
1918 // We want these instructions to be recognized as inlined instructions for the
1919 // compare call, but we don't have a source location for the definition of
1920 // that function, since we're generating that code now. Because the generated
1921 // code is a viable point for a memory access error, we make the pragmatic
1922 // choice here to directly use CI's location so that we have useful
1923 // attribution for the generated code.
1924 B.SetCurrentDebugLocation(CI->getDebugLoc());
1925
1926 BasicBlock *BBCI = CI->getParent();
1927 BasicBlock *BBTail =
1928 SplitBlock(BBCI, CI, DTU, nullptr, nullptr, BBCI->getName() + ".tail");
1929
1931 for (uint64_t I = 0; I < N; ++I)
1932 BBSubs.push_back(
1933 BasicBlock::Create(Ctx, "sub_" + Twine(I), BBCI->getParent(), BBTail));
1934 BasicBlock *BBNE = BasicBlock::Create(Ctx, "ne", BBCI->getParent(), BBTail);
1935
1936 cast<UncondBrInst>(BBCI->getTerminator())->setSuccessor(BBSubs[0]);
1937
1938 B.SetInsertPoint(BBNE);
1939 PHINode *Phi = B.CreatePHI(CI->getType(), N);
1940 B.CreateBr(BBTail);
1941
1942 Value *Base = LHS;
1943 for (uint64_t i = 0; i < N; ++i) {
1944 B.SetInsertPoint(BBSubs[i]);
1945 Value *VL =
1946 B.CreateZExt(B.CreateLoad(B.getInt8Ty(),
1947 B.CreateInBoundsPtrAdd(Base, B.getInt64(i))),
1948 CI->getType());
1949 Value *VR =
1950 ConstantInt::get(CI->getType(), static_cast<unsigned char>(RHS[i]));
1951 Value *Sub = Swapped ? B.CreateSub(VR, VL) : B.CreateSub(VL, VR);
1952 if (i < N - 1) {
1953 CondBrInst *CondBrInst = B.CreateCondBr(
1954 B.CreateICmpNE(Sub, ConstantInt::get(CI->getType(), 0)), BBNE,
1955 BBSubs[i + 1]);
1956
1957 Function *F = CI->getFunction();
1958 assert(F && "Instruction does not belong to a function!");
1959 std::optional<Function::ProfileCount> EC = F->getEntryCount();
1960 if (EC && EC->getCount() > 0)
1962 } else {
1963 B.CreateBr(BBNE);
1964 }
1965
1966 Phi->addIncoming(Sub, BBSubs[i]);
1967 }
1968
1969 CI->replaceAllUsesWith(Phi);
1970 CI->eraseFromParent();
1971
1972 if (DTU) {
1974 Updates.push_back({DominatorTree::Insert, BBCI, BBSubs[0]});
1975 for (uint64_t i = 0; i < N; ++i) {
1976 if (i < N - 1)
1977 Updates.push_back({DominatorTree::Insert, BBSubs[i], BBSubs[i + 1]});
1978 Updates.push_back({DominatorTree::Insert, BBSubs[i], BBNE});
1979 }
1980 Updates.push_back({DominatorTree::Insert, BBNE, BBTail});
1981 Updates.push_back({DominatorTree::Delete, BBCI, BBTail});
1982 DTU->applyUpdates(Updates);
1983 }
1984}
1985
1986/// Convert memchr with a small constant string into a switch
1988 const DataLayout &DL) {
1989 if (isa<Constant>(Call->getArgOperand(1)))
1990 return false;
1991
1992 StringRef Str;
1993 Value *Base = Call->getArgOperand(0);
1994 if (!getConstantStringInfo(Base, Str, /*TrimAtNul=*/false))
1995 return false;
1996
1997 uint64_t N = Str.size();
1998 if (auto *ConstInt = dyn_cast<ConstantInt>(Call->getArgOperand(2))) {
1999 uint64_t Val = ConstInt->getZExtValue();
2000 // Ignore the case that n is larger than the size of string.
2001 if (Val > N)
2002 return false;
2003 N = Val;
2004 } else
2005 return false;
2006
2008 return false;
2009
2010 BasicBlock *BB = Call->getParent();
2011 BasicBlock *BBNext = SplitBlock(BB, Call, DTU);
2012 IRBuilder<> IRB(BB);
2013 IRB.SetCurrentDebugLocation(Call->getDebugLoc());
2014 IntegerType *ByteTy = IRB.getInt8Ty();
2016 SwitchInst *SI = IRB.CreateSwitch(
2017 IRB.CreateTrunc(Call->getArgOperand(1), ByteTy), BBNext, N);
2018 // We can't know the precise weights here, as they would depend on the value
2019 // distribution of Call->getArgOperand(1). So we just mark it as "unknown".
2021 Type *IndexTy = DL.getIndexType(Call->getType());
2023
2024 BasicBlock *BBSuccess = BasicBlock::Create(
2025 Call->getContext(), "memchr.success", BB->getParent(), BBNext);
2026 IRB.SetInsertPoint(BBSuccess);
2027 PHINode *IndexPHI = IRB.CreatePHI(IndexTy, N, "memchr.idx");
2028 Value *FirstOccursLocation = IRB.CreateInBoundsPtrAdd(Base, IndexPHI);
2029 IRB.CreateBr(BBNext);
2030 if (DTU)
2031 Updates.push_back({DominatorTree::Insert, BBSuccess, BBNext});
2032
2034 for (uint64_t I = 0; I < N; ++I) {
2035 ConstantInt *CaseVal =
2036 ConstantInt::get(ByteTy, static_cast<unsigned char>(Str[I]));
2037 if (!Cases.insert(CaseVal).second)
2038 continue;
2039
2040 BasicBlock *BBCase = BasicBlock::Create(Call->getContext(), "memchr.case",
2041 BB->getParent(), BBSuccess);
2042 SI->addCase(CaseVal, BBCase);
2043 IRB.SetInsertPoint(BBCase);
2044 IndexPHI->addIncoming(ConstantInt::get(IndexTy, I), BBCase);
2045 IRB.CreateBr(BBSuccess);
2046 if (DTU) {
2047 Updates.push_back({DominatorTree::Insert, BB, BBCase});
2048 Updates.push_back({DominatorTree::Insert, BBCase, BBSuccess});
2049 }
2050 }
2051
2052 PHINode *PHI =
2053 PHINode::Create(Call->getType(), 2, Call->getName(), BBNext->begin());
2054 PHI->addIncoming(Constant::getNullValue(Call->getType()), BB);
2055 PHI->addIncoming(FirstOccursLocation, BBSuccess);
2056
2057 Call->replaceAllUsesWith(PHI);
2058 Call->eraseFromParent();
2059
2060 if (DTU)
2061 DTU->applyUpdates(Updates);
2062
2063 return true;
2064}
2065
2068 DominatorTree &DT, const DataLayout &DL,
2069 bool &MadeCFGChange) {
2070
2071 auto *CI = dyn_cast<CallInst>(&I);
2072 if (!CI || CI->isNoBuiltin())
2073 return false;
2074
2075 Function *CalledFunc = CI->getCalledFunction();
2076 if (!CalledFunc)
2077 return false;
2078
2079 LibFunc LF;
2080 if (!TLI.getLibFunc(*CalledFunc, LF) ||
2081 !isLibFuncEmittable(CI->getModule(), &TLI, LF))
2082 return false;
2083
2084 DomTreeUpdater DTU(&DT, DomTreeUpdater::UpdateStrategy::Lazy);
2085
2086 switch (LF) {
2087 case LibFunc_sqrt:
2088 case LibFunc_sqrtf:
2089 case LibFunc_sqrtl:
2090 return foldSqrt(CI, LF, TTI, TLI, AC, DT);
2091 case LibFunc_strcmp:
2092 case LibFunc_strncmp:
2093 if (StrNCmpInliner(CI, LF, &DTU, DL).optimizeStrNCmp()) {
2094 MadeCFGChange = true;
2095 return true;
2096 }
2097 break;
2098 case LibFunc_memchr:
2099 if (foldMemChr(CI, &DTU, DL)) {
2100 MadeCFGChange = true;
2101 return true;
2102 }
2103 break;
2104 default:;
2105 }
2106 return false;
2107}
2108
2109/// Match high part of long multiplication.
2110///
2111/// Considering a multiply made up of high and low parts, we can split the
2112/// multiply into:
2113/// x * y == (xh*T + xl) * (yh*T + yl)
2114/// where xh == x>>32 and xl == x & 0xffffffff. T = 2^32.
2115/// This expands to
2116/// xh*yh*T*T + xh*yl*T + xl*yh*T + xl*yl
2117/// which can be drawn as
2118/// [ xh*yh ]
2119/// [ xh*yl ]
2120/// [ xl*yh ]
2121/// [ xl*yl ]
2122/// We are looking for the "high" half, which is xh*yh + xh*yl>>32 + xl*yh>>32 +
2123/// some carrys. The carry makes this difficult and there are multiple ways of
2124/// representing it. The ones we attempt to support here are:
2125/// Carry: xh*yh + carry + lowsum
2126/// carry = lowsum < xh*yl ? 0x1000000 : 0
2127/// lowsum = xh*yl + xl*yh + (xl*yl>>32)
2128/// Ladder: xh*yh + c2>>32 + c3>>32
2129/// c2 = xh*yl + (xl*yl>>32); c3 = c2&0xffffffff + xl*yh
2130/// or c2 = (xl*yh&0xffffffff) + xh*yl + (xl*yl>>32); c3 = xl*yh
2131/// Carry4: xh*yh + carry + crosssum>>32 + (xl*yl + crosssum&0xffffffff) >> 32
2132/// crosssum = xh*yl + xl*yh
2133/// carry = crosssum < xh*yl ? 0x1000000 : 0
2134/// Ladder4: xh*yh + (xl*yh)>>32 + (xh*yl)>>32 + low>>32;
2135/// low = (xl*yl)>>32 + (xl*yh)&0xffffffff + (xh*yl)&0xffffffff
2136///
2137/// They all start by matching xh*yh + 2 or 3 other operands. The bottom of the
2138/// tree is xh*yh, xh*yl, xl*yh and xl*yl.
2140 Type *Ty = I.getType();
2141 if (!Ty->isIntOrIntVectorTy())
2142 return false;
2143
2144 unsigned BitWidth = Ty->getScalarSizeInBits();
2146 if (BitWidth % 2 != 0)
2147 return false;
2148
2149 auto CreateMulHigh = [&](Value *X, Value *Y) {
2150 IRBuilder<> Builder(&I);
2151 Type *NTy = Ty->getWithNewBitWidth(BitWidth * 2);
2152 Value *XExt = Builder.CreateZExt(X, NTy);
2153 Value *YExt = Builder.CreateZExt(Y, NTy);
2154 Value *Mul = Builder.CreateMul(XExt, YExt, "", /*HasNUW=*/true);
2155 Value *High = Builder.CreateLShr(Mul, BitWidth);
2156 Value *Res = Builder.CreateTrunc(High, Ty, "", /*HasNUW=*/true);
2157 Res->takeName(&I);
2158 I.replaceAllUsesWith(Res);
2159 LLVM_DEBUG(dbgs() << "Created long multiply from parts of " << *X << " and "
2160 << *Y << "\n");
2161 return true;
2162 };
2163
2164 // Common check routines for X_lo*Y_lo and X_hi*Y_lo
2165 auto CheckLoLo = [&](Value *XlYl, Value *X, Value *Y) {
2166 return match(XlYl, m_c_Mul(m_And(m_Specific(X), m_SpecificInt(LowMask)),
2167 m_And(m_Specific(Y), m_SpecificInt(LowMask))));
2168 };
2169 auto CheckHiLo = [&](Value *XhYl, Value *X, Value *Y) {
2170 return match(XhYl,
2172 m_And(m_Specific(Y), m_SpecificInt(LowMask))));
2173 };
2174
2175 auto FoldMulHighCarry = [&](Value *X, Value *Y, Instruction *Carry,
2176 Instruction *B) {
2177 // Looking for LowSum >> 32 and carry (select)
2178 if (Carry->getOpcode() != Instruction::Select)
2179 std::swap(Carry, B);
2180
2181 // Carry = LowSum < XhYl ? 0x100000000 : 0
2182 Value *LowSum, *XhYl;
2183 if (!match(Carry,
2186 m_Value(XhYl))),
2188 m_Zero()))))
2189 return false;
2190
2191 // XhYl can be Xh*Yl or Xl*Yh
2192 if (!CheckHiLo(XhYl, X, Y)) {
2193 if (CheckHiLo(XhYl, Y, X))
2194 std::swap(X, Y);
2195 else
2196 return false;
2197 }
2198 if (XhYl->hasNUsesOrMore(3))
2199 return false;
2200
2201 // B = LowSum >> 32
2202 if (!match(B, m_OneUse(m_LShr(m_Specific(LowSum),
2203 m_SpecificInt(BitWidth / 2)))) ||
2204 LowSum->hasNUsesOrMore(3))
2205 return false;
2206
2207 // LowSum = XhYl + XlYh + XlYl>>32
2208 Value *XlYh, *XlYl;
2209 auto XlYlHi = m_LShr(m_Value(XlYl), m_SpecificInt(BitWidth / 2));
2210 if (!match(LowSum,
2211 m_c_Add(m_Specific(XhYl),
2212 m_OneUse(m_c_Add(m_OneUse(m_Value(XlYh)), XlYlHi)))) &&
2213 !match(LowSum, m_c_Add(m_OneUse(m_Value(XlYh)),
2214 m_OneUse(m_c_Add(m_Specific(XhYl), XlYlHi)))) &&
2215 !match(LowSum,
2216 m_c_Add(XlYlHi, m_OneUse(m_c_Add(m_Specific(XhYl),
2217 m_OneUse(m_Value(XlYh)))))))
2218 return false;
2219
2220 // Check XlYl and XlYh
2221 if (!CheckLoLo(XlYl, X, Y))
2222 return false;
2223 if (!CheckHiLo(XlYh, Y, X))
2224 return false;
2225
2226 return CreateMulHigh(X, Y);
2227 };
2228
2229 auto FoldMulHighLadder = [&](Value *X, Value *Y, Instruction *A,
2230 Instruction *B) {
2231 // xh*yh + c2>>32 + c3>>32
2232 // c2 = xh*yl + (xl*yl>>32); c3 = c2&0xffffffff + xl*yh
2233 // or c2 = (xl*yh&0xffffffff) + xh*yl + (xl*yl>>32); c3 = xh*yl
2234 Value *XlYh, *XhYl, *XlYl, *C2, *C3;
2235 // Strip off the two expected shifts.
2236 if (!match(A, m_LShr(m_Value(C2), m_SpecificInt(BitWidth / 2))) ||
2238 return false;
2239
2240 if (match(C3, m_c_Add(m_Add(m_Value(), m_Value()), m_Value())))
2241 std::swap(C2, C3);
2242 // Try to match c2 = (xl*yh&0xffffffff) + xh*yl + (xl*yl>>32)
2243 if (match(C2,
2245 m_Value(XlYh)),
2246 m_LShr(m_Value(XlYl), m_SpecificInt(BitWidth / 2)))) ||
2248 m_LShr(m_Value(XlYl),
2249 m_SpecificInt(BitWidth / 2))),
2250 m_Value(XlYh))) ||
2252 m_SpecificInt(BitWidth / 2)),
2253 m_Value(XlYh)),
2254 m_And(m_Specific(C3), m_SpecificInt(LowMask))))) {
2255 XhYl = C3;
2256 } else {
2257 // Match c3 = c2&0xffffffff + xl*yh
2258 if (!match(C3, m_c_Add(m_And(m_Specific(C2), m_SpecificInt(LowMask)),
2259 m_Value(XlYh))))
2260 std::swap(C2, C3);
2261 if (!match(C3, m_c_Add(m_OneUse(
2262 m_And(m_Specific(C2), m_SpecificInt(LowMask))),
2263 m_Value(XlYh))) ||
2264 !C3->hasOneUse() || C2->hasNUsesOrMore(3))
2265 return false;
2266
2267 // Match c2 = xh*yl + (xl*yl >> 32)
2268 if (!match(C2, m_c_Add(m_LShr(m_Value(XlYl), m_SpecificInt(BitWidth / 2)),
2269 m_Value(XhYl))))
2270 return false;
2271 }
2272
2273 // Match XhYl and XlYh - they can appear either way around.
2274 if (!CheckHiLo(XlYh, Y, X))
2275 std::swap(XlYh, XhYl);
2276 if (!CheckHiLo(XlYh, Y, X))
2277 return false;
2278 if (!CheckHiLo(XhYl, X, Y))
2279 return false;
2280 if (!CheckLoLo(XlYl, X, Y))
2281 return false;
2282
2283 return CreateMulHigh(X, Y);
2284 };
2285
2286 auto FoldMulHighLadder4 = [&](Value *X, Value *Y, Instruction *A,
2288 /// Ladder4: xh*yh + (xl*yh)>>32 + (xh+yl)>>32 + low>>32;
2289 /// low = (xl*yl)>>32 + (xl*yh)&0xffffffff + (xh*yl)&0xffffffff
2290
2291 // Find A = Low >> 32 and B/C = XhYl>>32, XlYh>>32.
2292 auto ShiftAdd =
2294 if (!match(A, ShiftAdd))
2295 std::swap(A, B);
2296 if (!match(A, ShiftAdd))
2297 std::swap(A, C);
2298 Value *Low;
2300 return false;
2301
2302 // Match B == XhYl>>32 and C == XlYh>>32
2303 Value *XhYl, *XlYh;
2304 if (!match(B, m_LShr(m_Value(XhYl), m_SpecificInt(BitWidth / 2))) ||
2305 !match(C, m_LShr(m_Value(XlYh), m_SpecificInt(BitWidth / 2))))
2306 return false;
2307 if (!CheckHiLo(XhYl, X, Y))
2308 std::swap(XhYl, XlYh);
2309 if (!CheckHiLo(XhYl, X, Y) || XhYl->hasNUsesOrMore(3))
2310 return false;
2311 if (!CheckHiLo(XlYh, Y, X) || XlYh->hasNUsesOrMore(3))
2312 return false;
2313
2314 // Match Low as XlYl>>32 + XhYl&0xffffffff + XlYh&0xffffffff
2315 Value *XlYl;
2316 if (!match(
2317 Low,
2318 m_c_Add(
2320 m_OneUse(m_And(m_Specific(XhYl), m_SpecificInt(LowMask))),
2321 m_OneUse(m_And(m_Specific(XlYh), m_SpecificInt(LowMask))))),
2322 m_OneUse(
2323 m_LShr(m_Value(XlYl), m_SpecificInt(BitWidth / 2))))) &&
2324 !match(
2325 Low,
2326 m_c_Add(
2328 m_OneUse(m_And(m_Specific(XhYl), m_SpecificInt(LowMask))),
2329 m_OneUse(
2330 m_LShr(m_Value(XlYl), m_SpecificInt(BitWidth / 2))))),
2331 m_OneUse(m_And(m_Specific(XlYh), m_SpecificInt(LowMask))))) &&
2332 !match(
2333 Low,
2334 m_c_Add(
2336 m_OneUse(m_And(m_Specific(XlYh), m_SpecificInt(LowMask))),
2337 m_OneUse(
2338 m_LShr(m_Value(XlYl), m_SpecificInt(BitWidth / 2))))),
2339 m_OneUse(m_And(m_Specific(XhYl), m_SpecificInt(LowMask))))))
2340 return false;
2341 if (!CheckLoLo(XlYl, X, Y))
2342 return false;
2343
2344 return CreateMulHigh(X, Y);
2345 };
2346
2347 auto FoldMulHighCarry4 = [&](Value *X, Value *Y, Instruction *Carry,
2349 // xh*yh + carry + crosssum>>32 + (xl*yl + crosssum&0xffffffff) >> 32
2350 // crosssum = xh*yl+xl*yh
2351 // carry = crosssum < xh*yl ? 0x1000000 : 0
2352 if (Carry->getOpcode() != Instruction::Select)
2353 std::swap(Carry, B);
2354 if (Carry->getOpcode() != Instruction::Select)
2355 std::swap(Carry, C);
2356
2357 // Carry = CrossSum < XhYl ? 0x100000000 : 0
2358 Value *CrossSum, *XhYl;
2359 if (!match(Carry,
2362 m_Value(CrossSum), m_Value(XhYl))),
2364 m_Zero()))))
2365 return false;
2366
2367 if (!match(B, m_LShr(m_Specific(CrossSum), m_SpecificInt(BitWidth / 2))))
2368 std::swap(B, C);
2369 if (!match(B, m_LShr(m_Specific(CrossSum), m_SpecificInt(BitWidth / 2))))
2370 return false;
2371
2372 Value *XlYl, *LowAccum;
2373 if (!match(C, m_LShr(m_Value(LowAccum), m_SpecificInt(BitWidth / 2))) ||
2374 !match(LowAccum, m_c_Add(m_OneUse(m_LShr(m_Value(XlYl),
2375 m_SpecificInt(BitWidth / 2))),
2376 m_OneUse(m_And(m_Specific(CrossSum),
2377 m_SpecificInt(LowMask))))) ||
2378 LowAccum->hasNUsesOrMore(3))
2379 return false;
2380 if (!CheckLoLo(XlYl, X, Y))
2381 return false;
2382
2383 if (!CheckHiLo(XhYl, X, Y))
2384 std::swap(X, Y);
2385 if (!CheckHiLo(XhYl, X, Y))
2386 return false;
2387 Value *XlYh;
2388 if (!match(CrossSum, m_c_Add(m_Specific(XhYl), m_OneUse(m_Value(XlYh)))) ||
2389 !CheckHiLo(XlYh, Y, X) || CrossSum->hasNUsesOrMore(4) ||
2390 XhYl->hasNUsesOrMore(3))
2391 return false;
2392
2393 return CreateMulHigh(X, Y);
2394 };
2395
2396 // X and Y are the two inputs, A, B and C are other parts of the pattern
2397 // (crosssum>>32, carry, etc).
2398 Value *X, *Y;
2399 Instruction *A, *B, *C;
2400 auto HiHi = m_OneUse(m_Mul(m_LShr(m_Value(X), m_SpecificInt(BitWidth / 2)),
2402 if ((match(&I, m_c_Add(HiHi, m_OneUse(m_Add(m_Instruction(A),
2403 m_Instruction(B))))) ||
2405 m_OneUse(m_c_Add(HiHi, m_Instruction(B)))))) &&
2406 A->hasOneUse() && B->hasOneUse())
2407 if (FoldMulHighCarry(X, Y, A, B) || FoldMulHighLadder(X, Y, A, B))
2408 return true;
2409
2410 if ((match(&I, m_c_Add(HiHi, m_OneUse(m_c_Add(
2413 m_Instruction(C))))))) ||
2417 m_Instruction(C))))))) ||
2421 m_OneUse(m_c_Add(HiHi, m_Instruction(C))))))) ||
2422 match(&I,
2425 A->hasOneUse() && B->hasOneUse() && C->hasOneUse())
2426 return FoldMulHighCarry4(X, Y, A, B, C) ||
2427 FoldMulHighLadder4(X, Y, A, B, C);
2428
2429 return false;
2430}
2431
2432/// This is the entry point for folds that could be implemented in regular
2433/// InstCombine, but they are separated because they are not expected to
2434/// occur frequently and/or have more than a constant-length pattern match.
2438 AssumptionCache &AC, bool &MadeCFGChange) {
2439 bool MadeChange = false;
2440 for (BasicBlock &BB : F) {
2441 // Ignore unreachable basic blocks.
2442 if (!DT.isReachableFromEntry(&BB))
2443 continue;
2444
2445 const DataLayout &DL = F.getDataLayout();
2446
2447 // Walk the block backwards for efficiency. We're matching a chain of
2448 // use->defs, so we're more likely to succeed by starting from the bottom.
2449 // Also, we want to avoid matching partial patterns.
2450 // TODO: It would be more efficient if we removed dead instructions
2451 // iteratively in this loop rather than waiting until the end.
2453 MadeChange |= foldAnyOrAllBitsSet(I);
2454 MadeChange |= foldGuardedFunnelShift(I, DT);
2455 MadeChange |= foldSelectSplitCTTZ(I);
2456 MadeChange |= foldSelectSplitCTLZ(I);
2457 MadeChange |= tryToRecognizePopCount(I);
2458 MadeChange |= tryToRecognizePopCount1(I);
2459 MadeChange |= tryToRecognizePopCount2n3(I);
2460 MadeChange |= tryToFPToSat(I, TTI);
2461 MadeChange |= tryToRecognizeTableBasedCttz(I, DL);
2462 MadeChange |= tryToRecognizeTableBasedLog2(I, DL, TTI);
2463 MadeChange |= foldConsecutiveLoads(I, DL, TTI, AA, DT);
2464 MadeChange |= foldPatternedLoads(I, DL);
2465 MadeChange |= foldICmpOrChain(I, DL, TTI, AA, DT);
2466 MadeChange |= foldMulHigh(I);
2467 // NOTE: This function introduces erasing of the instruction `I`, so it
2468 // needs to be called at the end of this sequence, otherwise we may make
2469 // bugs.
2470 MadeChange |= foldLibCalls(I, TTI, TLI, AC, DT, DL, MadeCFGChange);
2471 }
2472
2473 // Do this separately to avoid redundantly scanning stores multiple times.
2474 MadeChange |= foldConsecutiveStores(BB, DL, TTI, AA);
2475 }
2476
2477 // We're done with transforms, so remove dead instructions.
2478 if (MadeChange)
2479 for (BasicBlock &BB : F)
2481
2482 return MadeChange;
2483}
2484
2485/// This is the entry point for all transforms. Pass manager differences are
2486/// handled in the callers of this function.
2489 AliasAnalysis &AA, bool &MadeCFGChange) {
2490 bool MadeChange = false;
2491 const DataLayout &DL = F.getDataLayout();
2492 TruncInstCombine TIC(AC, TLI, DL, DT);
2493 MadeChange |= TIC.run(F);
2494 MadeChange |= foldUnusualPatterns(F, DT, TTI, TLI, AA, AC, MadeCFGChange);
2495 return MadeChange;
2496}
2497
2500 auto &AC = AM.getResult<AssumptionAnalysis>(F);
2501 auto &TLI = AM.getResult<TargetLibraryAnalysis>(F);
2502 auto &DT = AM.getResult<DominatorTreeAnalysis>(F);
2503 auto &TTI = AM.getResult<TargetIRAnalysis>(F);
2504 auto &AA = AM.getResult<AAManager>(F);
2505 bool MadeCFGChange = false;
2506 if (!runImpl(F, AC, TTI, TLI, DT, AA, MadeCFGChange)) {
2507 // No changes, all analyses are preserved.
2508 return PreservedAnalyses::all();
2509 }
2510 // Mark all the analyses that instcombine updates as preserved.
2512 if (MadeCFGChange)
2514 else
2516 return PA;
2517}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Register Bank Select
Rewrite undef for PHI
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static void replaceWithPopCount(Instruction &I, Value *Root)
Helper function to replace an instruction with a popcount intrinsic.
static bool tryToRecognizePopCount(Instruction &I)
static bool foldSqrt(CallInst *Call, LibFunc Func, TargetTransformInfo &TTI, TargetLibraryInfo &TLI, AssumptionCache &AC, DominatorTree &DT)
Try to replace a mathlib call to sqrt with the LLVM intrinsic.
static bool isLog2Table(Constant *Table, const APInt &Mul, const APInt &Shift, Type *AccessTy, unsigned InputBits, const APInt &GEPIdxFactor, const DataLayout &DL)
static bool foldAnyOrAllBitsSet(Instruction &I)
Match patterns that correspond to "any-bits-set" and "all-bits-set".
static cl::opt< unsigned > MemChrInlineThreshold("memchr-inline-threshold", cl::init(3), cl::Hidden, cl::desc("The maximum length of a constant string to " "inline a memchr call."))
static bool tryToFPToSat(Instruction &I, TargetTransformInfo &TTI)
Fold smin(smax(fptosi(x), C1), C2) to llvm.fptosi.sat(x), providing C1 and C2 saturate the value of t...
static cl::opt< unsigned > StrNCmpInlineThreshold("strncmp-inline-threshold", cl::init(3), cl::Hidden, cl::desc("The maximum length of a constant string for a builtin string cmp " "call eligible for inlining. The default value is 3."))
static bool matchAndOrChain(Value *V, MaskOps &MOps)
This is a recursive helper for foldAnyOrAllBitsSet() that walks through a chain of 'and' or 'or' inst...
static bool foldMemChr(CallInst *Call, DomTreeUpdater *DTU, const DataLayout &DL)
Convert memchr with a small constant string into a switch.
static bool tryToRecognizePopCount2n3(Instruction &I)
static Value * optimizeShiftInOrChain(Value *V, IRBuilder<> &Builder)
Combine away instructions providing they are still equivalent when compared against 0.
static bool foldConsecutiveLoads(Instruction &I, const DataLayout &DL, TargetTransformInfo &TTI, AliasAnalysis &AA, const DominatorTree &DT)
static bool foldGuardedFunnelShift(Instruction &I, const DominatorTree &DT)
Match a pattern for a bitwise funnel/rotate operation that partially guards against undefined behavio...
static bool tryToRecognizeTableBasedCttz(Instruction &I, const DataLayout &DL)
static bool mergePartStores(SmallVectorImpl< PartStore > &Parts, const DataLayout &DL, TargetTransformInfo &TTI)
static bool foldLoadsRecursive(Value *V, LoadOps &LOps, const DataLayout &DL, AliasAnalysis &AA, bool IsRoot=false)
static bool mergeConsecutivePartStores(ArrayRef< PartStore > Parts, unsigned Width, const DataLayout &DL, TargetTransformInfo &TTI)
static cl::opt< unsigned > MaxInstrsToScan("aggressive-instcombine-max-scan-instrs", cl::init(64), cl::Hidden, cl::desc("Max number of instructions to scan for aggressive instcombine."))
static bool foldSelectSplitCTTZ(Instruction &I)
Try to fold a select-based split cttz pattern into a single full-width cttz.
static bool foldSelectSplitCTLZ(Instruction &I)
Same as foldSelectSplitCTTZ but for leading zeros (ctlz).
static bool tryToRecognizePopCount1(Instruction &I)
static bool foldICmpOrChain(Instruction &I, const DataLayout &DL, TargetTransformInfo &TTI, AliasAnalysis &AA, const DominatorTree &DT)
static bool isCTTZTable(Constant *Table, const APInt &Mul, const APInt &Shift, const APInt &AndMask, Type *AccessTy, unsigned InputBits, const APInt &GEPIdxFactor, const DataLayout &DL)
static std::optional< PartStore > matchPartStore(Instruction &I, const DataLayout &DL)
static bool foldConsecutiveStores(BasicBlock &BB, const DataLayout &DL, TargetTransformInfo &TTI, AliasAnalysis &AA)
static std::pair< APInt, APInt > getStrideAndModOffsetOfGEP(Value *PtrOp, const DataLayout &DL)
static bool foldPatternedLoads(Instruction &I, const DataLayout &DL)
If C is a constant patterned array and all valid loaded results for given alignment are same to a con...
static bool tryToRecognizeTableBasedLog2(Instruction &I, const DataLayout &DL, TargetTransformInfo &TTI)
static bool foldLibCalls(Instruction &I, TargetTransformInfo &TTI, TargetLibraryInfo &TLI, AssumptionCache &AC, DominatorTree &DT, const DataLayout &DL, bool &MadeCFGChange)
static bool foldMulHigh(Instruction &I)
Match high part of long multiplication.
static bool foldUnusualPatterns(Function &F, DominatorTree &DT, TargetTransformInfo &TTI, TargetLibraryInfo &TLI, AliasAnalysis &AA, AssumptionCache &AC, bool &MadeCFGChange)
This is the entry point for folds that could be implemented in regular InstCombine,...
AggressiveInstCombiner - Combine expression patterns to form expressions with fewer,...
This is the interface for LLVM's primary stateless and local alias analysis.
#define X(NUM, ENUM, NAME)
Definition ELF.h:853
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
static bool runImpl(Function &F, const TargetLowering &TLI, const LibcallLoweringInfo &Libcalls, AssumptionCache *AC)
#define DEBUG_TYPE
This is the interface for a simple mod/ref and alias analysis over globals.
Hexagon Common GEP
static MaybeAlign getAlign(Value *Ptr)
static Instruction * matchFunnelShift(Instruction &Or, InstCombinerImpl &IC)
Match UB-safe variants of the funnel shift intrinsic.
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
uint64_t High
This file contains the declarations for profiling metadata utility functions.
const SmallVectorImpl< MachineOperand > & Cond
static const MCExpr * MaskShift(const MCExpr *Val, uint32_t Mask, uint32_t Shift, MCContext &Ctx)
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
Definition Statistic.h:171
#define LLVM_DEBUG(...)
Definition Debug.h:119
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
This pass exposes codegen information to IR-level passes.
Value * RHS
Value * LHS
BinaryOperator * Mul
A manager for alias analyses.
Class for arbitrary precision integers.
Definition APInt.h:78
static APInt getAllOnes(unsigned numBits)
Return an APInt of a specified width with all bits set.
Definition APInt.h:235
uint64_t getZExtValue() const
Get zero extended value.
Definition APInt.h:1563
unsigned getActiveBits() const
Compute the number of active bits in the value.
Definition APInt.h:1535
void setBit(unsigned BitPosition)
Set the given bit to 1 whose position is given as "bitPosition".
Definition APInt.h:1353
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
Definition APInt.h:381
unsigned getBitWidth() const
Return the number of bits in the APInt.
Definition APInt.h:1511
bool isNegative() const
Determine sign of this APInt.
Definition APInt.h:330
static LLVM_ABI APInt getSplat(unsigned NewLen, const APInt &V)
Return a value containing V broadcasted over NewLen bits.
Definition APInt.cpp:652
LLVM_ABI APInt srem(const APInt &RHS) const
Function for signed remainder operation.
Definition APInt.cpp:1788
bool isSubsetOf(const APInt &RHS) const
This operation checks that all bits set in this APInt are also set in RHS.
Definition APInt.h:1264
static APInt getLowBitsSet(unsigned numBits, unsigned loBitsSet)
Constructs an APInt value that has the bottom loBitsSet bits set.
Definition APInt.h:307
bool slt(const APInt &RHS) const
Signed less than comparison.
Definition APInt.h:1137
unsigned countTrailingOnes() const
Definition APInt.h:1685
static APInt getOneBitSet(unsigned numBits, unsigned BitNo)
Return an APInt with exactly one bit set in the result.
Definition APInt.h:240
bool uge(const APInt &RHS) const
Unsigned greater or equal comparison.
Definition APInt.h:1228
PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
const T & front() const
Get the first element.
Definition ArrayRef.h:144
size_t size() const
Get the array size.
Definition ArrayRef.h:141
A function analysis which provides an AssumptionCache.
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
Definition BasicBlock.h:62
iterator begin()
Instruction iterator methods.
Definition BasicBlock.h:461
LLVM_ABI const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
const Function * getParent() const
Return the enclosing method, or null if none.
Definition BasicBlock.h:213
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
Definition BasicBlock.h:206
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
Definition BasicBlock.h:237
This class is a wrapper over an AAResults, and it is intended to be used only when there are no IR ch...
ModRefInfo getModRefInfo(const Instruction *I, const std::optional< MemoryLocation > &OptLoc)
Represents analyses that only rely on functions' control flow.
Definition Analysis.h:73
Value * getArgOperand(unsigned i) const
This class represents a function call, abstracting a target machine's calling convention.
@ ICMP_ULT
unsigned less than
Definition InstrTypes.h:765
@ ICMP_NE
not equal
Definition InstrTypes.h:762
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
This is the shared class of boolean and integer constants.
Definition Constants.h:87
uint64_t getZExtValue() const
Return the constant as a 64-bit unsigned integer value after it has been zero extended as appropriate...
Definition Constants.h:168
This is an important base class in LLVM.
Definition Constant.h:43
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
static LLVM_ABI DebugLoc getMergedLocations(ArrayRef< DebugLoc > Locs)
Try to combine the vector of locations passed as input in a single one.
Definition DebugLoc.cpp:166
Analysis pass which computes a DominatorTree.
Definition Dominators.h:278
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Definition Dominators.h:159
LLVM_ABI bool isReachableFromEntry(const Use &U) const
Provide an overload for a Use.
LLVM_ABI bool dominates(const BasicBlock *BB, const Use &U) const
Return true if the (end of the) basic block BB dominates the use U.
void applyUpdates(ArrayRef< UpdateT > Updates)
Submit updates to all available trees.
an instruction for type-safe pointer arithmetic to access elements of arrays and structs
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
bool hasInitializer() const
Definitions have initializers, declarations don't.
bool isConstant() const
If the value is a global constant, its value is immutable throughout the runtime execution of the pro...
static bool isEquality(Predicate P)
Return true if this predicate is either EQ or NE.
void SetCurrentDebugLocation(const DebugLoc &L)
Set location information used by debugging information.
Definition IRBuilder.h:247
UncondBrInst * CreateBr(BasicBlock *Dest)
Create an unconditional 'br label X' instruction.
Definition IRBuilder.h:1232
PHINode * CreatePHI(Type *Ty, unsigned NumReservedValues, const Twine &Name="")
Definition IRBuilder.h:2539
SwitchInst * CreateSwitch(Value *V, BasicBlock *Dest, unsigned NumCases=10, MDNode *BranchWeights=nullptr, MDNode *Unpredictable=nullptr)
Create a switch instruction with the specified value, default dest, and with a hint for the number of...
Definition IRBuilder.h:1261
Value * CreateTrunc(Value *V, Type *DestTy, const Twine &Name="", bool IsNUW=false, bool IsNSW=false)
Definition IRBuilder.h:2106
void SetInsertPoint(BasicBlock *TheBB)
This specifies that created instructions should be appended to the end of the specified block.
Definition IRBuilder.h:207
Value * CreateInBoundsPtrAdd(Value *Ptr, Value *Offset, const Twine &Name="")
Definition IRBuilder.h:2096
IntegerType * getInt8Ty()
Fetch the type representing an 8-bit integer.
Definition IRBuilder.h:576
This provides a uniform API for creating instructions and inserting them into a basic block: either a...
Definition IRBuilder.h:2858
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI void setAAMetadata(const AAMDNodes &N)
Sets the AA metadata on this instruction from the AAMDNodes structure.
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
LLVM_ABI const Function * getFunction() const
Return the function this instruction belongs to.
LLVM_ABI AAMDNodes getAAMetadata() const
Returns the AA metadata for this instruction.
Class to represent integer types.
static LLVM_ABI IntegerType * get(LLVMContext &C, unsigned NumBits)
This static method is the primary way of constructing an IntegerType.
Definition Type.cpp:354
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
An instruction for reading from memory.
unsigned getPointerAddressSpace() const
Returns the address space of the pointer operand.
Value * getPointerOperand()
bool isSimple() const
static LocationSize precise(uint64_t Value)
LLVM_ABI MDNode * createUnlikelyBranchWeights()
Return metadata containing two branch weights, with significant bias towards false destination.
Definition MDBuilder.cpp:48
size_type size() const
Definition MapVector.h:58
std::pair< KeyT, ValueT > & front()
Definition MapVector.h:81
Representation for a specific memory location.
static LLVM_ABI MemoryLocation get(const LoadInst *LI)
Return a location with information about the memory reference by the given instruction.
static MemoryLocation getBeforeOrAfter(const Value *Ptr, const AAMDNodes &AATags=AAMDNodes())
Return a location that may access any location before or after Ptr, while remaining within the underl...
void addIncoming(Value *V, BasicBlock *BB)
Add an incoming value to the end of the PHI list.
static PHINode * Create(Type *Ty, unsigned NumReservedValues, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructors - NumReservedValues is a hint for the number of incoming edges that this phi node will h...
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
Definition Analysis.h:118
PreservedAnalyses & preserveSet()
Mark an analysis set as preserved.
Definition Analysis.h:151
PreservedAnalyses & preserve()
Mark an analysis as preserved.
Definition Analysis.h:132
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void reserve(size_type N)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
An instruction for storing to memory.
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
static constexpr size_t npos
Definition StringRef.h:58
Multiway switch.
Analysis pass providing the TargetTransformInfo.
Analysis pass providing the TargetLibraryInfo.
Provides information about what library functions are available for the current target.
bool getLibFunc(StringRef funcName, LibFunc &F) const
Searches for a particular function name.
This pass provides access to the codegen interfaces that are needed for IR-level transformations.
@ None
The insert/extract is not used with a load/store.
@ TCK_RecipThroughput
Reciprocal throughput.
@ TCK_SizeAndLatency
The weighted sum of size and latency.
@ TCC_Basic
The cost of a typical 'add' instruction.
bool run(Function &F)
Perform TruncInst pattern optimization on given function.
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
LLVM_ABI unsigned getIntegerBitWidth() const
LLVM_ABI TypeSize getPrimitiveSizeInBits() const LLVM_READONLY
Return the basic size of this type if it is a primitive type.
Definition Type.cpp:201
LLVM_ABI Type * getWithNewBitWidth(unsigned NewBitWidth) const
Given an integer or vector type, change the lane bitwidth to NewBitwidth, whilst keeping the old numb...
LLVM_ABI unsigned getScalarSizeInBits() const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
Definition Type.cpp:236
bool isIntegerTy() const
True if this is an instance of IntegerType.
Definition Type.h:257
static LLVM_ABI IntegerType * getIntNTy(LLVMContext &C, unsigned N)
Definition Type.cpp:317
LLVM Value Representation.
Definition Value.h:75
Type * getType() const
All values are typed, get the type of this value.
Definition Value.h:255
bool hasOneUse() const
Return true if there is exactly one use of this value.
Definition Value.h:439
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
Definition Value.cpp:549
LLVMContext & getContext() const
All values hold a context through their type.
Definition Value.h:258
LLVM_ABI bool hasNUsesOrMore(unsigned N) const
Return true if this value has N uses or more.
Definition Value.cpp:154
LLVM_ABI const Value * stripAndAccumulateConstantOffsets(const DataLayout &DL, APInt &Offset, bool AllowNonInbounds, bool AllowInvariantGroup=false, function_ref< bool(Value &Value, APInt &Offset)> ExternalAnalysis=nullptr, bool LookThroughIntToPtr=false) const
Accumulate the constant offset this value has compared to a base pointer.
LLVM_ABI uint64_t getPointerDereferenceableBytes(const DataLayout &DL, bool &CanBeNull, bool &CanBeFreed) const
Returns the number of bytes known to be dereferenceable for the pointer value.
Definition Value.cpp:890
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
Definition Value.cpp:318
LLVM_ABI void takeName(Value *V)
Transfer the name from V to this value.
Definition Value.cpp:399
static LLVM_ABI VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
const ParentTy * getParent() const
Definition ilist_node.h:34
CallInst * Call
Changed
#define UINT64_MAX
Definition DataTypes.h:77
Abstract Attribute helper functions.
Definition Attributor.h:165
LLVM_ABI APInt GreatestCommonDivisor(APInt A, APInt B)
Compute GCD of two unsigned APInt values.
Definition APInt.cpp:830
@ Fast
Attempts to make calls as fast as possible (e.g.
Definition CallingConv.h:41
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
@ BasicBlock
Various leaf nodes.
Definition ISDOpcodes.h:81
SpecificConstantMatch m_ZeroInt()
Convenience matchers for specific integer values.
BinaryOp_match< SpecificConstantMatch, SrcTy, TargetOpcode::G_SUB > m_Neg(const SrcTy &&Src)
Matches a register negated by a G_SUB.
OneUse_match< SubPat > m_OneUse(const SubPat &SP)
match_combine_or< Ty... > m_CombineOr(const Ty &...Ps)
Combine pattern matchers matching any of Ps patterns.
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
ShiftLike_match< LHS, Instruction::LShr > m_LShrOrSelf(const LHS &L, uint64_t &R)
Matches lshr L, ConstShAmt or L itself (R will be set to zero in this case).
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
match_combine_or< CastInst_match< OpTy, CastInst >, OpTy > m_CastOrSelf(const OpTy &Op)
Matches any cast or self. Used to ignore casts.
ap_match< APInt > m_APInt(const APInt *&Res)
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt.
BinaryOp_match< LHS, RHS, Instruction::And, true > m_c_And(const LHS &L, const RHS &R)
Matches an And with LHS and RHS in either order.
CastInst_match< OpTy, TruncInst > m_Trunc(const OpTy &Op)
Matches Trunc.
specific_intval< false > m_SpecificInt(const APInt &V)
Match a specific integer value or vector with all elements equal to the value.
bool match(Val *V, const Pattern &P)
match_bind< Instruction > m_Instruction(Instruction *&I)
Match an instruction, capturing it if we match.
match_deferred< Value > m_Deferred(Value *const &V)
Like m_Specific(), but works if the specific value to match is determined as part of the same match()...
specificval_ty m_Specific(const Value *V)
Match if we have a specific specified value.
cst_pred_ty< is_one > m_One()
Match an integer 1 or a vector with all elements equal to 1.
ThreeOps_match< Cond, LHS, RHS, Instruction::Select > m_Select(const Cond &C, const LHS &L, const RHS &R)
Matches SelectInst.
MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty > m_SMin(const LHS &L, const RHS &R)
auto m_Value()
Match an arbitrary value and ignore it.
ShiftLike_match< LHS, Instruction::Shl > m_ShlOrSelf(const LHS &L, uint64_t &R)
Matches shl L, ConstShAmt or L itself (R will be set to zero in this case).
BinaryOp_match< LHS, RHS, Instruction::Mul > m_Mul(const LHS &L, const RHS &R)
specific_bbval m_SpecificBB(BasicBlock *BB)
Match a specific basic block value.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Shl, OverflowingBinaryOperator::NoSignedWrap > m_NSWShl(const LHS &L, const RHS &R)
SpecificCmpClass_match< LHS, RHS, ICmpInst > m_SpecificICmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
CastInst_match< OpTy, ZExtInst > m_ZExt(const OpTy &Op)
Matches ZExt.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Shl, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWShl(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::Add, true > m_c_Add(const LHS &L, const RHS &R)
Matches a Add with LHS and RHS in either order.
match_combine_or< BinaryOp_match< LHS, RHS, Instruction::Add >, DisjointOr_match< LHS, RHS > > m_AddLike(const LHS &L, const RHS &R)
Match either "add" or "or disjoint".
CastInst_match< OpTy, FPToSIInst > m_FPToSI(const OpTy &Op)
MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty > m_SMax(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::LShr > m_LShr(const LHS &L, const RHS &R)
CmpClass_match< LHS, RHS, ICmpInst > m_ICmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::Shl > m_Shl(const LHS &L, const RHS &R)
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_Cttz(const Opnd0 &Op0, const Opnd1 &Op1)
brc_match< Cond_t, match_bind< BasicBlock >, match_bind< BasicBlock > > m_Br(const Cond_t &C, BasicBlock *&T, BasicBlock *&F)
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_Ctlz(const Opnd0 &Op0, const Opnd1 &Op1)
BinaryOp_match< LHS, RHS, Instruction::Or > m_Or(const LHS &L, const RHS &R)
is_zero m_Zero()
Match any null constant or a vector with all elements equal to 0.
BinaryOp_match< LHS, RHS, Instruction::Or, true > m_c_Or(const LHS &L, const RHS &R)
Matches an Or with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::Mul, true > m_c_Mul(const LHS &L, const RHS &R)
Matches a Mul with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
initializer< Ty > init(const Ty &Val)
NodeAddr< PhiNode * > Phi
Definition RDFGraph.h:390
This is an optimization pass for GlobalISel generic memory operations.
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
Definition STLExtras.h:315
@ Low
Lower the current thread's priority such that it does not affect foreground tasks significantly.
Definition Threading.h:280
FunctionAddr VTableAddr Value
Definition InstrProf.h:137
cl::opt< bool > ProfcheckDisableMetadataFixes
Definition LoopInfo.cpp:60
LLVM_ABI void setExplicitlyUnknownBranchWeightsIfProfiled(Instruction &I, StringRef PassName, const Function *F=nullptr)
Like setExplicitlyUnknownBranchWeights(...), but only sets unknown branch weights in the new instruct...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
LLVM_ABI bool isOnlyUsedInZeroComparison(const Instruction *CxtI)
LLVM_ABI bool getConstantStringInfo(const Value *V, StringRef &Str, bool TrimAtNul=true)
This function computes the length of a null-terminated C string pointed to by V.
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
iterator_range< early_inc_iterator_impl< detail::IterOfRange< RangeT > > > make_early_inc_range(RangeT &&Range)
Make a range that does early increment to allow mutation of the underlying range without disrupting i...
Definition STLExtras.h:633
LLVM_ABI bool SimplifyInstructionsInBlock(BasicBlock *BB, const TargetLibraryInfo *TLI=nullptr)
Scan the specified basic block and try to simplify any instructions in it and recursively delete dead...
Definition Local.cpp:723
LLVM_ABI void setExplicitlyUnknownBranchWeights(Instruction &I, StringRef PassName)
Specify that the branch weights for this terminator cannot be known at compile time.
LLVM_ABI bool MaskedValueIsZero(const Value *V, const APInt &Mask, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if 'V & Mask' is known to be zero.
LLVM_ABI bool isLibFuncEmittable(const Module *M, const TargetLibraryInfo *TLI, LibFunc TheLibFunc)
Check whether the library function is available on target and also that it in the current Module is a...
auto dyn_cast_or_null(const Y &Val)
Definition Casting.h:753
unsigned Log2_32(uint32_t Value)
Return the floor log base 2 of the specified value, -1 if the value is zero.
Definition MathExtras.h:331
auto reverse(ContainerTy &&C)
Definition STLExtras.h:407
constexpr bool isPowerOf2_32(uint32_t Value)
Return true if the argument is a power of two > 0.
Definition MathExtras.h:279
bool isModSet(const ModRefInfo MRI)
Definition ModRef.h:49
void sort(IteratorTy Start, IteratorTy End)
Definition STLExtras.h:1635
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:209
bool isModOrRefSet(const ModRefInfo MRI)
Definition ModRef.h:43
LLVM_ABI Constant * ConstantFoldLoadFromConst(Constant *C, Type *Ty, const APInt &Offset, const DataLayout &DL)
Extract value of C at the given Offset reinterpreted as Ty.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
Definition Casting.h:547
@ Other
Any other memory.
Definition ModRef.h:68
@ First
Helpers to iterate all locations in the MemoryEffectsBase class.
Definition ModRef.h:74
TargetTransformInfo TTI
IRBuilder(LLVMContext &, FolderTy, InserterTy, MDNode *, ArrayRef< OperandBundleDef >) -> IRBuilder< FolderTy, InserterTy >
@ Sub
Subtraction of integers.
LLVM_ABI BasicBlock * SplitBlock(BasicBlock *Old, BasicBlock::iterator SplitPt, DominatorTree *DT, LoopInfo *LI=nullptr, MemorySSAUpdater *MSSAU=nullptr, const Twine &BBName="")
Split the specified block at the specified instruction.
ArrayRef(const T &OneElt) -> ArrayRef< T >
constexpr unsigned BitWidth
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
LLVM_ABI bool isGuaranteedNotToBePoison(const Value *V, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Returns true if V cannot be poison, but may be undef.
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
AAResults AliasAnalysis
Temporary typedef for legacy code that uses a generic AliasAnalysis pointer or reference.
LLVM_ABI bool cannotBeOrderedLessThanZero(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Return true if we can prove that the specified FP value is either NaN or never less than -0....
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
Definition BitVector.h:876
#define N
This is used by foldLoadsRecursive() to capture a Root Load node which is of type or(load,...
ValWidth bits starting at ValOffset of Val stored at PtrBase+PtrOffset.
bool operator<(const PartStore &Other) const
bool isCompatibleWith(const PartStore &Other) const
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
Definition Metadata.h:763
LLVM_ABI AAMDNodes concat(const AAMDNodes &Other) const
Determine the best AAMDNodes after concatenating two different locations together.
Matching combinators.
A MapVector that performs no allocations if smaller than a certain size.
Definition MapVector.h:334