Reapply r131781, now that the GVN bug with partially-aliasing loads

is disabled.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132632 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Dan Gohman
2011-06-04 06:50:18 +00:00
parent a3351a0e5d
commit 5f1312c36e
3 changed files with 143 additions and 2 deletions

View File

@ -944,7 +944,17 @@ BasicAliasAnalysis::aliasGEP(const GEPOperator *GEP1, uint64_t V1Size,
return NoAlias;
}
return MayAlias;
// Statically, we can see that the base objects are the same, but the
// pointers have dynamic offsets which we can't resolve. And none of our
// little tricks above worked.
//
// TODO: Returning PartialAlias instead of MayAlias is a mild hack; the
// practical effect of this is protecting TBAA in the case of dynamic
// indices into arrays of unions. An alternative way to solve this would
// be to have clang emit extra metadata for unions and/or union accesses.
// A union-specific solution wouldn't handle the problem for malloc'd
// memory however.
return PartialAlias;
}
static AliasAnalysis::AliasResult