/freebsd/contrib/llvm-project/llvm/include/llvm/Analysis/ |
H A D | MemorySSA.h | 210 friend class MemoryDef; 373 class MemoryDef final : public MemoryUseOrDef { 379 MemoryDef(LLVMContext &C, MemoryAccess *DMA, Instruction *MI, BasicBlock *BB, 423 struct OperandTraits<MemoryDef> : public FixedNumOperandTraits<MemoryDef, 2> {}; 424 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(MemoryDef, MemoryAccess) 431 return OperandTraits<MemoryDef>::op_begin(cast<MemoryDef>(MUD)); 437 return OperandTraits<MemoryDef>::op_end(cast<MemoryDef>(MUD)); 443 return OperandTraits<MemoryDef>::operands(cast<MemoryDef>(MUD)); 663 assert((isa<MemoryDef>(this) || isa<MemoryPhi>(this)) && 665 if (const auto *MD = dyn_cast<MemoryDef>(this)) [all …]
|
H A D | MemorySSAUpdater.h | 85 void insertDef(MemoryDef *Def, bool RenameUses = false);
|
/freebsd/contrib/llvm-project/llvm/lib/Transforms/Scalar/ |
H A D | DeadStoreElimination.cpp | 781 bool canSkipDef(MemoryDef *D, bool DefVisibleToCaller) { in canSkipDef() 835 SmallVector<MemoryDef *, 64> MemDefs; 884 auto *MD = dyn_cast_or_null<MemoryDef>(MA); in DSEState() 1170 bool isWriteAtEndOfFunction(MemoryDef *Def, const MemoryLocation &DefLoc) { in isWriteAtEndOfFunction() 1203 if (MemoryDef *UseDef = dyn_cast<MemoryDef>(UseAccess)) in isWriteAtEndOfFunction() 1328 getDomMemoryDef(MemoryDef *KillingDef, MemoryAccess *StartAccess, in getDomMemoryDef() 1352 for (;; Current = cast<MemoryDef>(Current)->getDefiningAccess()) { in getDomMemoryDef() 1390 MemoryDef *CurrentDef = cast<MemoryDef>(Current); in getDomMemoryDef() 1502 Instruction *MaybeDeadI = cast<MemoryDef>(MaybeDeadAccess)->getMemoryInst(); in getDomMemoryDef() 1600 if (MemoryDef *UseDef = dyn_cast<MemoryDef>(UseAccess)) { in getDomMemoryDef() [all …]
|
H A D | MemCpyOptimizer.cpp | 490 auto *NewDef = cast<MemoryDef>( in tryMergingIntoMemset() 701 cast<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(SI)); in processStoreOfLoad() 703 MSSAU->insertDef(cast<MemoryDef>(NewAccess), /*RenameUses=*/true); in processStoreOfLoad() 822 auto *StoreDef = cast<MemoryDef>(MSSA->getMemoryAccess(SI)); in processStore() 824 MSSAU->insertDef(cast<MemoryDef>(NewAccess), /*RenameUses=*/false); in processStore() 1262 assert(isa<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(M))); in processMemCpyMemCpyDependence() 1263 auto *LastDef = cast<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(M)); in processMemCpyMemCpyDependence() 1265 MSSAU->insertDef(cast<MemoryDef>(NewAccess), /*RenameUses=*/true); in processMemCpyMemCpyDependence() 1373 assert(isa<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(MemCpy)) && in processMemSetMemCpyDependence() 1378 cast<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(MemCpy)); in processMemSetMemCpyDependence() [all …]
|
H A D | GVNHoist.cpp | 293 bool hasMemoryUse(const Instruction *NewPt, MemoryDef *Def, 306 bool hasEHOrLoadsOnPath(const Instruction *NewPt, MemoryDef *Def, 586 bool GVNHoist::hasMemoryUse(const Instruction *NewPt, MemoryDef *Def, in hasMemoryUse() 639 bool GVNHoist::hasEHOrLoadsOnPath(const Instruction *NewPt, MemoryDef *Def, in hasEHOrLoadsOnPath() 732 if (hasEHOrLoadsOnPath(NewPt, cast<MemoryDef>(U), NBBsOnAllPaths)) in safeToHoistLdSt()
|
H A D | LoopSink.cpp | 246 if (auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc)) in sinkInstruction()
|
H A D | NewGVN.cpp | 1539 if (auto *MD = dyn_cast<MemoryDef>(DefiningAccess)) { in performSymbolicLoadEvaluation() 2286 auto *InstMA = dyn_cast_or_null<MemoryDef>(getMemoryAccess(I)); in moveValueToNewCongruenceClass() 2900 auto *MD = dyn_cast<MemoryDef>(&Def); in initializeCongruenceClasses() 3218 if (auto *MemDef = dyn_cast<MemoryDef>(Pair.first)) in verifyMemoryCongruency() 3255 isa<MemoryDef>(U); in verifyMemoryCongruency() 3264 const MemoryDef *MD = cast<MemoryDef>(U); in verifyMemoryCongruency()
|
H A D | LICM.cpp | 1313 } else if (const auto *MD = dyn_cast<MemoryDef>(&MA)) { in canSinkOrHoistInst() 1473 if (auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc)) in cloneInstructionInExitBlock() 1906 MSSAU.insertDef(cast<MemoryDef>(NewMemAcc), true); in insertStoresInLoopExitBlocks() 2403 if (const auto *MD = dyn_cast<MemoryDef>(&MA)) in pointerInvalidatedByBlock()
|
H A D | SimpleLoopUnswitch.cpp | 320 DefiningAccess = cast<MemoryDef>(DefiningAccess)->getDefiningAccess(); in buildPartialInvariantUnswitchConditionalBranch() 2794 MemoryDef *MD = cast<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(GI)); in turnGuardIntoBranch()
|
H A D | LoopIdiomRecognize.cpp | 1132 MSSAU->insertDef(cast<MemoryDef>(NewMemAcc), true); in processLoopStridedStore() 1431 MSSAU->insertDef(cast<MemoryDef>(NewMemAcc), true); in processLoopStoreOfLoopLoad()
|
H A D | GVN.cpp | 1488 if (auto *NewDef = dyn_cast<MemoryDef>(NewAccess)) in eliminatePartiallyRedundantLoad() 2092 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() 573 if (MemoryDef *DefMUD = dyn_cast<MemoryDef>(InsnDefining)) { in getNewDefiningAccessForClone() 1155 if (auto *MD = dyn_cast<MemoryDef>(What)) in moveTo()
|
/freebsd/contrib/llvm-project/llvm/lib/Target/AMDGPU/Utils/ |
H A D | AMDGPUMemoryUtils.h | 23 class MemoryDef; variable 63 bool isReallyAClobber(const Value *Ptr, MemoryDef *Def, AAResults *AA);
|
H A D | AMDGPUMemoryUtils.cpp | 284 bool isReallyAClobber(const Value *Ptr, MemoryDef *Def, AAResults *AA) { in isReallyAClobber() 350 if (MemoryDef *Def = dyn_cast<MemoryDef>(MA)) { in isClobberedInFunction()
|
/freebsd/contrib/llvm-project/llvm/include/llvm/IR/ |
H A D | Value.def | 121 HANDLE_MEMORY_VALUE(MemoryDef)
|
/freebsd/contrib/llvm-project/llvm/lib/Transforms/Utils/ |
H A D | LoopUtils.cpp | 2111 if (auto *CurrentDef = dyn_cast<MemoryDef>(Current)) { in hasPartialIVCondition()
|