forked from OSchip/llvm-project
Do not verify the base addresses
Verification of base addresses is difficult as the independent blocks pass may introduce aliasing that was not there during scop detection. As a midterm solution -polly-codegen-scev will remove the need for the independent blocks pass. For now, we do not verify at compile time that the independent blocks pass does not make the base addresses loop invariant. Disabling this just removes one of the multiple safety layers we have. We still can check for correctness in our regression tests. llvm-svn: 200315
This commit is contained in:
parent
458fb78cfa
commit
ab2227a505
|
@ -420,8 +420,11 @@ bool ScopDetection::isValidMemoryAccess(Instruction &Inst,
|
||||||
// Check that the base address of the access is invariant in the current
|
// Check that the base address of the access is invariant in the current
|
||||||
// region.
|
// region.
|
||||||
if (!isInvariant(*BaseValue, Context.CurRegion)) {
|
if (!isInvariant(*BaseValue, Context.CurRegion)) {
|
||||||
INVALID(AffFunc,
|
// Verification of this property is difficult as the independent blocks
|
||||||
"Base address not invariant in current region:" << *BaseValue);
|
// pass may introduce aliasing that we did not have when running the
|
||||||
|
// scop detection.
|
||||||
|
INVALID_NOVERIFY(
|
||||||
|
AffFunc, "Base address not invariant in current region:" << *BaseValue);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue