Test source: git
Source: /bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll -- 1. ModuleToFunctionPassAdaptor -- 1. PassManager<llvm::Function> : Skipping NOP -- 2. DFAJumpThreadingPass ---------------------------------------- define i32 @test1(i32 %num) { entry: br label %for.body for.body: %count = phi i32 [ 0, %entry ], [ %inc, %for.inc ] %state = phi i32 [ 1, %entry ], [ %state.next, %for.inc ] switch i32 %state, label %for.inc [ i32 1, label %case1 i32 2, label %case2 ] case1: br label %for.inc case2: %cmp = icmp eq i32 %count, 50 %sel = select i1 %cmp, i32 1, i32 2 br label %for.inc for.inc: %state.next = phi i32 [ %sel, %case2 ], [ 1, %for.body ], [ 2, %case1 ] %inc = add nsw i32 %count, 1 %cmp.exit = icmp slt i32 %inc, %num br i1 %cmp.exit, label %for.body, label %for.end for.end: ret i32 0 } Transformation seems to be correct! (syntactically equal) -- 3. DFAJumpThreadingPass ---------------------------------------- define i32 @test1(i32 %num) { entry: br label %for.body for.body: %count = phi i32 [ 0, %entry ], [ %inc, %for.inc ] %state = phi i32 [ 1, %entry ], [ %state.next, %for.inc ] switch i32 %state, label %for.inc [ i32 1, label %case1 i32 2, label %case2 ] case1: br label %for.inc case2: %cmp = icmp eq i32 %count, 50 %sel = select i1 %cmp, i32 1, i32 2 br label %for.inc for.inc: %state.next = phi i32 [ %sel, %case2 ], [ 1, %for.body ], [ 2, %case1 ] %inc = add nsw i32 %count, 1 %cmp.exit = icmp slt i32 %inc, %num br i1 %cmp.exit, label %for.body, label %for.end for.end: ret i32 0 } => define i32 @test1(i32 %num) { entry: br label %for.body for.body: %count = phi i32 [ 0, %entry ] %state = phi i32 [ 1, %entry ] switch i32 %state, label %for.inc.jt1 [ i32 1, label %case1 i32 2, label %case2 ] case2: %count1 = phi i32 [ %count.jt2, %for.body.jt2 ], [ %count, %for.body ] %cmp = icmp eq i32 %count1, 50 br i1 %cmp, label %for.inc.jt1, label %sel.si.unfold.false.jt2 for.inc.jt1: %count3 = phi i32 [ %count, %for.body ], [ %count1, %case2 ] %inc.jt1 = add nsw i32 %count3, 1 %cmp.exit.jt1 = icmp slt i32 %inc.jt1, %num br i1 %cmp.exit.jt1, label %for.body.jt1, label %for.end for.body.jt1: %count.jt1 = phi i32 [ %inc.jt1, %for.inc.jt1 ] br label %case1 case1: %count2 = phi i32 [ %count.jt1, %for.body.jt1 ], [ %count, %for.body ] br label %for.inc.jt2 sel.si.unfold.false.jt2: br label %for.inc.jt2 for.inc.jt2: %count4 = phi i32 [ %count1, %sel.si.unfold.false.jt2 ], [ %count2, %case1 ] %inc.jt2 = add nsw i32 %count4, 1 %cmp.exit.jt2 = icmp slt i32 %inc.jt2, %num br i1 %cmp.exit.jt2, label %for.body.jt2, label %for.end for.body.jt2: %count.jt2 = phi i32 [ %inc.jt2, %for.inc.jt2 ] br label %case2 for.end: ret i32 0 } Transformation seems to be correct! -- 4. PassManager<llvm::Function> : Skipping NOP -- 5. PassManager<llvm::Function> : Skipping NOP -- 6. DFAJumpThreadingPass ---------------------------------------- define i32 @test2(i32 %init) { entry: %cmp = icmp eq i32 %init, 0 %sel = select i1 %cmp, i32 0, i32 2 br label %loop.1 loop.1: %state.1 = phi i32 [ %sel, %entry ], [ %state.1.be2, %loop.1.backedge ] br label %loop.2 loop.2: %state.2 = phi i32 [ %state.1, %loop.1 ], [ %state.2.be, %loop.2.backedge ] br label %loop.3 loop.3: %state = phi i32 [ %state.2, %loop.2 ], [ 3, %case2 ] switch i32 %state, label %infloop.i [ i32 2, label %case2 i32 3, label %case3 i32 4, label %case4 i32 0, label %case0 i32 1, label %case1 ] infloop.i: br label %infloop.i case2: br i1 %cmp, label %loop.3, label %loop.1.backedge case3: br i1 %cmp, label %loop.2.backedge, label %case4 case4: br i1 %cmp, label %loop.2.backedge, label %loop.1.backedge loop.2.backedge: %state.2.be = phi i32 [ 3, %case4 ], [ 0, %case3 ] br label %loop.2 loop.1.backedge: %state.1.be = phi i32 [ 2, %case4 ], [ 4, %case2 ] %state.1.be2 = select i1 %cmp, i32 1, i32 %state.1.be br label %loop.1 case0: br label %exit case1: br label %exit exit: ret i32 0 } Transformation seems to be correct! (syntactically equal) -- 7. DFAJumpThreadingPass ---------------------------------------- define i32 @test2(i32 %init) { entry: %cmp = icmp eq i32 %init, 0 %sel = select i1 %cmp, i32 0, i32 2 br label %loop.1 loop.1: %state.1 = phi i32 [ %sel, %entry ], [ %state.1.be2, %loop.1.backedge ] br label %loop.2 loop.2: %state.2 = phi i32 [ %state.1, %loop.1 ], [ %state.2.be, %loop.2.backedge ] br label %loop.3 loop.3: %state = phi i32 [ %state.2, %loop.2 ], [ 3, %case2 ] switch i32 %state, label %infloop.i [ i32 2, label %case2 i32 3, label %case3 i32 4, label %case4 i32 0, label %case0 i32 1, label %case1 ] infloop.i: br label %infloop.i case2: br i1 %cmp, label %loop.3, label %loop.1.backedge case3: br i1 %cmp, label %loop.2.backedge, label %case4 case4: br i1 %cmp, label %loop.2.backedge, label %loop.1.backedge loop.2.backedge: %state.2.be = phi i32 [ 3, %case4 ], [ 0, %case3 ] br label %loop.2 loop.1.backedge: %state.1.be = phi i32 [ 2, %case4 ], [ 4, %case2 ] %state.1.be2 = select i1 %cmp, i32 1, i32 %state.1.be br label %loop.1 case0: br label %exit case1: br label %exit exit: ret i32 0 } => define i32 @test2(i32 %init) { entry: %cmp = icmp eq i32 %init, 0 br i1 %cmp, label %loop.1, label %sel.si.unfold.false sel.si.unfold.false: %.si.unfold.phi = phi i32 [ 2, %entry ] br label %loop.1 loop.1: %state.1 = phi i32 [ 0, %entry ], [ %.si.unfold.phi, %sel.si.unfold.false ] br label %loop.2 loop.2: %state.2 = phi i32 [ %state.1, %loop.1 ] br label %loop.3 loop.3: %state = phi i32 [ %state.2, %loop.2 ] switch i32 %state, label %infloop.i [ i32 2, label %case2 i32 3, label %case3 i32 4, label %case4 i32 0, label %case0 i32 1, label %case1 ] infloop.i: br label %infloop.i case4: br i1 %cmp, label %loop.2.backedge.jt3, label %loop.1.backedge.jt2 loop.2.backedge.jt3: br label %loop.2.jt3 loop.2.jt3: br label %loop.3.jt3 loop.1.backedge.jt2: br i1 %cmp, label %loop.1.jt1, label %state.1.be2.si.unfold.false.jt2 state.1.be2.si.unfold.false.jt2: br label %loop.1.jt2 loop.1.jt2: br label %loop.2.jt2 loop.2.jt2: br label %loop.3.jt2 loop.3.jt2: br label %case2 case2: br i1 %cmp, label %loop.3.jt3, label %loop.1.backedge.jt4 loop.3.jt3: br label %case3 case3: br i1 %cmp, label %loop.2.backedge.jt0, label %case4 loop.2.backedge.jt0: br label %loop.2.jt0 loop.2.jt0: br label %loop.3.jt0 loop.3.jt0: br label %case0 loop.1.backedge.jt4: br i1 %cmp, label %loop.1.jt1, label %state.1.be2.si.unfold.false.jt4 loop.1.jt1: br label %loop.2.jt1 loop.2.jt1: br label %loop.3.jt1 loop.3.jt1: br label %case1 state.1.be2.si.unfold.false.jt4: br label %loop.1.jt4 loop.1.jt4: br label %loop.2.jt4 loop.2.jt4: br label %loop.3.jt4 loop.3.jt4: br label %case4 case0: br label %exit case1: br label %exit exit: ret i32 0 } Transformation seems to be correct! -- 8. PassManager<llvm::Function> : Skipping NOP -- 9. PassManager<llvm::Function> : Skipping NOP -- 10. DFAJumpThreadingPass ---------------------------------------- define void @pr78059_bitwidth() { .split.preheader: br label %.split .split: %#0 = phi i128 [ 0, %.split.preheader ], [ 340282366920938463463374607431768211455, %.split ] switch i128 %#0, label %end [ i128 340282366920938463463374607431768211455, label %end i128 0, label %.split ] end: ret void } Transformation seems to be correct! (syntactically equal) -- 11. DFAJumpThreadingPass ---------------------------------------- define void @pr78059_bitwidth() { .split.preheader: br label %.split .split: %#0 = phi i128 [ 0, %.split.preheader ], [ 340282366920938463463374607431768211455, %.split ] switch i128 %#0, label %end [ i128 340282366920938463463374607431768211455, label %end i128 0, label %.split ] end: ret void } => define void @pr78059_bitwidth() { .split.preheader: br label %.split .split: %#0 = phi i128 [ 0, %.split.preheader ] switch i128 %#0, label %end [ i128 340282366920938463463374607431768211455, label %end i128 0, label %.split.jt18446744073709551615 ] .split.jt18446744073709551615: br label %end end: ret void } **************************************** WARNING: Source function is always UB. It can be refined by any target function. Please make sure this is what you wanted. **************************************** Transformation doesn't verify! (not unsound) ERROR: The source program doesn't reach a return instruction. Consider increasing the unroll factor if it has loops -- 12. PassManager<llvm::Function> : Skipping NOP -- 13. PassManager<llvm::Function> : Skipping NOP -- 14. DFAJumpThreadingPass ---------------------------------------- define void @self-reference() { .split.preheader: br label %.split .split: %#0 = phi i32 [ 0, %.split.preheader ], [ 4294967295, %.split ] switch i32 %#0, label %end [ i32 4294967295, label %end i32 0, label %.split ] end: ret void } Transformation seems to be correct! (syntactically equal) -- 15. DFAJumpThreadingPass ---------------------------------------- define void @self-reference() { .split.preheader: br label %.split .split: %#0 = phi i32 [ 0, %.split.preheader ], [ 4294967295, %.split ] switch i32 %#0, label %end [ i32 4294967295, label %end i32 0, label %.split ] end: ret void } => define void @self-reference() { .split.preheader: br label %.split .split: %#0 = phi i32 [ 0, %.split.preheader ] switch i32 %#0, label %end [ i32 4294967295, label %end i32 0, label %.split.jt4294967295 ] .split.jt4294967295: br label %end end: ret void } **************************************** WARNING: Source function is always UB. It can be refined by any target function. Please make sure this is what you wanted. **************************************** Transformation doesn't verify! (not unsound) ERROR: The source program doesn't reach a return instruction. Consider increasing the unroll factor if it has loops -- 16. PassManager<llvm::Function> : Skipping NOP -- 17. PassManager<llvm::Function> : Skipping NOP -- 18. DFAJumpThreadingPass ---------------------------------------- define void @pr106083_invalidBBarg_fold(i1 %cmp1, i1 %cmp2, i1 %not, ptr %d) { bb: %sel = select i1 %cmp1, i32 0, i32 1 br label %BB1 BB1: %i = phi i16 [ 0, %BB1.backedge ], [ 0, %bb ], [ 1, %BB7 ] br i1 %not, label %BB7, label %BB2 BB2: store i16 0, ptr %d, align 2 %spec.select = select i1 %cmp2, i32 %sel, i32 0 br label %BB7 BB7: %d.promoted4 = phi i16 [ 0, %BB1 ], [ 1, %BB2 ] %_3 = phi i32 [ 0, %BB1 ], [ %spec.select, %BB2 ] switch i32 %_3, label %BB1.backedge [ i32 0, label %BB1 i32 1, label %BB8 ] BB1.backedge: br label %BB1 BB8: ret void } Transformation seems to be correct! (syntactically equal) -- 19. DFAJumpThreadingPass ---------------------------------------- define void @pr106083_invalidBBarg_fold(i1 %cmp1, i1 %cmp2, i1 %not, ptr %d) { bb: %sel = select i1 %cmp1, i32 0, i32 1 br label %BB1 BB1: br i1 %not, label %BB7, label %BB2 BB2: store i16 0, ptr %d, align 2 %spec.select = select i1 %cmp2, i32 %sel, i32 0 br label %BB7 BB7: %_3 = phi i32 [ 0, %BB1 ], [ %spec.select, %BB2 ] switch i32 %_3, label %BB1.backedge [ i32 0, label %BB1 i32 1, label %BB8 ] BB1.backedge: br label %BB1 BB8: ret void } => define void @pr106083_invalidBBarg_fold(i1 %cmp1, i1 %cmp2, i1 %not, ptr %d) { bb: br i1 %cmp1, label %BB1, label %sel.si.unfold.false sel.si.unfold.false: %.si.unfold.phi1 = phi i32 [ 1, %bb ] br label %BB1 BB1: %sel.si.unfold.phi = phi i32 [ %sel.si.unfold.phi, %BB1.backedge ], [ %sel.si.unfold.phi, %BB7 ], [ 0, %bb ], [ %.si.unfold.phi1, %sel.si.unfold.false ], [ %sel.si.unfold.phi, %BB7.jt0 ] br i1 %not, label %BB7.jt0, label %BB2 BB2: store i16 0, ptr %d, align 2 br i1 %cmp2, label %BB7, label %spec.select.si.unfold.false.jt0 BB7: %_3 = phi i32 [ %sel.si.unfold.phi, %BB2 ] switch i32 %_3, label %BB1.backedge [ i32 0, label %BB1 i32 1, label %BB8 ] BB1.backedge: br label %BB1 BB8: ret void spec.select.si.unfold.false.jt0: br label %BB7.jt0 BB7.jt0: br label %BB1 } Transformation seems to be correct! -- 20. PassManager<llvm::Function> : Skipping NOP -- 21. PassManager<llvm::Function> : Skipping NOP -- 22. DFAJumpThreadingPass ---------------------------------------- define void @pr106083_select_dead_uses(i1 %cmp1, i1 %not, ptr %p) { bb: %spec.select = select i1 %cmp1, i32 0, i32 1 br label %.loopexit6 .loopexit6: br i1 %not, label %select.unfold, label %bb1 bb1: %i = load i32, ptr %p, align 4 %not2 = icmp eq i32 0, 0 %spec.select7 = select i1 %not2, i32 %spec.select, i32 0 br label %select.unfold select.unfold: %_2 = phi i32 [ 0, %.loopexit6 ], [ %spec.select7, %bb1 ] switch i32 %_2, label %bb2 [ i32 0, label %.preheader.preheader i32 1, label %.loopexit6 ] bb2: assume i1 0 .preheader.preheader: ret void } Transformation seems to be correct! (syntactically equal) -- 23. DFAJumpThreadingPass ---------------------------------------- define void @pr106083_select_dead_uses(i1 %cmp1, i1 %not, ptr %p) { bb: %spec.select = select i1 %cmp1, i32 0, i32 1 br label %.loopexit6 .loopexit6: br i1 %not, label %select.unfold, label %bb1 bb1: %i = load i32, ptr %p, align 4 %not2 = icmp eq i32 0, 0, offsetonly %spec.select7 = select i1 %not2, i32 %spec.select, i32 0 br label %select.unfold select.unfold: %_2 = phi i32 [ 0, %.loopexit6 ], [ %spec.select7, %bb1 ] switch i32 %_2, label %bb2 [ i32 0, label %.preheader.preheader i32 1, label %.loopexit6 ] bb2: assume i1 0 .preheader.preheader: ret void } => define void @pr106083_select_dead_uses(i1 %cmp1, i1 %not, ptr %p) { bb: br i1 %cmp1, label %.loopexit6, label %spec.select.si.unfold.false spec.select.si.unfold.false: %.si.unfold.phi1 = phi i32 [ 1, %bb ] br label %.loopexit6 .loopexit6: %spec.select.si.unfold.phi = phi i32 [ %spec.select.si.unfold.phi, %select.unfold ], [ 0, %bb ], [ %.si.unfold.phi1, %spec.select.si.unfold.false ] br i1 %not, label %select.unfold.jt0, label %bb1 bb1: %i = load i32, ptr %p, align 4 %not2 = icmp eq i32 0, 0, offsetonly br i1 %not2, label %select.unfold, label %spec.select7.si.unfold.false.jt0 select.unfold: %_2 = phi i32 [ %spec.select.si.unfold.phi, %bb1 ] switch i32 %_2, label %bb2 [ i32 0, label %.preheader.preheader i32 1, label %.loopexit6 ] bb2: assume i1 0 spec.select7.si.unfold.false.jt0: br label %select.unfold.jt0 select.unfold.jt0: br label %.preheader.preheader .preheader.preheader: ret void } Transformation doesn't verify! (unsound) ERROR: Source is more defined than target Example: i1 %cmp1 = undef i1 %not = #x1 (1) ptr %p = poison Source: i32 %spec.select = #x00000000 (0) [based on undef] >> Jump to %.loopexit6 >> Jump to %select.unfold i32 %_2 = #x00000000 (0) >> Jump to %.preheader.preheader SOURCE MEMORY STATE =================== NON-LOCAL BLOCKS: Block 0 > size: 0 align: 4 alloc type: 0 alive: false address: 0 Block 1 > size: 0 align: 1 alloc type: 0 alive: true address: 2 Target: UB triggered on br Pass: DFAJumpThreadingPass Command line: '/home/nlopes/llvm/build/bin/opt' '-load=/home/nlopes/alive2/build/tv/tv.so' '-load-pass-plugin=/home/nlopes/alive2/build/tv/tv.so' '-tv-exit-on-error' '-S' '-passes=dfa-jump-threading' '/bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll' '-tv-smt-to=20000' '-tv-report-dir=/home/nlopes/alive2/build/logs' '-tv-smt-stats' Wrote bitcode to: "/home/nlopes/alive2/build/logs/dfa-jump-threading-transform_nyevHkM4_GpXL.bc" ------------------- SMT STATS ------------------- Num queries: 49 Num invalid: 0 Num skips: 0 Num trivial: 22 (31.0%) Num timeout: 0 (0.0%) Num errors: 0 (0.0%) Num SAT: 40 (81.6%) Num UNSAT: 9 (18.4%) Alive2: Transform doesn't verify; aborting!
RUN: at line 2: /home/nlopes/alive2/build/opt-alive.sh -S -passes=dfa-jump-threading /bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll | /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll + /home/nlopes/alive2/build/opt-alive.sh -S -passes=dfa-jump-threading /bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll + /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll FileCheck error: '<stdin>' is empty. FileCheck command line: /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/DFAJumpThreading/dfa-jump-threading-transform.ll