summaryrefslogtreecommitdiffstats
path: root/polly/test/Isl/CodeGen/non-affine-region-exit-phi-incoming-synthesize.ll
diff options
context:
space:
mode:
Diffstat (limited to 'polly/test/Isl/CodeGen/non-affine-region-exit-phi-incoming-synthesize.ll')
-rw-r--r--polly/test/Isl/CodeGen/non-affine-region-exit-phi-incoming-synthesize.ll35
1 files changed, 35 insertions, 0 deletions
diff --git a/polly/test/Isl/CodeGen/non-affine-region-exit-phi-incoming-synthesize.ll b/polly/test/Isl/CodeGen/non-affine-region-exit-phi-incoming-synthesize.ll
new file mode 100644
index 00000000000..f7f7d3c1e35
--- /dev/null
+++ b/polly/test/Isl/CodeGen/non-affine-region-exit-phi-incoming-synthesize.ll
@@ -0,0 +1,35 @@
+; RUN: opt %loadPolly -polly-codegen -S < %s | FileCheck %s
+;
+; This caused the code generation to generate invalid code as the same BBMap was
+; used for the whole non-affine region. When %add is synthesized for the
+; incoming value of subregion_if first, the code for it was generated into
+; subregion_if, but reused for the incoming value of subregion_exit, although it
+; is not dominated by subregion_if.
+;
+; CHECK-LABEL: polly.stmt.subregion_entry:
+; CHECK: %[[R0:[0-9]*]] = add i32 %n, -2
+; CHECK: store i32 %[[R0]], i32* %retval.s2a
+;
+; CHECK-LABEL: polly.stmt.subregion_if:
+; CHECK: %[[R1:[0-9]*]] = add i32 %n, -2
+; CHECK: store i32 %[[R1]], i32* %retval.s2a
+;
+; CHECK-LABEL: polly.stmt.polly.merge_new_and_old.exit:
+; CHECK: load i32, i32* %retval.s2a
+
+define i32 @func(i32 %n){
+entry:
+ br label %subregion_entry
+
+subregion_entry:
+ %add = add nsw i32 %n, -2
+ %cmp = fcmp ogt float undef, undef
+ br i1 %cmp, label %subregion_if, label %subregion_exit
+
+subregion_if:
+ br label %subregion_exit
+
+subregion_exit:
+ %retval = phi i32 [ %add, %subregion_if ], [ %add, %subregion_entry ]
+ ret i32 %retval
+}
OpenPOWER on IntegriCloud