summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/LoopVectorize/lcssa-crash.ll
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2017-01-26 10:41:09 +0000
committerChandler Carruth <chandlerc@gmail.com>2017-01-26 10:41:09 +0000
commit6f4ed077d09ccdb80e4527a7aec8cdca67294205 (patch)
tree0f54e541d5421f27bf2593b633abb87669e9c6f8 /llvm/test/Transforms/LoopVectorize/lcssa-crash.ll
parente2463504672e48537cb2dc861f96496115d316ab (diff)
downloadbcm5719-llvm-6f4ed077d09ccdb80e4527a7aec8cdca67294205.tar.gz
bcm5719-llvm-6f4ed077d09ccdb80e4527a7aec8cdca67294205.zip
[LV] Fix an issue where forming LCSSA in the place that we did would
change the set of uniform instructions in the loop causing an assert failure. The problem is that the legalization checking also builds data structures mapping various facts about the loop body. The immediate cause was the set of uniform instructions. If these then change when LCSSA is formed, the data structures would already have been built and become stale. The included test case triggered an assert in loop vectorize that was reduced out of the new PM's pipeline. The solution is to form LCSSA early enough that no information is cached across the changes made. The only really obvious position is outside of the main logic to vectorize the loop. This also has the advantage of removing one case where forming LCSSA could mutate the loop but we wouldn't track that as a "Changed" state. If it is significantly advantageous to do some legalization checking prior to this, we can do a more careful positioning but it seemed best to just back off to a safe position first. llvm-svn: 293168
Diffstat (limited to 'llvm/test/Transforms/LoopVectorize/lcssa-crash.ll')
-rw-r--r--llvm/test/Transforms/LoopVectorize/lcssa-crash.ll23
1 files changed, 23 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopVectorize/lcssa-crash.ll b/llvm/test/Transforms/LoopVectorize/lcssa-crash.ll
index e6bd6ed61e2..3d3ef9e0593 100644
--- a/llvm/test/Transforms/LoopVectorize/lcssa-crash.ll
+++ b/llvm/test/Transforms/LoopVectorize/lcssa-crash.ll
@@ -37,3 +37,26 @@ L0:
L1:
ret void
}
+
+; This loop has different uniform instructions before and after LCSSA.
+define void @test3() {
+entry:
+ %add41 = add i32 undef, undef
+ %idxprom4736 = zext i32 %add41 to i64
+ br label %while.body
+
+while.body:
+ %idxprom4738 = phi i64 [ %idxprom47, %while.body ], [ %idxprom4736, %entry ]
+ %pos.337 = phi i32 [ %inc46, %while.body ], [ %add41, %entry ]
+ %inc46 = add i32 %pos.337, 1
+ %arrayidx48 = getelementptr inbounds [1024 x i8], [1024 x i8]* undef, i64 0, i64 %idxprom4738
+ store i8 0, i8* %arrayidx48, align 1
+ %and43 = and i32 %inc46, 3
+ %cmp44 = icmp eq i32 %and43, 0
+ %idxprom47 = zext i32 %inc46 to i64
+ br i1 %cmp44, label %while.end, label %while.body
+
+while.end:
+ %add58 = add i32 %inc46, 4
+ ret void
+}
OpenPOWER on IntegriCloud