LLVM 23.0.0git
AliasAnalysis.cpp
Go to the documentation of this file.
1//==- AliasAnalysis.cpp - Generic Alias Analysis Interface Implementation --==//
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 generic AliasAnalysis interface which is used as the
10// common interface used by all clients and implementations of alias analysis.
11//
12// This file also implements the default version of the AliasAnalysis interface
13// that is to be used when no other implementation is specified. This does some
14// simple tests that detect obvious cases: two different global pointers cannot
15// alias, a global cannot alias a malloc, two different mallocs cannot alias,
16// etc.
17//
18// This alias analysis implementation really isn't very good for anything, but
19// it is very fast, and makes a nice clean default implementation. Because it
20// handles lots of little corner cases, other, more complex, alias analysis
21// implementations may choose to rely on this pass to resolve these simple and
22// easy cases.
23//
24//===----------------------------------------------------------------------===//
25
27#include "llvm/ADT/Statistic.h"
37#include "llvm/IR/Argument.h"
38#include "llvm/IR/Attributes.h"
39#include "llvm/IR/BasicBlock.h"
40#include "llvm/IR/Instruction.h"
42#include "llvm/IR/Type.h"
43#include "llvm/IR/Value.h"
45#include "llvm/Pass.h"
49#include <cassert>
50#include <functional>
51#include <iterator>
52
53#define DEBUG_TYPE "aa"
54
55using namespace llvm;
56
57STATISTIC(NumNoAlias, "Number of NoAlias results");
58STATISTIC(NumMayAlias, "Number of MayAlias results");
59STATISTIC(NumMustAlias, "Number of MustAlias results");
60
61/// Allow disabling BasicAA from the AA results. This is particularly useful
62/// when testing to isolate a single AA implementation.
63static cl::opt<bool> DisableBasicAA("disable-basic-aa", cl::Hidden,
64 cl::init(false));
65
66#ifndef NDEBUG
67/// Print a trace of alias analysis queries and their results.
68static cl::opt<bool> EnableAATrace("aa-trace", cl::Hidden, cl::init(false));
69#else
70static const bool EnableAATrace = false;
71#endif
72
73AAResults::AAResults(const TargetLibraryInfo &TLI) : TLI(TLI) {}
74
76 : TLI(Arg.TLI), AAs(std::move(Arg.AAs)), AADeps(std::move(Arg.AADeps)) {}
77
78AAResults::~AAResults() = default;
79
81 FunctionAnalysisManager::Invalidator &Inv) {
82 // AAResults preserves the AAManager by default, due to the stateless nature
83 // of AliasAnalysis. There is no need to check whether it has been preserved
84 // explicitly. Check if any module dependency was invalidated and caused the
85 // AAManager to be invalidated. Invalidate ourselves in that case.
86 auto PAC = PA.getChecker<AAManager>();
87 if (!PAC.preservedWhenStateless())
88 return true;
89
90 // Check if any of the function dependencies were invalidated, and invalidate
91 // ourselves in that case.
92 for (AnalysisKey *ID : AADeps)
93 if (Inv.invalidate(ID, F, PA))
94 return true;
95
96 // Everything we depend on is still fine, so are we. Nothing to invalidate.
97 return false;
98}
99
100//===----------------------------------------------------------------------===//
101// Default chaining methods
102//===----------------------------------------------------------------------===//
103
105 const MemoryLocation &LocB) {
106 SimpleAAQueryInfo AAQIP(*this);
107 return alias(LocA, LocB, AAQIP, nullptr);
108}
109
111 const MemoryLocation &LocB, AAQueryInfo &AAQI,
112 const Instruction *CtxI) {
113 assert(LocA.Ptr->getType()->isPointerTy() &&
114 LocB.Ptr->getType()->isPointerTy() &&
115 "Can only call alias() on pointers");
117
118 if (EnableAATrace) {
119 for (unsigned I = 0; I < AAQI.Depth; ++I)
120 dbgs() << " ";
121 dbgs() << "Start " << *LocA.Ptr << " @ " << LocA.Size << ", "
122 << *LocB.Ptr << " @ " << LocB.Size << "\n";
123 }
124
125 AAQI.Depth++;
126 for (const auto &AA : AAs) {
127 Result = AA->alias(LocA, LocB, AAQI, CtxI);
128 if (Result != AliasResult::MayAlias)
129 break;
130 }
131 AAQI.Depth--;
132
133 if (EnableAATrace) {
134 for (unsigned I = 0; I < AAQI.Depth; ++I)
135 dbgs() << " ";
136 dbgs() << "End " << *LocA.Ptr << " @ " << LocA.Size << ", "
137 << *LocB.Ptr << " @ " << LocB.Size << " = " << Result << "\n";
138 }
139
140 if (AAQI.Depth == 0) {
141 if (Result == AliasResult::NoAlias)
142 ++NumNoAlias;
143 else if (Result == AliasResult::MustAlias)
144 ++NumMustAlias;
145 else
146 ++NumMayAlias;
147 }
148 return Result;
149}
150
153
154 for (const auto &AA : AAs) {
155 Result = AA->aliasErrno(Loc, M);
156 if (Result != AliasResult::MayAlias)
157 break;
158 }
159
160 return Result;
161}
162
164 bool IgnoreLocals) {
165 SimpleAAQueryInfo AAQIP(*this);
166 return getModRefInfoMask(Loc, AAQIP, IgnoreLocals);
167}
168
170 AAQueryInfo &AAQI, bool IgnoreLocals) {
172
173 for (const auto &AA : AAs) {
174 Result &= AA->getModRefInfoMask(Loc, AAQI, IgnoreLocals);
175
176 // Early-exit the moment we reach the bottom of the lattice.
177 if (isNoModRef(Result))
179 }
180
181 return Result;
182}
183
186
187 for (const auto &AA : AAs) {
188 Result &= AA->getArgModRefInfo(Call, ArgIdx);
189
190 // Early-exit the moment we reach the bottom of the lattice.
191 if (isNoModRef(Result))
193 }
194
195 return Result;
196}
197
199 const CallBase *Call2) {
200 SimpleAAQueryInfo AAQIP(*this);
201 return getModRefInfo(I, Call2, AAQIP);
202}
203
205 AAQueryInfo &AAQI) {
206 // We may have two calls.
207 if (const auto *Call1 = dyn_cast<CallBase>(I)) {
208 // Check if the two calls modify the same memory.
209 return getModRefInfo(Call1, Call2, AAQI);
210 }
211 // If this is a fence, just return ModRef.
212 if (I->isFenceLike())
213 return ModRefInfo::ModRef;
214 // Otherwise, check if the call modifies or references the
215 // location this memory access defines. The best we can say
216 // is that if the call references what this instruction
217 // defines, it must be clobbered by this location.
218 const MemoryLocation DefLoc = MemoryLocation::get(I);
219 ModRefInfo MR = getModRefInfo(Call2, DefLoc, AAQI);
220 if (isModOrRefSet(MR))
221 return ModRefInfo::ModRef;
223}
224
226 const MemoryLocation &Loc,
227 AAQueryInfo &AAQI) {
229
230 for (const auto &AA : AAs) {
231 Result &= AA->getModRefInfo(Call, Loc, AAQI);
232
233 // Early-exit the moment we reach the bottom of the lattice.
234 if (isNoModRef(Result))
236 }
237
238 // Apply the ModRef mask. This ensures that if Loc is a constant memory
239 // location, we take into account the fact that the call definitely could not
240 // modify the memory location.
241 if (!isNoModRef(Result))
242 Result &= getModRefInfoMask(Loc);
243
244 return Result;
245}
246
249 const MemoryEffects CallDef) {
250
252 auto addModRefInfoForLoc = [&](IRMemLocation L) {
253 ModRefInfo UseMR = CallUse.getModRef(L);
254 if (UseMR == ModRefInfo::NoModRef)
255 return;
256 ModRefInfo DefMR = CallDef.getModRef(L);
257 if (DefMR == ModRefInfo::NoModRef)
258 return;
259 if (DefMR == ModRefInfo::Ref && DefMR == UseMR)
260 return;
261 Result |= UseMR;
262 };
263
264 addModRefInfoForLoc(IRMemLocation::InaccessibleMem);
266 addModRefInfoForLoc(Loc);
267 return Result;
268}
269
271 const CallBase *Call2, AAQueryInfo &AAQI) {
273
274 for (const auto &AA : AAs) {
275 Result &= AA->getModRefInfo(Call1, Call2, AAQI);
276
277 // Early-exit the moment we reach the bottom of the lattice.
278 if (isNoModRef(Result))
280 }
281
282 // Try to refine the mod-ref info further using other API entry points to the
283 // aggregate set of AA results.
284
285 // If Call1 or Call2 are readnone, they don't interact.
286 auto Call1B = getMemoryEffects(Call1, AAQI);
287 if (Call1B.doesNotAccessMemory())
289
290 auto Call2B = getMemoryEffects(Call2, AAQI);
291 if (Call2B.doesNotAccessMemory())
293
294 // If they both only read from memory, there is no dependence.
295 if (Call1B.onlyReadsMemory() && Call2B.onlyReadsMemory())
297
298 // If Call1 only reads memory, the only dependence on Call2 can be
299 // from Call1 reading memory written by Call2.
300 if (Call1B.onlyReadsMemory())
301 Result &= ModRefInfo::Ref;
302 else if (Call1B.onlyWritesMemory())
303 Result &= ModRefInfo::Mod;
304
305 // If Call2 only access memory through arguments, accumulate the mod/ref
306 // information from Call1's references to the memory referenced by
307 // Call2's arguments.
308 if (Call2B.onlyAccessesArgPointees()) {
309 if (!Call2B.doesAccessArgPointees())
312 for (auto I = Call2->arg_begin(), E = Call2->arg_end(); I != E; ++I) {
313 const Value *Arg = *I;
314 if (!Arg->getType()->isPointerTy())
315 continue;
316 unsigned Call2ArgIdx = std::distance(Call2->arg_begin(), I);
317 auto Call2ArgLoc =
318 MemoryLocation::getForArgument(Call2, Call2ArgIdx, TLI);
319
320 // ArgModRefC2 indicates what Call2 might do to Call2ArgLoc, and the
321 // dependence of Call1 on that location is the inverse:
322 // - If Call2 modifies location, dependence exists if Call1 reads or
323 // writes.
324 // - If Call2 only reads location, dependence exists if Call1 writes.
325 ModRefInfo ArgModRefC2 = getArgModRefInfo(Call2, Call2ArgIdx);
327 if (isModSet(ArgModRefC2))
328 ArgMask = ModRefInfo::ModRef;
329 else if (isRefSet(ArgModRefC2))
330 ArgMask = ModRefInfo::Mod;
331
332 // ModRefC1 indicates what Call1 might do to Call2ArgLoc, and we use
333 // above ArgMask to update dependence info.
334 ArgMask &= getModRefInfo(Call1, Call2ArgLoc, AAQI);
335
336 R = (R | ArgMask) & Result;
337 if (R == Result)
338 break;
339 }
340
341 return R;
342 }
343
344 // If Call1 only accesses memory through arguments, check if Call2 references
345 // any of the memory referenced by Call1's arguments. If not, return NoModRef.
346 if (Call1B.onlyAccessesArgPointees()) {
347 if (!Call1B.doesAccessArgPointees())
350 for (auto I = Call1->arg_begin(), E = Call1->arg_end(); I != E; ++I) {
351 const Value *Arg = *I;
352 if (!Arg->getType()->isPointerTy())
353 continue;
354 unsigned Call1ArgIdx = std::distance(Call1->arg_begin(), I);
355 auto Call1ArgLoc =
356 MemoryLocation::getForArgument(Call1, Call1ArgIdx, TLI);
357
358 // ArgModRefC1 indicates what Call1 might do to Call1ArgLoc; if Call1
359 // might Mod Call1ArgLoc, then we care about either a Mod or a Ref by
360 // Call2. If Call1 might Ref, then we care only about a Mod by Call2.
361 ModRefInfo ArgModRefC1 = getArgModRefInfo(Call1, Call1ArgIdx);
362 ModRefInfo ModRefC2 = getModRefInfo(Call2, Call1ArgLoc, AAQI);
363 if ((isModSet(ArgModRefC1) && isModOrRefSet(ModRefC2)) ||
364 (isRefSet(ArgModRefC1) && isModSet(ModRefC2)))
365 R = (R | ArgModRefC1) & Result;
366
367 if (R == Result)
368 break;
369 }
370
371 return R;
372 }
373
374 // If only Inaccessible and Target Memory Location have set ModRefInfo
375 // then check the relation between the same locations.
376 if (Call1B.onlyAccessesInaccessibleOrTargetMem() &&
377 Call2B.onlyAccessesInaccessibleOrTargetMem())
378 return getModRefInfoInaccessibleAndTargetMemLoc(Call1B, Call2B);
379
380 return Result;
381}
382
384 const Instruction *I2) {
385 SimpleAAQueryInfo AAQIP(*this);
386 return getModRefInfo(I1, I2, AAQIP);
387}
388
390 const Instruction *I2, AAQueryInfo &AAQI) {
391 // Early-exit if either instruction does not read or write memory.
392 if (!I1->mayReadOrWriteMemory() || !I2->mayReadOrWriteMemory())
394
395 if (const auto *Call2 = dyn_cast<CallBase>(I2))
396 return getModRefInfo(I1, Call2, AAQI);
397
398 // FIXME: We can have a more precise result.
401}
402
404 AAQueryInfo &AAQI) {
406
407 for (const auto &AA : AAs) {
408 Result &= AA->getMemoryEffects(Call, AAQI);
409
410 // Early-exit the moment we reach the bottom of the lattice.
411 if (Result.doesNotAccessMemory())
412 return Result;
413 }
414
415 return Result;
416}
417
422
425
426 for (const auto &AA : AAs) {
427 Result &= AA->getMemoryEffects(F);
428
429 // Early-exit the moment we reach the bottom of the lattice.
430 if (Result.doesNotAccessMemory())
431 return Result;
432 }
433
434 return Result;
435}
436
438 switch (AR) {
440 OS << "NoAlias";
441 break;
443 OS << "MustAlias";
444 break;
446 OS << "MayAlias";
447 break;
449 OS << "PartialAlias";
450 if (AR.hasOffset())
451 OS << " (off " << AR.getOffset() << ")";
452 break;
453 }
454 return OS;
455}
456
457//===----------------------------------------------------------------------===//
458// Helper method implementation
459//===----------------------------------------------------------------------===//
460
462 AAQueryInfo &AAQI) {
463 if (!Loc.Ptr)
464 return ModRefInfo::ModRef;
465
466 // If the location is *never* captured, it cannot be affected by
467 // synchronizing operations. However, we cannot ignore locations that are
468 // only captured after the operation, as the synchronization may still have
469 // an effect if the object is only captured *later*. As such, set I to null
470 // and ReturnCaptures to true here.
471 const Value *Obj = getUnderlyingObject(Loc.Ptr);
473 Obj, /*I=*/nullptr, /*OrAt=*/true, /*ReturnCaptures=*/true);
474 if (capturesNothing(CC))
476
477 // If only read provenance was captured, other threads may only read the
478 // object.
479 ModRefInfo MR =
481
482 // If Loc is a constant memory location, the synchronization operation
483 // definitely could not modify it.
484 return MR & AA->getModRefInfoMask(Loc);
485}
486
488 const MemoryLocation &Loc,
489 AAQueryInfo &AAQI) {
490 // If the load address doesn't alias the given address, it doesn't read
491 // or write the specified memory.
492 if (Loc.Ptr) {
493 AliasResult AR = alias(MemoryLocation::get(L), Loc, AAQI, L);
494 if (AR == AliasResult::NoAlias) {
495 // Synchronization effects may affect locations that do not alias.
496 // FIXME: Should be isStrongerThanMonotonic().
497 if (isStrongerThanUnordered(L->getOrdering()))
498 return getSyncEffects(this, Loc, AAQI);
500 }
501 }
502
503 // Preserve the ordering requirement.
504 if (isStrongerThanUnordered(L->getOrdering()))
505 return ModRefInfo::ModRef;
506
507 // Otherwise, a load just reads.
508 return ModRefInfo::Ref;
509}
510
512 const MemoryLocation &Loc,
513 AAQueryInfo &AAQI) {
514 if (Loc.Ptr) {
515 AliasResult AR = alias(MemoryLocation::get(S), Loc, AAQI, S);
516 // If the store address cannot alias the pointer in question, then the
517 // specified memory cannot be modified by the store.
518 if (AR == AliasResult::NoAlias) {
519 // Synchronization effects may affect locations that do not alias.
520 // FIXME: Should be isStrongerThanMonotonic().
522 return getSyncEffects(this, Loc, AAQI);
524 }
525
526 // Examine the ModRef mask. If Mod isn't present, then return NoModRef.
527 // This ensures that if Loc is a constant memory location, we take into
528 // account the fact that the store definitely could not modify the memory
529 // location.
532 }
533
534 // Preserve the ordering requirement.
536 return ModRefInfo::ModRef;
537
538 // Otherwise, a store just writes.
539 return ModRefInfo::Mod;
540}
541
543 const MemoryLocation &Loc,
544 AAQueryInfo &AAQI) {
545 if (Loc.Ptr) {
547
548 for (const auto &AA : AAs) {
549 Result &= AA->getModRefInfo(F, Loc, AAQI);
550
551 if (isNoModRef(Result))
553 }
554
555 return Result & getSyncEffects(this, Loc, AAQI);
556 }
557
558 return ModRefInfo::ModRef;
559}
560
562 const MemoryLocation &Loc,
563 AAQueryInfo &AAQI) {
564 if (Loc.Ptr) {
565 AliasResult AR = alias(MemoryLocation::get(V), Loc, AAQI, V);
566 // If the va_arg address cannot alias the pointer in question, then the
567 // specified memory cannot be accessed by the va_arg.
568 if (AR == AliasResult::NoAlias)
570
571 // If the pointer is a pointer to invariant memory, then it could not have
572 // been modified by this va_arg.
573 return getModRefInfoMask(Loc, AAQI);
574 }
575
576 // Otherwise, a va_arg reads and writes.
577 return ModRefInfo::ModRef;
578}
579
581 const MemoryLocation &Loc,
582 AAQueryInfo &AAQI) {
583 if (Loc.Ptr) {
584 // If the pointer is a pointer to invariant memory,
585 // then it could not have been modified by this catchpad.
586 return getModRefInfoMask(Loc, AAQI);
587 }
588
589 // Otherwise, a catchpad reads and writes.
590 return ModRefInfo::ModRef;
591}
592
594 const MemoryLocation &Loc,
595 AAQueryInfo &AAQI) {
596 if (Loc.Ptr) {
597 // If the pointer is a pointer to invariant memory,
598 // then it could not have been modified by this catchpad.
599 return getModRefInfoMask(Loc, AAQI);
600 }
601
602 // Otherwise, a catchret reads and writes.
603 return ModRefInfo::ModRef;
604}
605
607 const MemoryLocation &Loc,
608 AAQueryInfo &AAQI) {
609 if (Loc.Ptr) {
610 AliasResult AR = alias(MemoryLocation::get(CX), Loc, AAQI, CX);
611 // If the cmpxchg address does not alias the location, it does not access
612 // it.
613 if (AR == AliasResult::NoAlias) {
614 // Synchronization effects may affect locations that do not alias.
616 return getSyncEffects(this, Loc, AAQI);
618 }
619 }
620
621 return ModRefInfo::ModRef;
622}
623
625 const MemoryLocation &Loc,
626 AAQueryInfo &AAQI) {
627 if (Loc.Ptr) {
628 AliasResult AR = alias(MemoryLocation::get(RMW), Loc, AAQI, RMW);
629 // If the atomicrmw address does not alias the location, it does not access
630 // it.
631 if (AR == AliasResult::NoAlias) {
632 // Synchronization effects may affect locations that do not alias.
634 return getSyncEffects(this, Loc, AAQI);
636 }
637 }
638
639 return ModRefInfo::ModRef;
640}
641
643 const std::optional<MemoryLocation> &OptLoc,
644 AAQueryInfo &AAQIP) {
645 if (OptLoc == std::nullopt) {
646 if (const auto *Call = dyn_cast<CallBase>(I))
647 return getMemoryEffects(Call, AAQIP).getModRef();
648 }
649
650 const MemoryLocation &Loc = OptLoc.value_or(MemoryLocation());
651
652 switch (I->getOpcode()) {
653 case Instruction::VAArg:
654 return getModRefInfo((const VAArgInst *)I, Loc, AAQIP);
655 case Instruction::Load:
656 return getModRefInfo((const LoadInst *)I, Loc, AAQIP);
657 case Instruction::Store:
658 return getModRefInfo((const StoreInst *)I, Loc, AAQIP);
659 case Instruction::Fence:
660 return getModRefInfo((const FenceInst *)I, Loc, AAQIP);
661 case Instruction::AtomicCmpXchg:
662 return getModRefInfo((const AtomicCmpXchgInst *)I, Loc, AAQIP);
663 case Instruction::AtomicRMW:
664 return getModRefInfo((const AtomicRMWInst *)I, Loc, AAQIP);
665 case Instruction::Call:
666 case Instruction::CallBr:
667 case Instruction::Invoke:
668 return getModRefInfo((const CallBase *)I, Loc, AAQIP);
669 case Instruction::CatchPad:
670 return getModRefInfo((const CatchPadInst *)I, Loc, AAQIP);
671 case Instruction::CatchRet:
672 return getModRefInfo((const CatchReturnInst *)I, Loc, AAQIP);
673 default:
674 assert(!I->mayReadOrWriteMemory() &&
675 "Unhandled memory access instruction!");
677 }
678}
679
680/// Return information about whether a particular call site modifies
681/// or reads the specified memory location \p MemLoc before instruction \p I
682/// in a BasicBlock.
683/// FIXME: this is really just shoring-up a deficiency in alias analysis.
684/// BasicAA isn't willing to spend linear time determining whether an alloca
685/// was captured before or after this particular call, while we are. However,
686/// with a smarter AA in place, this test is just wasting compile time.
688 const MemoryLocation &MemLoc,
689 DominatorTree *DT,
690 AAQueryInfo &AAQI) {
691 if (!DT)
692 return ModRefInfo::ModRef;
693
694 const Value *Object = getUnderlyingObject(MemLoc.Ptr);
695 if (!isIdentifiedFunctionLocal(Object))
696 return ModRefInfo::ModRef;
697
698 const auto *Call = dyn_cast<CallBase>(I);
699 if (!Call || Call == Object)
700 return ModRefInfo::ModRef;
701
703 Object, /* ReturnCaptures */ true, I, DT,
704 /* include Object */ true, CaptureComponents::Provenance)))
705 return ModRefInfo::ModRef;
706
707 unsigned ArgNo = 0;
709 // Set flag only if no May found and all operands processed.
710 for (auto CI = Call->data_operands_begin(), CE = Call->data_operands_end();
711 CI != CE; ++CI, ++ArgNo) {
712 // Only look at the no-capture or byval pointer arguments. If this
713 // pointer were passed to arguments that were neither of these, then it
714 // couldn't be no-capture.
715 if (!(*CI)->getType()->isPointerTy())
716 continue;
717
718 // Make sure we still check captures(ret: address, provenance) and
719 // captures(address) arguments, as these wouldn't be treated as a capture
720 // at the call-site.
721 CaptureInfo Captures = Call->getCaptureInfo(ArgNo);
723 continue;
724
725 AliasResult AR =
728 // If this is a no-capture pointer argument, see if we can tell that it
729 // is impossible to alias the pointer we're checking. If not, we have to
730 // assume that the call could touch the pointer, even though it doesn't
731 // escape.
732 if (AR == AliasResult::NoAlias)
733 continue;
734 if (Call->doesNotAccessMemory(ArgNo))
735 continue;
736 if (Call->onlyReadsMemory(ArgNo)) {
737 R = ModRefInfo::Ref;
738 continue;
739 }
740 return ModRefInfo::ModRef;
741 }
742 return R;
743}
744
745/// canBasicBlockModify - Return true if it is possible for execution of the
746/// specified basic block to modify the location Loc.
747///
752
753/// canInstructionRangeModRef - Return true if it is possible for the
754/// execution of the specified instructions to mod\ref (according to the
755/// mode) the location Loc. The instructions to consider are all
756/// of the instructions in the range of [I1,I2] INCLUSIVE.
757/// I1 and I2 must be in the same basic block.
759 const Instruction &I2,
760 const MemoryLocation &Loc,
761 const ModRefInfo Mode) {
762 assert(I1.getParent() == I2.getParent() &&
763 "Instructions not in same basic block!");
764 BasicBlock::const_iterator I = I1.getIterator();
766 ++E; // Convert from inclusive to exclusive range.
767
768 for (; I != E; ++I) // Check every instruction in range
769 if (isModOrRefSet(getModRefInfo(&*I, Loc) & Mode))
770 return true;
771 return false;
772}
773
774// Provide a definition for the root virtual destructor.
776
777// Provide a definition for the static object used to identify passes.
778AnalysisKey AAManager::Key;
779
781
784
786
787INITIALIZE_PASS(ExternalAAWrapperPass, "external-aa", "External Alias Analysis",
788 false, true)
789
792 return new ExternalAAWrapperPass(std::move(Callback));
793}
794
796
798
800 "Function Alias Analysis Results", false, true)
808 "Function Alias Analysis Results", false, true)
809
810/// Run the wrapper pass to rebuild an aggregation over known AA passes.
811///
812/// This is the legacy pass manager's interface to the new-style AA results
813/// aggregation object. Because this is somewhat shoe-horned into the legacy
814/// pass manager, we hard code all the specific alias analyses available into
815/// it. While the particular set enabled is configured via commandline flags,
816/// adding a new alias analysis to LLVM will require adding support for it to
817/// this list.
819 // NB! This *must* be reset before adding new AA results to the new
820 // AAResults object because in the legacy pass manager, each instance
821 // of these will refer to the *same* immutable analyses, registering and
822 // unregistering themselves with them. We need to carefully tear down the
823 // previous object first, in this case replacing it with an empty one, before
824 // registering new results.
825 AAR.reset(
827
828 // Add any target-specific alias analyses that should be run early.
829 auto *ExtWrapperPass = getAnalysisIfAvailable<ExternalAAWrapperPass>();
830 if (ExtWrapperPass && ExtWrapperPass->RunEarly && ExtWrapperPass->CB) {
831 LLVM_DEBUG(dbgs() << "AAResults register Early ExternalAA: "
832 << ExtWrapperPass->getPassName() << "\n");
833 ExtWrapperPass->CB(*this, F, *AAR);
834 }
835
836 // BasicAA is always available for function analyses. Also, we add it first
837 // so that it can trump TBAA results when it proves MustAlias.
838 // FIXME: TBAA should have an explicit mode to support this and then we
839 // should reconsider the ordering here.
840 if (!DisableBasicAA) {
841 LLVM_DEBUG(dbgs() << "AAResults register BasicAA\n");
842 AAR->addAAResult(getAnalysis<BasicAAWrapperPass>().getResult());
843 }
844
845 // Populate the results with the currently available AAs.
846 if (auto *WrapperPass =
848 LLVM_DEBUG(dbgs() << "AAResults register ScopedNoAliasAA\n");
849 AAR->addAAResult(WrapperPass->getResult());
850 }
851 if (auto *WrapperPass = getAnalysisIfAvailable<TypeBasedAAWrapperPass>()) {
852 LLVM_DEBUG(dbgs() << "AAResults register TypeBasedAA\n");
853 AAR->addAAResult(WrapperPass->getResult());
854 }
855 if (auto *WrapperPass = getAnalysisIfAvailable<GlobalsAAWrapperPass>()) {
856 LLVM_DEBUG(dbgs() << "AAResults register GlobalsAA\n");
857 AAR->addAAResult(WrapperPass->getResult());
858 }
859 if (auto *WrapperPass = getAnalysisIfAvailable<SCEVAAWrapperPass>()) {
860 LLVM_DEBUG(dbgs() << "AAResults register SCEVAA\n");
861 AAR->addAAResult(WrapperPass->getResult());
862 }
863
864 // If available, run an external AA providing callback over the results as
865 // well.
866 if (ExtWrapperPass && !ExtWrapperPass->RunEarly && ExtWrapperPass->CB) {
867 LLVM_DEBUG(dbgs() << "AAResults register Late ExternalAA: "
868 << ExtWrapperPass->getPassName() << "\n");
869 ExtWrapperPass->CB(*this, F, *AAR);
870 }
871
872 // Analyses don't mutate the IR, so return false.
873 return false;
874}
875
877 AU.setPreservesAll();
880
881 // We also need to mark all the alias analysis passes we will potentially
882 // probe in runOnFunction as used here to ensure the legacy pass manager
883 // preserves them. This hard coding of lists of alias analyses is specific to
884 // the legacy pass manager.
890}
891
894 for (auto &Getter : ResultGetters)
895 (*Getter)(F, AM, R);
896 return R;
897}
898
900 if (const auto *Call = dyn_cast<CallBase>(V))
901 return Call->hasRetAttr(Attribute::NoAlias);
902 return false;
903}
904
905static bool isNoAliasOrByValArgument(const Value *V) {
906 if (const Argument *A = dyn_cast<Argument>(V))
907 return A->hasNoAliasAttr() || A->hasByValAttr();
908 return false;
909}
910
912 if (isa<AllocaInst>(V))
913 return true;
915 return true;
916 if (isNoAliasCall(V))
917 return true;
919 return true;
920 return false;
921}
922
926
928 // TODO: We can handle other cases here
929 // 1) For GC languages, arguments to functions are often required to be
930 // base pointers.
931 // 2) Result of allocation routines are often base pointers. Leverage TLI.
932 return (isa<AllocaInst>(V) || isa<GlobalVariable>(V));
933}
934
936 if (auto *CB = dyn_cast<CallBase>(V)) {
938 CB, /*MustPreserveOffset=*/true))
939 return false;
940
941 // The return value of a function with a captures(ret: address, provenance)
942 // attribute is not necessarily an escape source. The return value may
943 // alias with a non-escaping object.
944 return !CB->hasArgumentWithAdditionalReturnCaptureComponents();
945 }
946
947 // The load case works because isNotCapturedBefore considers all
948 // stores to be escapes (it passes true for the StoreCaptures argument
949 // to PointerMayBeCaptured).
950 if (isa<LoadInst>(V))
951 return true;
952
953 // The inttoptr case works because isNotCapturedBefore considers all
954 // means of converting or equating a pointer to an int (ptrtoint, ptr store
955 // which could be followed by an integer load, ptr<->int compare) as
956 // escaping, and objects located at well-known addresses via platform-specific
957 // means cannot be considered non-escaping local objects.
958 if (isa<IntToPtrInst>(V))
959 return true;
960
961 // Capture tracking considers insertions into aggregates and vectors as
962 // captures. As such, extractions from aggregates and vectors are escape
963 // sources.
965 return true;
966
967 // Same for inttoptr constant expressions.
968 if (auto *CE = dyn_cast<ConstantExpr>(V))
969 if (CE->getOpcode() == Instruction::IntToPtr)
970 return true;
971
972 return false;
973}
974
976 bool &RequiresNoCaptureBeforeUnwind) {
977 RequiresNoCaptureBeforeUnwind = false;
978
979 // Alloca goes out of scope on unwind.
980 if (isa<AllocaInst>(Object))
981 return true;
982
983 // Byval goes out of scope on unwind.
984 if (auto *A = dyn_cast<Argument>(Object))
985 return A->hasByValAttr() || A->hasAttribute(Attribute::DeadOnUnwind);
986
987 // A noalias return is not accessible from any other code. If the pointer
988 // does not escape prior to the unwind, then the caller cannot access the
989 // memory either.
990 if (isNoAliasCall(Object)) {
991 RequiresNoCaptureBeforeUnwind = true;
992 return true;
993 }
994
995 return false;
996}
997
998// We don't consider globals as writable: While the physical memory is writable,
999// we may not have provenance to perform the write.
1001 bool &ExplicitlyDereferenceableOnly) {
1002 ExplicitlyDereferenceableOnly = false;
1003
1004 // TODO: Alloca might not be writable after its lifetime ends.
1005 // See https://github.com/llvm/llvm-project/issues/51838.
1006 if (isa<AllocaInst>(Object))
1007 return true;
1008
1009 if (auto *A = dyn_cast<Argument>(Object)) {
1010 // Also require noalias, otherwise writability at function entry cannot be
1011 // generalized to writability at other program points, even if the pointer
1012 // does not escape.
1013 if (A->hasAttribute(Attribute::Writable) && A->hasNoAliasAttr()) {
1014 ExplicitlyDereferenceableOnly = true;
1015 return true;
1016 }
1017
1018 return A->hasByValAttr();
1019 }
1020
1021 // TODO: Noalias shouldn't imply writability, this should check for an
1022 // allocator function instead.
1023 return isNoAliasCall(Object);
1024}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
ModRefInfo getModRefInfoInaccessibleAndTargetMemLoc(const MemoryEffects CallUse, const MemoryEffects CallDef)
static cl::opt< bool > EnableAATrace("aa-trace", cl::Hidden, cl::init(false))
Print a trace of alias analysis queries and their results.
static bool isNoAliasOrByValArgument(const Value *V)
static cl::opt< bool > DisableBasicAA("disable-basic-aa", cl::Hidden, cl::init(false))
Allow disabling BasicAA from the AA results.
Atomic ordering constants.
This file contains the simple types necessary to represent the attributes associated with functions a...
This is the interface for LLVM's primary stateless and local alias analysis.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
This is the interface for a simple mod/ref and alias analysis over globals.
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
This file provides utility analysis objects describing memory locations.
#define INITIALIZE_PASS_DEPENDENCY(depName)
Definition PassSupport.h:42
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
Definition PassSupport.h:44
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
Definition PassSupport.h:39
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
Definition PassSupport.h:56
This is the interface for a SCEV-based alias analysis.
This is the interface for a metadata-based scoped no-alias analysis.
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
This is the interface for a metadata-based TBAA.
A manager for alias analyses.
LLVM_ABI Result run(Function &F, FunctionAnalysisManager &AM)
This class stores info we want to provide to or retain within an alias query.
unsigned Depth
Query depth used to distinguish recursive queries.
CaptureAnalysis * CA
A wrapper pass to provide the legacy pass manager access to a suitably prepared AAResults object.
bool runOnFunction(Function &F) override
Run the wrapper pass to rebuild an aggregation over known AA passes.
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
ModRefInfo getModRefInfo(const Instruction *I, const std::optional< MemoryLocation > &OptLoc)
Check whether or not an instruction may read or write the optionally specified memory location.
LLVM_ABI AliasResult alias(const MemoryLocation &LocA, const MemoryLocation &LocB)
The main low level interface to the alias analysis implementation.
LLVM_ABI ModRefInfo getModRefInfoMask(const MemoryLocation &Loc, bool IgnoreLocals=false)
Returns a bitmask that should be unconditionally applied to the ModRef info of a memory location.
ModRefInfo callCapturesBefore(const Instruction *I, const MemoryLocation &MemLoc, DominatorTree *DT)
Return information about whether a particular call site modifies or reads the specified memory locati...
LLVM_ABI AAResults(const TargetLibraryInfo &TLI)
LLVM_ABI MemoryEffects getMemoryEffects(const CallBase *Call)
Return the behavior of the given call site.
LLVM_ABI bool invalidate(Function &F, const PreservedAnalyses &PA, FunctionAnalysisManager::Invalidator &Inv)
Handle invalidation events in the new pass manager.
LLVM_ABI ModRefInfo getArgModRefInfo(const CallBase *Call, unsigned ArgIdx)
Get the ModRef info associated with a pointer argument of a call.
LLVM_ABI bool canInstructionRangeModRef(const Instruction &I1, const Instruction &I2, const MemoryLocation &Loc, const ModRefInfo Mode)
Check if it is possible for the execution of the specified instructions to mod(according to the mode)...
LLVM_ABI AliasResult aliasErrno(const MemoryLocation &Loc, const Module *M)
LLVM_ABI ~AAResults()
LLVM_ABI bool canBasicBlockModify(const BasicBlock &BB, const MemoryLocation &Loc)
Check if it is possible for execution of the specified basic block to modify the location Loc.
The possible results of an alias query.
@ MayAlias
The two locations may or may not alias.
@ NoAlias
The two locations do not alias at all.
@ PartialAlias
The two locations alias, but only due to a partial overlap.
@ MustAlias
The two locations precisely alias each other.
constexpr int32_t getOffset() const
constexpr bool hasOffset() const
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent the analysis usage information of a pass.
AnalysisUsage & addUsedIfAvailable()
Add the specified Pass class to the set of analyses used by this pass.
void setPreservesAll()
Set by analyses that do not transform their input at all.
AnalysisUsage & addRequiredTransitive()
This class represents an incoming formal argument to a Function.
Definition Argument.h:32
An instruction that atomically checks whether a specified value is in a memory location,...
AtomicOrdering getSuccessOrdering() const
Returns the success ordering constraint of this cmpxchg instruction.
an instruction that atomically reads a memory location, combines it with another value,...
AtomicOrdering getOrdering() const
Returns the ordering constraint of this rmw instruction.
Legacy wrapper pass to provide the BasicAAResult object.
LLVM Basic Block Representation.
Definition BasicBlock.h:62
const Instruction & back() const
Definition BasicBlock.h:486
InstListType::const_iterator const_iterator
Definition BasicBlock.h:171
const Instruction & front() const
Definition BasicBlock.h:484
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
User::op_iterator arg_begin()
Return the iterator pointing to the beginning of the argument list.
User::op_iterator arg_end()
Return the iterator pointing to the end of the argument list.
Represents which components of the pointer may be captured in which location.
Definition ModRef.h:414
CaptureComponents getOtherComponents() const
Get components potentially captured through locations other than the return value.
Definition ModRef.h:446
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Definition Dominators.h:159
An instruction for ordering other memory operations.
FunctionPass(char &pid)
Definition Pass.h:316
Legacy wrapper pass to provide the GlobalsAAResult object.
ImmutablePass class - This class is used to provide information that does not need to be run.
Definition Pass.h:285
ImmutablePass(char &pid)
Definition Pass.h:287
bool mayReadOrWriteMemory() const
Return true if this instruction may read or write memory.
An instruction for reading from memory.
ModRefInfo getModRef(Location Loc) const
Get ModRefInfo for the given Location.
Definition ModRef.h:219
static MemoryEffectsBase unknown()
Definition ModRef.h:123
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.
LocationSize Size
The maximum size of the location, in address-units, or UnknownSize if the size is not known.
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...
const Value * Ptr
The address of the start of the location.
static LLVM_ABI std::optional< MemoryLocation > getOrNone(const Instruction *Inst)
static LLVM_ABI MemoryLocation getForArgument(const CallBase *Call, unsigned ArgIdx, const TargetLibraryInfo *TLI)
Return a location representing a particular argument of a call.
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
AnalysisType & getAnalysis() const
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information ...
AnalysisType * getAnalysisIfAvailable() const
getAnalysisIfAvailable<AnalysisType>() - Subclasses use this function to get analysis information tha...
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
PreservedAnalysisChecker getChecker() const
Build a checker for this PreservedAnalyses and the specified analysis type.
Definition Analysis.h:275
Legacy wrapper pass to provide the SCEVAAResult object.
Legacy wrapper pass to provide the ScopedNoAliasAAResult object.
AAQueryInfo that uses SimpleCaptureAnalysis.
An instruction for storing to memory.
AtomicOrdering getOrdering() const
Returns the ordering constraint of this store instruction.
Analysis pass providing the TargetLibraryInfo.
Provides information about what library functions are available for the current target.
Legacy wrapper pass to provide the TypeBasedAAResult object.
bool isPointerTy() const
True if this is an instance of PointerType.
Definition Type.h:284
This class represents the va_arg llvm instruction, which returns an argument of the specified type gi...
LLVM Value Representation.
Definition Value.h:75
Type * getType() const
All values are typed, get the type of this value.
Definition Value.h:255
const ParentTy * getParent() const
Definition ilist_node.h:34
self_iterator getIterator()
Definition ilist_node.h:123
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
CallInst * Call
Abstract Attribute helper functions.
Definition Attributor.h:165
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
bool capturesReadProvenanceOnly(CaptureComponents CC)
Definition ModRef.h:391
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
bool isStrongerThanMonotonic(AtomicOrdering AO)
LLVM_ABI bool isBaseOfObject(const Value *V)
Return true if we know V to the base address of the corresponding memory object.
bool isStrongerThanUnordered(AtomicOrdering AO)
LLVM_ABI bool isIntrinsicReturningPointerAliasingArgumentWithoutCapturing(const CallBase *Call, bool MustPreserveOffset)
{launder,strip}.invariant.group returns pointer that aliases its argument, and it only captures point...
LLVM_ABI bool isNoAliasCall(const Value *V)
Return true if this pointer is returned by a noalias function.
MemoryEffectsBase< IRMemLocation > MemoryEffects
Summary of how a function affects memory in the program.
Definition ModRef.h:356
LLVM_ABI bool PointerMayBeCapturedBefore(const Value *V, bool ReturnCaptures, const Instruction *I, const DominatorTree *DT, bool IncludeI=false, unsigned MaxUsesToExplore=0, const LoopInfo *LI=nullptr)
PointerMayBeCapturedBefore - Return true if this pointer value may be captured by the enclosing funct...
LLVM_ABI ModRefInfo getSyncEffects(AAResults *AA, const MemoryLocation &Loc, AAQueryInfo &AAQI)
Get ModRefInfo for a synchronizing operation, such as a fence or stronger than monotonic atomic load/...
bool isModSet(const ModRefInfo MRI)
Definition ModRef.h:49
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 bool isNotVisibleOnUnwind(const Value *Object, bool &RequiresNoCaptureBeforeUnwind)
Return true if Object memory is not visible after an unwind, in the sense that program semantics cann...
CaptureComponents
Components of the pointer that may be captured.
Definition ModRef.h:365
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
ModRefInfo
Flags indicating whether a memory access modifies or references memory.
Definition ModRef.h:28
@ Ref
The access may reference the value stored in memory.
Definition ModRef.h:32
@ ModRef
The access may reference and may modify the value stored in memory.
Definition ModRef.h:36
@ Mod
The access may modify the value stored in memory.
Definition ModRef.h:34
@ NoModRef
The access neither references nor modifies the value stored in memory.
Definition ModRef.h:30
IRMemLocation
The locations at which a function might access memory.
Definition ModRef.h:60
@ InaccessibleMem
Memory that is inaccessible via LLVM IR.
Definition ModRef.h:64
raw_ostream & operator<<(raw_ostream &OS, const APFixedPoint &FX)
LLVM_ABI bool isIdentifiedFunctionLocal(const Value *V)
Return true if V is umabigously identified at the function-level.
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1916
LLVM_ABI bool isEscapeSource(const Value *V)
Returns true if the pointer is one which would have been considered an escape by isNotCapturedBefore.
bool capturesAnything(CaptureComponents CC)
Definition ModRef.h:379
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
bool capturesNothing(CaptureComponents CC)
Definition ModRef.h:375
bool isNoModRef(const ModRefInfo MRI)
Definition ModRef.h:40
LLVM_ABI bool isIdentifiedObject(const Value *V)
Return true if this pointer refers to a distinct and identifiable object.
bool capturesAnyProvenance(CaptureComponents CC)
Definition ModRef.h:400
bool isRefSet(const ModRefInfo MRI)
Definition ModRef.h:52
LLVM_ABI bool isWritableObject(const Value *Object, bool &ExplicitlyDereferenceableOnly)
Return true if the Object is writable, in the sense that any location based on this pointer that can ...
LLVM_ABI ImmutablePass * createExternalAAWrapperPass(std::function< void(Pass &, Function &, AAResults &)> Callback)
A wrapper pass around a callback which can be used to populate the AAResults in the AAResultsWrapperP...
Implement std::hash so that hash_code can be used in STL containers.
Definition BitVector.h:874
A special type used by analysis passes to provide an address that identifies that particular analysis...
Definition Analysis.h:29
virtual CaptureComponents getCapturesBefore(const Value *Object, const Instruction *I, bool OrAt, bool ReturnCaptures)=0
Return how Object may be captured before instruction I, considering only provenance captures.
A wrapper pass for external alias analyses.
std::function< void(Pass &, Function &, AAResults &)> CallbackT
static LLVM_ABI char ID
bool RunEarly
Flag indicating whether this external AA should run before Basic AA.