| /freebsd/contrib/llvm-project/llvm/include/llvm/Analysis/ |
| H A D | MemorySSA.h | 207 friend class MemoryDef; 371 class MemoryDef final : public MemoryUseOrDef { 379 MemoryDef(LLVMContext &C, MemoryAccess *DMA, Instruction *MI, BasicBlock *BB, 422 struct OperandTraits<MemoryDef> : public FixedNumOperandTraits<MemoryDef, 2> {}; 423 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(MemoryDef, MemoryAccess) 430 return OperandTraits<MemoryDef>::op_begin(cast<MemoryDef>(MUD)); 436 return OperandTraits<MemoryDef>::op_end(cast<MemoryDef>(MUD)); 442 return OperandTraits<MemoryDef>::operands(cast<MemoryDef>(MUD)); 664 assert((isa<MemoryDef>(this) || isa<MemoryPhi>(this)) && 666 if (const auto *MD = dyn_cast<MemoryDef>(this)) [all …]
|
| H A D | MemorySSAUpdater.h | 86 LLVM_ABI void insertDef(MemoryDef *Def, bool RenameUses = false);
|
| /freebsd/contrib/llvm-project/llvm/lib/Transforms/Scalar/ |
| H A D | DeadStoreElimination.cpp | 840 bool canSkipDef(MemoryDef *D, bool DefVisibleToCaller) { in canSkipDef() 871 MemoryLocationWrapper(MemoryLocation MemLoc, MemoryDef *MemDef, in MemoryLocationWrapper() 882 MemoryDef *MemDef; 890 MemoryDefWrapper(MemoryDef *MemDef, in MemoryDefWrapper() 963 SmallVector<MemoryDef *, 64> MemDefs; 1012 auto *MD = dyn_cast_or_null<MemoryDef>(MA); in DSEState() 1319 bool isWriteAtEndOfFunction(MemoryDef *Def, const MemoryLocation &DefLoc) { in isWriteAtEndOfFunction() 1352 if (MemoryDef *UseDef = dyn_cast<MemoryDef>(UseAccess)) in isWriteAtEndOfFunction() 1477 getDomMemoryDef(MemoryDef *KillingDef, MemoryAccess *StartAccess, in getDomMemoryDef() 1502 for (;; Current = cast<MemoryDef>(Current)->getDefiningAccess()) { in getDomMemoryDef() [all …]
|
| H A D | MemCpyOptimizer.cpp | 483 auto *NewDef = cast<MemoryDef>( in tryMergingIntoMemset() 687 auto *LastDef = cast<MemoryDef>(MSSA->getMemoryAccess(SI)); in processStoreOfLoad() 689 MSSAU->insertDef(cast<MemoryDef>(NewAccess), /*RenameUses=*/true); in processStoreOfLoad() 815 auto *StoreDef = cast<MemoryDef>(MSSA->getMemoryAccess(SI)); in processStore() 817 MSSAU->insertDef(cast<MemoryDef>(NewAccess), /*RenameUses=*/false); in processStore() 1263 assert(isa<MemoryDef>(MSSA->getMemoryAccess(M))); in processMemCpyMemCpyDependence() 1264 auto *LastDef = cast<MemoryDef>(MSSA->getMemoryAccess(M)); in processMemCpyMemCpyDependence() 1266 MSSAU->insertDef(cast<MemoryDef>(NewAccess), /*RenameUses=*/true); in processMemCpyMemCpyDependence() 1374 assert(isa<MemoryDef>(MSSA->getMemoryAccess(MemCpy)) && in processMemSetMemCpyDependence() 1378 auto *LastDef = cast<MemoryDef>(MSSA->getMemoryAccess(MemCpy)); in processMemSetMemCpyDependence() [all …]
|
| H A D | GVNHoist.cpp | 292 bool hasMemoryUse(const Instruction *NewPt, MemoryDef *Def, 305 bool hasEHOrLoadsOnPath(const Instruction *NewPt, MemoryDef *Def, 584 bool GVNHoist::hasMemoryUse(const Instruction *NewPt, MemoryDef *Def, in hasMemoryUse() 637 bool GVNHoist::hasEHOrLoadsOnPath(const Instruction *NewPt, MemoryDef *Def, in hasEHOrLoadsOnPath() 730 if (hasEHOrLoadsOnPath(NewPt, cast<MemoryDef>(U), NBBsOnAllPaths)) in safeToHoistLdSt()
|
| H A D | LoopSink.cpp | 262 if (auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc)) in sinkInstruction()
|
| H A D | NewGVN.cpp | 1580 if (auto *MD = dyn_cast<MemoryDef>(DefiningAccess)) { in performSymbolicLoadEvaluation() 2324 auto *InstMA = dyn_cast_or_null<MemoryDef>(getMemoryAccess(I)); in moveValueToNewCongruenceClass() 2938 auto *MD = dyn_cast<MemoryDef>(&Def); in initializeCongruenceClasses() 3250 if (auto *MemDef = dyn_cast<MemoryDef>(Pair.first)) in verifyMemoryCongruency() 3287 isa<MemoryDef>(U); in verifyMemoryCongruency() 3295 const MemoryDef *MD = cast<MemoryDef>(U); in verifyMemoryCongruency()
|
| H A D | LICM.cpp | 1405 if (auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc)) in cloneInstructionInExitBlock() 1835 MSSAU.insertDef(cast<MemoryDef>(NewMemAcc), true); in insertStoresInLoopExitBlocks() 2329 } else if (const auto *MD = dyn_cast<MemoryDef>(&MA)) { in noConflictingReadWrites() 2414 if (const auto *MD = dyn_cast<MemoryDef>(&MA)) in pointerInvalidatedByBlock()
|
| H A D | SimpleLoopUnswitch.cpp | 325 DefiningAccess = cast<MemoryDef>(DefiningAccess)->getDefiningAccess(); in buildPartialInvariantUnswitchConditionalBranch() 2799 MemoryDef *MD = cast<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(GI)); in turnGuardIntoBranch()
|
| H A D | LoopIdiomRecognize.cpp | 1161 MSSAU->insertDef(cast<MemoryDef>(NewMemAcc), true); in processLoopStridedStore() 1464 MSSAU->insertDef(cast<MemoryDef>(NewMemAcc), true); in processLoopStoreOfLoopLoad()
|
| H A D | GVN.cpp | 1583 if (auto *NewDef = dyn_cast<MemoryDef>(NewAccess)) in eliminatePartiallyRedundantLoad() 2133 MSSAU->insertDef(cast<MemoryDef>(NewDef), /*RenameUses=*/false); in processAssumeIntrinsic()
|
| /freebsd/contrib/llvm-project/llvm/lib/Analysis/ |
| H A D | MemorySSA.cpp | 282 instructionClobbersQuery(const MemoryDef *MD, const MemoryLocation &UseLoc, in instructionClobbersQuery() 327 static bool instructionClobbersQuery(MemoryDef *MD, const MemoryUseOrDef *MU, in instructionClobbersQuery() 340 bool MemorySSAUtil::defClobbersUseOrDef(MemoryDef *MD, const MemoryUseOrDef *MU, in defClobbersUseOrDef() 424 if (const auto *MD = dyn_cast<MemoryDef>(MA)) { in checkClobberSanity() 442 if (const auto *MD = dyn_cast<MemoryDef>(MA)) { in checkClobberSanity() 574 if (auto *MD = dyn_cast<MemoryDef>(Current)) { in walkToPhiOrClobber() 657 assert(isa<MemoryDef>(Query->OriginalAccess)); in getBlockingAccess() 1132 if (isa<MemoryDef>(&L)) in renameBlock() 1468 MemoryDef *MD = cast<MemoryDef>(VersionStack[UpperBound]); in optimizeUsesInBlock() 1527 LiveOnEntryDef.reset(new MemoryDef(StartingPoint.getContext(), nullptr, in buildMemorySSA() [all …]
|
| H A D | MemorySSAUpdater.cpp | 271 if (auto *MD = dyn_cast<MemoryDef>(FirstDef)) in insertUse() 307 void MemorySSAUpdater::insertDef(MemoryDef *MD, bool RenameUses) { in insertDef() 441 if (auto *MD = dyn_cast<MemoryDef>(FirstDef)) in insertDef() 479 cast<MemoryDef>(DefIter)->setDefiningAccess(NewDef); in fixupDefs() 510 cast<MemoryDef>(FirstDef)->setDefiningAccess(getPreviousDef(FirstDef)); in fixupDefs() 572 if (MemoryDef *DefMUD = dyn_cast<MemoryDef>(InsnDefining)) { in getNewDefiningAccessForClone() 1170 if (auto *MD = dyn_cast<MemoryDef>(What)) in moveTo()
|
| /freebsd/contrib/llvm-project/llvm/lib/Target/AMDGPU/ |
| H A D | AMDGPUMemoryUtils.h | 23 class MemoryDef; variable 68 bool isReallyAClobber(const Value *Ptr, MemoryDef *Def, AAResults *AA);
|
| H A D | AMDGPUMemoryUtils.cpp | 343 bool isReallyAClobber(const Value *Ptr, MemoryDef *Def, AAResults *AA) { in isReallyAClobber() 405 if (MemoryDef *Def = dyn_cast<MemoryDef>(MA)) { in isClobberedInFunction()
|
| /freebsd/contrib/llvm-project/llvm/include/llvm/IR/ |
| H A D | Value.def | 123 HANDLE_MEMORY_VALUE(MemoryDef)
|
| /freebsd/contrib/llvm-project/llvm/lib/Transforms/Utils/ |
| H A D | LoopUtils.cpp | 2176 if (auto *CurrentDef = dyn_cast<MemoryDef>(Current)) { in hasPartialIVCondition()
|