1 ; RUN: opt -loop-reduce -S < %s | FileCheck %s 2 ; 3 ; Test TransformForPostIncUse and LSR's expansion of expressions in 4 ; post-inc form to ensure the implementation can handle expressions 5 ; DAGs, not just trees. 6 7 target triple = "x86_64-apple-darwin" 8 9 ; Verify that -loop-reduce runs without "hanging" and reuses post-inc 10 ; expansions. 11 ; CHECK: @test 12 ; CHECK: icmp 13 ; CHECK: icmp 14 ; CHECK: icmp 15 ; CHECK: icmp 16 ; CHECK: icmp 17 ; CHECK: icmp 18 ; CHECK: icmp 19 ; CHECK: icmp 20 ; CHECK: icmp 21 ; CHECK: icmp 22 ; CHECK: icmp 23 ; CHECK: icmp 24 ; CHECK: icmp 25 ; CHECK: icmp 26 ; CHECK: icmp 27 ; CHECK: icmp 28 ; CHECK: icmp 29 ; CHECK-NOT: icmp 30 define void @test(i8* %base, i32 %a0) nounwind { 31 entry: 32 br label %bb1 33 bb1: 34 %n0 = sub i32 0, %a0 35 %t0 = icmp ugt i32 %n0, -4 36 %m0 = select i1 %t0, i32 %n0, i32 -4 37 %a1 = add i32 %m0, %a0 38 %n1 = sub i32 0, %a1 39 %t1 = icmp ugt i32 %n1, -4 40 %m1 = select i1 %t1, i32 %n1, i32 -4 41 %a2 = add i32 %m1, %a1 42 %n2 = sub i32 0, %a2 43 %t2 = icmp ugt i32 %n2, -4 44 %m2 = select i1 %t2, i32 %n2, i32 -4 45 %a3 = add i32 %m2, %a2 46 %n3 = sub i32 0, %a3 47 %t3 = icmp ugt i32 %n3, -4 48 %m3 = select i1 %t3, i32 %n3, i32 -4 49 %a4 = add i32 %m3, %a3 50 %n4 = sub i32 0, %a4 51 %t4 = icmp ugt i32 %n4, -4 52 %m4 = select i1 %t4, i32 %n4, i32 -4 53 %a5 = add i32 %m4, %a4 54 %n5 = sub i32 0, %a5 55 %t5 = icmp ugt i32 %n5, -4 56 %m5 = select i1 %t5, i32 %n5, i32 -4 57 %a6 = add i32 %m5, %a5 58 %n6 = sub i32 0, %a6 59 %t6 = icmp ugt i32 %n6, -4 60 %m6 = select i1 %t6, i32 %n6, i32 -4 61 %a7 = add i32 %m6, %a6 62 %n7 = sub i32 0, %a7 63 %t7 = icmp ugt i32 %n7, -4 64 %m7 = select i1 %t7, i32 %n7, i32 -4 65 %a8 = add i32 %m7, %a7 66 %n8 = sub i32 0, %a8 67 %t8 = icmp ugt i32 %n8, -4 68 %m8 = select i1 %t8, i32 %n8, i32 -4 69 %a9 = add i32 %m8, %a8 70 %n9 = sub i32 0, %a9 71 %t9 = icmp ugt i32 %n9, -4 72 %m9 = select i1 %t9, i32 %n9, i32 -4 73 %a10 = add i32 %m9, %a9 74 %n10 = sub i32 0, %a10 75 %t10 = icmp ugt i32 %n10, -4 76 %m10 = select i1 %t10, i32 %n10, i32 -4 77 %a11 = add i32 %m10, %a10 78 %n11 = sub i32 0, %a11 79 %t11 = icmp ugt i32 %n11, -4 80 %m11 = select i1 %t11, i32 %n11, i32 -4 81 %a12 = add i32 %m11, %a11 82 %n12 = sub i32 0, %a12 83 %t12 = icmp ugt i32 %n12, -4 84 %m12 = select i1 %t12, i32 %n12, i32 -4 85 %a13 = add i32 %m12, %a12 86 %n13 = sub i32 0, %a13 87 %t13 = icmp ugt i32 %n13, -4 88 %m13 = select i1 %t13, i32 %n13, i32 -4 89 %a14 = add i32 %m13, %a13 90 %n14 = sub i32 0, %a14 91 %t14 = icmp ugt i32 %n14, -4 92 %m14 = select i1 %t14, i32 %n14, i32 -4 93 %a15 = add i32 %m14, %a14 94 %n15 = sub i32 0, %a15 95 %t15 = icmp ugt i32 %n15, -4 96 %m15 = select i1 %t15, i32 %n15, i32 -4 97 %a16 = add i32 %m15, %a15 98 %gep = getelementptr i8* %base, i32 %a16 99 %ofs = add i32 %a16, 4 100 %limit = getelementptr i8* %base, i32 %ofs 101 br label %loop 102 103 loop: 104 %iv = phi i8* [ %gep, %bb1 ], [ %inc, %loop ] 105 %inc = getelementptr inbounds i8* %iv, i64 1 106 %exitcond = icmp eq i8* %inc, %limit 107 br i1 %exitcond, label %loop, label %exit 108 109 exit: 110 ret void 111 } 112