range.ll 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. ; RUN: opt -correlated-propagation -S < %s | FileCheck %s
  2. declare i32 @foo()
  3. define i32 @test1(i32 %a) nounwind {
  4. %a.off = add i32 %a, -8
  5. %cmp = icmp ult i32 %a.off, 8
  6. br i1 %cmp, label %then, label %else
  7. then:
  8. %dead = icmp eq i32 %a, 7
  9. br i1 %dead, label %end, label %else
  10. else:
  11. ret i32 1
  12. end:
  13. ret i32 2
  14. ; CHECK-LABEL: @test1(
  15. ; CHECK: then:
  16. ; CHECK-NEXT: br i1 false, label %end, label %else
  17. }
  18. define i32 @test2(i32 %a) nounwind {
  19. %a.off = add i32 %a, -8
  20. %cmp = icmp ult i32 %a.off, 8
  21. br i1 %cmp, label %then, label %else
  22. then:
  23. %dead = icmp ugt i32 %a, 15
  24. br i1 %dead, label %end, label %else
  25. else:
  26. ret i32 1
  27. end:
  28. ret i32 2
  29. ; CHECK-LABEL: @test2(
  30. ; CHECK: then:
  31. ; CHECK-NEXT: br i1 false, label %end, label %else
  32. }
  33. ; CHECK-LABEL: @test3(
  34. define i32 @test3(i32 %c) nounwind {
  35. %cmp = icmp slt i32 %c, 2
  36. br i1 %cmp, label %if.then, label %if.end
  37. if.then:
  38. ret i32 1
  39. if.end:
  40. %cmp1 = icmp slt i32 %c, 3
  41. br i1 %cmp1, label %if.then2, label %if.end8
  42. ; CHECK: if.then2
  43. if.then2:
  44. %cmp2 = icmp eq i32 %c, 2
  45. ; CHECK: br i1 true
  46. br i1 %cmp2, label %if.then4, label %if.end6
  47. ; CHECK: if.end6
  48. if.end6:
  49. ret i32 2
  50. if.then4:
  51. ret i32 3
  52. if.end8:
  53. ret i32 4
  54. }
  55. ; CHECK-LABEL: @test4(
  56. define i32 @test4(i32 %c) nounwind {
  57. switch i32 %c, label %sw.default [
  58. i32 1, label %sw.bb
  59. i32 2, label %sw.bb
  60. i32 4, label %sw.bb
  61. ]
  62. ; CHECK: sw.bb
  63. sw.bb:
  64. %cmp = icmp sge i32 %c, 1
  65. ; CHECK: br i1 true
  66. br i1 %cmp, label %if.then, label %if.end
  67. if.then:
  68. br label %return
  69. if.end:
  70. br label %return
  71. sw.default:
  72. br label %return
  73. return:
  74. %retval.0 = phi i32 [ 42, %sw.default ], [ 4, %if.then ], [ 9, %if.end ]
  75. ret i32 %retval.0
  76. }
  77. ; CHECK-LABEL: @test5(
  78. define i1 @test5(i32 %c) nounwind {
  79. %cmp = icmp slt i32 %c, 5
  80. br i1 %cmp, label %if.then, label %if.end
  81. if.then:
  82. %cmp1 = icmp eq i32 %c, 4
  83. br i1 %cmp1, label %if.end, label %if.end8
  84. if.end:
  85. ret i1 true
  86. if.end8:
  87. %cmp2 = icmp eq i32 %c, 3
  88. %cmp3 = icmp eq i32 %c, 4
  89. %cmp4 = icmp eq i32 %c, 6
  90. ; CHECK: %or = or i1 false, false
  91. %or = or i1 %cmp3, %cmp4
  92. ; CHECK: ret i1 %cmp2
  93. ret i1 %cmp2
  94. }
  95. ; CHECK-LABEL: @test6(
  96. define i1 @test6(i32 %c) nounwind {
  97. %cmp = icmp ule i32 %c, 7
  98. br i1 %cmp, label %if.then, label %if.end
  99. if.then:
  100. ; CHECK: icmp eq i32 %c, 6
  101. ; CHECK: br i1
  102. switch i32 %c, label %if.end [
  103. i32 6, label %sw.bb
  104. i32 8, label %sw.bb
  105. ]
  106. if.end:
  107. ret i1 true
  108. sw.bb:
  109. %cmp2 = icmp eq i32 %c, 6
  110. ; CHECK: ret i1 true
  111. ret i1 %cmp2
  112. }
  113. ; CHECK-LABEL: @test7(
  114. define i1 @test7(i32 %c) nounwind {
  115. entry:
  116. switch i32 %c, label %sw.default [
  117. i32 6, label %sw.bb
  118. i32 7, label %sw.bb
  119. ]
  120. sw.bb:
  121. ret i1 true
  122. sw.default:
  123. %cmp5 = icmp eq i32 %c, 5
  124. %cmp6 = icmp eq i32 %c, 6
  125. %cmp7 = icmp eq i32 %c, 7
  126. %cmp8 = icmp eq i32 %c, 8
  127. ; CHECK: %or = or i1 %cmp5, false
  128. %or = or i1 %cmp5, %cmp6
  129. ; CHECK: %or2 = or i1 false, %cmp8
  130. %or2 = or i1 %cmp7, %cmp8
  131. ret i1 false
  132. }