trip-count7.ll 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. ; RUN: opt < %s -analyze -scalar-evolution | FileCheck %s
  2. target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
  3. ; CHECK: Loop %bb7.i: Unpredictable backedge-taken count.
  4. %struct.complex = type { float, float }
  5. %struct.element = type { i32, i32 }
  6. %struct.node = type { %struct.node*, %struct.node*, i32 }
  7. @seed = external global i64 ; <i64*> [#uses=0]
  8. @_2E_str = external constant [18 x i8], align 1 ; <[18 x i8]*> [#uses=0]
  9. @_2E_str1 = external constant [4 x i8], align 1 ; <[4 x i8]*> [#uses=0]
  10. @value = external global float ; <float*> [#uses=0]
  11. @fixed = external global float ; <float*> [#uses=0]
  12. @floated = external global float ; <float*> [#uses=0]
  13. @permarray = external global [11 x i32], align 32 ; <[11 x i32]*> [#uses=0]
  14. @pctr = external global i32 ; <i32*> [#uses=0]
  15. @tree = external global %struct.node* ; <%struct.node**> [#uses=0]
  16. @stack = external global [4 x i32], align 16 ; <[4 x i32]*> [#uses=0]
  17. @cellspace = external global [19 x %struct.element], align 32 ; <[19 x %struct.element]*> [#uses=0]
  18. @freelist = external global i32 ; <i32*> [#uses=0]
  19. @movesdone = external global i32 ; <i32*> [#uses=0]
  20. @ima = external global [41 x [41 x i32]], align 32 ; <[41 x [41 x i32]]*> [#uses=0]
  21. @imb = external global [41 x [41 x i32]], align 32 ; <[41 x [41 x i32]]*> [#uses=0]
  22. @imr = external global [41 x [41 x i32]], align 32 ; <[41 x [41 x i32]]*> [#uses=0]
  23. @rma = external global [41 x [41 x float]], align 32 ; <[41 x [41 x float]]*> [#uses=0]
  24. @rmb = external global [41 x [41 x float]], align 32 ; <[41 x [41 x float]]*> [#uses=0]
  25. @rmr = external global [41 x [41 x float]], align 32 ; <[41 x [41 x float]]*> [#uses=0]
  26. @piececount = external global [4 x i32], align 16 ; <[4 x i32]*> [#uses=0]
  27. @class = external global [13 x i32], align 32 ; <[13 x i32]*> [#uses=0]
  28. @piecemax = external global [13 x i32], align 32 ; <[13 x i32]*> [#uses=0]
  29. @puzzl = external global [512 x i32], align 32 ; <[512 x i32]*> [#uses=0]
  30. @p = external global [13 x [512 x i32]], align 32 ; <[13 x [512 x i32]]*> [#uses=0]
  31. @n = external global i32 ; <i32*> [#uses=0]
  32. @kount = external global i32 ; <i32*> [#uses=0]
  33. @sortlist = external global [5001 x i32], align 32 ; <[5001 x i32]*> [#uses=0]
  34. @biggest = external global i32 ; <i32*> [#uses=0]
  35. @littlest = external global i32 ; <i32*> [#uses=0]
  36. @top = external global i32 ; <i32*> [#uses=0]
  37. @z = external global [257 x %struct.complex], align 32 ; <[257 x %struct.complex]*> [#uses=0]
  38. @w = external global [257 x %struct.complex], align 32 ; <[257 x %struct.complex]*> [#uses=0]
  39. @e = external global [130 x %struct.complex], align 32 ; <[130 x %struct.complex]*> [#uses=0]
  40. @zr = external global float ; <float*> [#uses=0]
  41. @zi = external global float ; <float*> [#uses=0]
  42. declare void @Initrand() nounwind
  43. declare i32 @Rand() nounwind
  44. declare void @Try(i32, i32*, i32*, i32*, i32*, i32*) nounwind
  45. declare i32 @puts(i8* nocapture) nounwind
  46. declare void @Queens(i32) nounwind
  47. declare i32 @printf(i8* nocapture, ...) nounwind
  48. declare i32 @main() nounwind
  49. declare void @Doit() nounwind
  50. declare void @Doit_bb7([15 x i32]*, [17 x i32]*, [9 x i32]*) nounwind
  51. define void @Doit_bb7_2E_i([9 x i32]* %x1, [15 x i32]* %c, [17 x i32]* %b, [9 x i32]* %a, i32* %q, i32* %x1.sub, i32* %b9, i32* %a10, i32* %c11) nounwind {
  52. newFuncRoot:
  53. br label %bb7.i
  54. Try.exit.exitStub: ; preds = %bb7.i
  55. ret void
  56. bb.i: ; preds = %bb7.i
  57. %tmp = add i32 %j.0.i, 1 ; <i32> [#uses=5]
  58. store i32 0, i32* %q, align 4
  59. %tmp1 = sext i32 %tmp to i64 ; <i64> [#uses=1]
  60. %tmp2 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp1 ; <i32*> [#uses=1]
  61. %tmp3 = load i32, i32* %tmp2, align 4 ; <i32> [#uses=1]
  62. %tmp4 = icmp eq i32 %tmp3, 0 ; <i1> [#uses=1]
  63. br i1 %tmp4, label %bb.i.bb7.i.backedge_crit_edge, label %bb1.i
  64. bb1.i: ; preds = %bb.i
  65. %tmp5 = add i32 %j.0.i, 2 ; <i32> [#uses=1]
  66. %tmp6 = sext i32 %tmp5 to i64 ; <i64> [#uses=1]
  67. %tmp7 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp6 ; <i32*> [#uses=1]
  68. %tmp8 = load i32, i32* %tmp7, align 4 ; <i32> [#uses=1]
  69. %tmp9 = icmp eq i32 %tmp8, 0 ; <i1> [#uses=1]
  70. br i1 %tmp9, label %bb1.i.bb7.i.backedge_crit_edge, label %bb2.i
  71. bb2.i: ; preds = %bb1.i
  72. %tmp10 = sub i32 7, %j.0.i ; <i32> [#uses=1]
  73. %tmp11 = sext i32 %tmp10 to i64 ; <i64> [#uses=1]
  74. %tmp12 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp11 ; <i32*> [#uses=1]
  75. %tmp13 = load i32, i32* %tmp12, align 4 ; <i32> [#uses=1]
  76. %tmp14 = icmp eq i32 %tmp13, 0 ; <i1> [#uses=1]
  77. br i1 %tmp14, label %bb2.i.bb7.i.backedge_crit_edge, label %bb3.i
  78. bb3.i: ; preds = %bb2.i
  79. %tmp15 = getelementptr [9 x i32], [9 x i32]* %x1, i64 0, i64 1 ; <i32*> [#uses=1]
  80. store i32 %tmp, i32* %tmp15, align 4
  81. %tmp16 = sext i32 %tmp to i64 ; <i64> [#uses=1]
  82. %tmp17 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp16 ; <i32*> [#uses=1]
  83. store i32 0, i32* %tmp17, align 4
  84. %tmp18 = add i32 %j.0.i, 2 ; <i32> [#uses=1]
  85. %tmp19 = sext i32 %tmp18 to i64 ; <i64> [#uses=1]
  86. %tmp20 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp19 ; <i32*> [#uses=1]
  87. store i32 0, i32* %tmp20, align 4
  88. %tmp21 = sub i32 7, %j.0.i ; <i32> [#uses=1]
  89. %tmp22 = sext i32 %tmp21 to i64 ; <i64> [#uses=1]
  90. %tmp23 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp22 ; <i32*> [#uses=1]
  91. store i32 0, i32* %tmp23, align 4
  92. call void @Try(i32 2, i32* %q, i32* %b9, i32* %a10, i32* %c11, i32* %x1.sub) nounwind
  93. %tmp24 = load i32, i32* %q, align 4 ; <i32> [#uses=1]
  94. %tmp25 = icmp eq i32 %tmp24, 0 ; <i1> [#uses=1]
  95. br i1 %tmp25, label %bb5.i, label %bb3.i.bb7.i.backedge_crit_edge
  96. bb5.i: ; preds = %bb3.i
  97. %tmp26 = sext i32 %tmp to i64 ; <i64> [#uses=1]
  98. %tmp27 = getelementptr [9 x i32], [9 x i32]* %a, i64 0, i64 %tmp26 ; <i32*> [#uses=1]
  99. store i32 1, i32* %tmp27, align 4
  100. %tmp28 = add i32 %j.0.i, 2 ; <i32> [#uses=1]
  101. %tmp29 = sext i32 %tmp28 to i64 ; <i64> [#uses=1]
  102. %tmp30 = getelementptr [17 x i32], [17 x i32]* %b, i64 0, i64 %tmp29 ; <i32*> [#uses=1]
  103. store i32 1, i32* %tmp30, align 4
  104. %tmp31 = sub i32 7, %j.0.i ; <i32> [#uses=1]
  105. %tmp32 = sext i32 %tmp31 to i64 ; <i64> [#uses=1]
  106. %tmp33 = getelementptr [15 x i32], [15 x i32]* %c, i64 0, i64 %tmp32 ; <i32*> [#uses=1]
  107. store i32 1, i32* %tmp33, align 4
  108. br label %bb7.i.backedge
  109. bb7.i.backedge: ; preds = %bb3.i.bb7.i.backedge_crit_edge, %bb2.i.bb7.i.backedge_crit_edge, %bb1.i.bb7.i.backedge_crit_edge, %bb.i.bb7.i.backedge_crit_edge, %bb5.i
  110. br label %bb7.i
  111. bb7.i: ; preds = %bb7.i.backedge, %newFuncRoot
  112. %j.0.i = phi i32 [ 0, %newFuncRoot ], [ %tmp, %bb7.i.backedge ] ; <i32> [#uses=8]
  113. %tmp34 = load i32, i32* %q, align 4 ; <i32> [#uses=1]
  114. %tmp35 = icmp eq i32 %tmp34, 0 ; <i1> [#uses=1]
  115. %tmp36 = icmp ne i32 %j.0.i, 8 ; <i1> [#uses=1]
  116. %tmp37 = and i1 %tmp35, %tmp36 ; <i1> [#uses=1]
  117. br i1 %tmp37, label %bb.i, label %Try.exit.exitStub
  118. bb.i.bb7.i.backedge_crit_edge: ; preds = %bb.i
  119. br label %bb7.i.backedge
  120. bb1.i.bb7.i.backedge_crit_edge: ; preds = %bb1.i
  121. br label %bb7.i.backedge
  122. bb2.i.bb7.i.backedge_crit_edge: ; preds = %bb2.i
  123. br label %bb7.i.backedge
  124. bb3.i.bb7.i.backedge_crit_edge: ; preds = %bb3.i
  125. br label %bb7.i.backedge
  126. }