2011-10-13-SCEVChain.ll 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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. target triple = "x86_64-apple-darwin"
  7. ; Verify that -loop-reduce runs without "hanging" and reuses post-inc
  8. ; expansions.
  9. ; CHECK-LABEL: @test(
  10. ; CHECK: icmp
  11. ; CHECK: icmp
  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-NOT: icmp
  28. define void @test(i8* %base, i32 %a0) nounwind {
  29. entry:
  30. br label %bb1
  31. bb1:
  32. %n0 = sub i32 0, %a0
  33. %t0 = icmp ugt i32 %n0, -4
  34. %m0 = select i1 %t0, i32 %n0, i32 -4
  35. %a1 = add i32 %m0, %a0
  36. %n1 = sub i32 0, %a1
  37. %t1 = icmp ugt i32 %n1, -4
  38. %m1 = select i1 %t1, i32 %n1, i32 -4
  39. %a2 = add i32 %m1, %a1
  40. %n2 = sub i32 0, %a2
  41. %t2 = icmp ugt i32 %n2, -4
  42. %m2 = select i1 %t2, i32 %n2, i32 -4
  43. %a3 = add i32 %m2, %a2
  44. %n3 = sub i32 0, %a3
  45. %t3 = icmp ugt i32 %n3, -4
  46. %m3 = select i1 %t3, i32 %n3, i32 -4
  47. %a4 = add i32 %m3, %a3
  48. %n4 = sub i32 0, %a4
  49. %t4 = icmp ugt i32 %n4, -4
  50. %m4 = select i1 %t4, i32 %n4, i32 -4
  51. %a5 = add i32 %m4, %a4
  52. %n5 = sub i32 0, %a5
  53. %t5 = icmp ugt i32 %n5, -4
  54. %m5 = select i1 %t5, i32 %n5, i32 -4
  55. %a6 = add i32 %m5, %a5
  56. %n6 = sub i32 0, %a6
  57. %t6 = icmp ugt i32 %n6, -4
  58. %m6 = select i1 %t6, i32 %n6, i32 -4
  59. %a7 = add i32 %m6, %a6
  60. %n7 = sub i32 0, %a7
  61. %t7 = icmp ugt i32 %n7, -4
  62. %m7 = select i1 %t7, i32 %n7, i32 -4
  63. %a8 = add i32 %m7, %a7
  64. %n8 = sub i32 0, %a8
  65. %t8 = icmp ugt i32 %n8, -4
  66. %m8 = select i1 %t8, i32 %n8, i32 -4
  67. %a9 = add i32 %m8, %a8
  68. %n9 = sub i32 0, %a9
  69. %t9 = icmp ugt i32 %n9, -4
  70. %m9 = select i1 %t9, i32 %n9, i32 -4
  71. %a10 = add i32 %m9, %a9
  72. %n10 = sub i32 0, %a10
  73. %t10 = icmp ugt i32 %n10, -4
  74. %m10 = select i1 %t10, i32 %n10, i32 -4
  75. %a11 = add i32 %m10, %a10
  76. %n11 = sub i32 0, %a11
  77. %t11 = icmp ugt i32 %n11, -4
  78. %m11 = select i1 %t11, i32 %n11, i32 -4
  79. %a12 = add i32 %m11, %a11
  80. %n12 = sub i32 0, %a12
  81. %t12 = icmp ugt i32 %n12, -4
  82. %m12 = select i1 %t12, i32 %n12, i32 -4
  83. %a13 = add i32 %m12, %a12
  84. %n13 = sub i32 0, %a13
  85. %t13 = icmp ugt i32 %n13, -4
  86. %m13 = select i1 %t13, i32 %n13, i32 -4
  87. %a14 = add i32 %m13, %a13
  88. %n14 = sub i32 0, %a14
  89. %t14 = icmp ugt i32 %n14, -4
  90. %m14 = select i1 %t14, i32 %n14, i32 -4
  91. %a15 = add i32 %m14, %a14
  92. %n15 = sub i32 0, %a15
  93. %t15 = icmp ugt i32 %n15, -4
  94. %m15 = select i1 %t15, i32 %n15, i32 -4
  95. %a16 = add i32 %m15, %a15
  96. %gep = getelementptr i8, i8* %base, i32 %a16
  97. %ofs = add i32 %a16, 4
  98. %limit = getelementptr i8, i8* %base, i32 %ofs
  99. br label %loop
  100. loop:
  101. %iv = phi i8* [ %gep, %bb1 ], [ %inc, %loop ]
  102. %inc = getelementptr inbounds i8, i8* %iv, i64 1
  103. %exitcond = icmp eq i8* %inc, %limit
  104. br i1 %exitcond, label %loop, label %exit
  105. exit:
  106. ret void
  107. }