mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Be conservative about allocations that may alias the accessed pointer.
If an allocation has a must-alias relation to the access pointer, we treat it as a Def. Otherwise, without this check, the code here was just skipping over the allocation call and ignoring it. I noticed this by inspection and don't have a specific testcase that it breaks, but it seems like we need to treat a may-alias allocation as a Clobber. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@163127 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2dc88d94c3
commit
2d5c28da0d
@ -485,6 +485,9 @@ getPointerDependencyFrom(const AliasAnalysis::Location &MemLoc, bool isLoad,
|
|||||||
|
|
||||||
if (AccessPtr == Inst || AA->isMustAlias(Inst, AccessPtr))
|
if (AccessPtr == Inst || AA->isMustAlias(Inst, AccessPtr))
|
||||||
return MemDepResult::getDef(Inst);
|
return MemDepResult::getDef(Inst);
|
||||||
|
// Be conservative if the accessed pointer may alias the allocation.
|
||||||
|
if (AA->alias(Inst, AccessPtr) != AliasAnalysis::NoAlias)
|
||||||
|
return MemDepResult::getClobber(Inst);
|
||||||
// If the allocation is not aliased and does not read memory (like
|
// If the allocation is not aliased and does not read memory (like
|
||||||
// strdup), it is safe to ignore.
|
// strdup), it is safe to ignore.
|
||||||
if (isa<AllocaInst>(Inst) ||
|
if (isa<AllocaInst>(Inst) ||
|
||||||
|
Loading…
Reference in New Issue
Block a user