Home
last modified time | relevance | path

Searched refs:MemoryDef (Results 1 – 17 of 17) sorted by relevance

/freebsd/contrib/llvm-project/llvm/include/llvm/Analysis/
H A DMemorySSA.h210 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 DMemorySSAUpdater.h85 void insertDef(MemoryDef *Def, bool RenameUses = false);
/freebsd/contrib/llvm-project/llvm/lib/Transforms/Scalar/
H A DDeadStoreElimination.cpp781 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 DMemCpyOptimizer.cpp490 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 DGVNHoist.cpp293 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 DLoopSink.cpp246 if (auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc)) in sinkInstruction()
H A DNewGVN.cpp1539 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 DLICM.cpp1313 } 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 DSimpleLoopUnswitch.cpp320 DefiningAccess = cast<MemoryDef>(DefiningAccess)->getDefiningAccess(); in buildPartialInvariantUnswitchConditionalBranch()
2794 MemoryDef *MD = cast<MemoryDef>(MSSAU->getMemorySSA()->getMemoryAccess(GI)); in turnGuardIntoBranch()
H A DLoopIdiomRecognize.cpp1132 MSSAU->insertDef(cast<MemoryDef>(NewMemAcc), true); in processLoopStridedStore()
1431 MSSAU->insertDef(cast<MemoryDef>(NewMemAcc), true); in processLoopStoreOfLoopLoad()
H A DGVN.cpp1488 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 DMemorySSA.cpp282 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 DMemorySSAUpdater.cpp271 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 DAMDGPUMemoryUtils.h23 class MemoryDef; variable
63 bool isReallyAClobber(const Value *Ptr, MemoryDef *Def, AAResults *AA);
H A DAMDGPUMemoryUtils.cpp284 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 DValue.def121 HANDLE_MEMORY_VALUE(MemoryDef)
/freebsd/contrib/llvm-project/llvm/lib/Transforms/Utils/
H A DLoopUtils.cpp2111 if (auto *CurrentDef = dyn_cast<MemoryDef>(Current)) { in hasPartialIVCondition()