2005-12-03-IncorrectPHIFold.ll 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. ; Make sure this doesn't turn into an infinite loop
  2. ; RUN: opt < %s -simplifycfg -constprop -simplifycfg | llvm-dis | FileCheck %s
  3. %struct.anon = type { i32, i32, i32, i32, [1024 x i8] }
  4. @_zero_ = external global %struct.anon* ; <%struct.anon**> [#uses=2]
  5. @_one_ = external global %struct.anon* ; <%struct.anon**> [#uses=4]
  6. @str = internal constant [4 x i8] c"%d\0A\00" ; <[4 x i8]*> [#uses=0]
  7. declare i32 @bc_compare(%struct.anon*, %struct.anon*)
  8. declare void @free_num(%struct.anon**)
  9. declare %struct.anon* @copy_num(%struct.anon*)
  10. declare void @init_num(%struct.anon**)
  11. declare %struct.anon* @new_num(i32, i32)
  12. declare void @int2num(%struct.anon**, i32)
  13. declare void @bc_multiply(%struct.anon*, %struct.anon*, %struct.anon**, i32)
  14. declare void @bc_raise(%struct.anon*, %struct.anon*, %struct.anon**, i32)
  15. declare i32 @bc_divide(%struct.anon*, %struct.anon*, %struct.anon**, i32)
  16. declare void @bc_add(%struct.anon*, %struct.anon*, %struct.anon**)
  17. declare i32 @_do_compare(%struct.anon*, %struct.anon*, i32, i32)
  18. declare i32 @printf(i8*, ...)
  19. define i32 @bc_sqrt(%struct.anon** %num, i32 %scale) {
  20. entry:
  21. %guess = alloca %struct.anon* ; <%struct.anon**> [#uses=7]
  22. %guess1 = alloca %struct.anon* ; <%struct.anon**> [#uses=7]
  23. %point5 = alloca %struct.anon* ; <%struct.anon**> [#uses=3]
  24. %tmp = load %struct.anon*, %struct.anon** %num ; <%struct.anon*> [#uses=1]
  25. %tmp1 = load %struct.anon*, %struct.anon** @_zero_ ; <%struct.anon*> [#uses=1]
  26. %tmp.upgrd.1 = call i32 @bc_compare( %struct.anon* %tmp, %struct.anon* %tmp1 ) ; <i32> [#uses=2]
  27. %tmp.upgrd.2 = icmp slt i32 %tmp.upgrd.1, 0 ; <i1> [#uses=1]
  28. br i1 %tmp.upgrd.2, label %cond_true, label %cond_false
  29. cond_true: ; preds = %entry
  30. ret i32 0
  31. cond_false: ; preds = %entry
  32. %tmp5 = icmp eq i32 %tmp.upgrd.1, 0 ; <i1> [#uses=1]
  33. br i1 %tmp5, label %cond_true6, label %cond_next13
  34. cond_true6: ; preds = %cond_false
  35. call void @free_num( %struct.anon** %num )
  36. %tmp8 = load %struct.anon*, %struct.anon** @_zero_ ; <%struct.anon*> [#uses=1]
  37. %tmp9 = call %struct.anon* @copy_num( %struct.anon* %tmp8 ) ; <%struct.anon*> [#uses=1]
  38. store %struct.anon* %tmp9, %struct.anon** %num
  39. ret i32 1
  40. cond_next13: ; preds = %cond_false
  41. %tmp15 = load %struct.anon*, %struct.anon** %num ; <%struct.anon*> [#uses=1]
  42. %tmp16 = load %struct.anon*, %struct.anon** @_one_ ; <%struct.anon*> [#uses=1]
  43. %tmp17 = call i32 @bc_compare( %struct.anon* %tmp15, %struct.anon* %tmp16 ) ; <i32> [#uses=2]
  44. %tmp19 = icmp eq i32 %tmp17, 0 ; <i1> [#uses=1]
  45. br i1 %tmp19, label %cond_true20, label %cond_next27
  46. cond_true20: ; preds = %cond_next13
  47. call void @free_num( %struct.anon** %num )
  48. %tmp22 = load %struct.anon*, %struct.anon** @_one_ ; <%struct.anon*> [#uses=1]
  49. %tmp23 = call %struct.anon* @copy_num( %struct.anon* %tmp22 ) ; <%struct.anon*> [#uses=1]
  50. store %struct.anon* %tmp23, %struct.anon** %num
  51. ret i32 1
  52. cond_next27: ; preds = %cond_next13
  53. %tmp29 = load %struct.anon*, %struct.anon** %num ; <%struct.anon*> [#uses=1]
  54. %tmp30 = getelementptr %struct.anon, %struct.anon* %tmp29, i32 0, i32 2 ; <i32*> [#uses=1]
  55. %tmp31 = load i32, i32* %tmp30 ; <i32> [#uses=2]
  56. %tmp33 = icmp sge i32 %tmp31, %scale ; <i1> [#uses=1]
  57. %max = select i1 %tmp33, i32 %tmp31, i32 %scale ; <i32> [#uses=4]
  58. %tmp35 = add i32 %max, 2 ; <i32> [#uses=0]
  59. call void @init_num( %struct.anon** %guess )
  60. call void @init_num( %struct.anon** %guess1 )
  61. %tmp36 = call %struct.anon* @new_num( i32 1, i32 1 ) ; <%struct.anon*> [#uses=2]
  62. store %struct.anon* %tmp36, %struct.anon** %point5
  63. %tmp.upgrd.3 = getelementptr %struct.anon, %struct.anon* %tmp36, i32 0, i32 4, i32 1 ; <i8*> [#uses=1]
  64. store i8 5, i8* %tmp.upgrd.3
  65. %tmp39 = icmp slt i32 %tmp17, 0 ; <i1> [#uses=1]
  66. br i1 %tmp39, label %cond_true40, label %cond_false43
  67. cond_true40: ; preds = %cond_next27
  68. %tmp41 = load %struct.anon*, %struct.anon** @_one_ ; <%struct.anon*> [#uses=1]
  69. %tmp42 = call %struct.anon* @copy_num( %struct.anon* %tmp41 ) ; <%struct.anon*> [#uses=1]
  70. store %struct.anon* %tmp42, %struct.anon** %guess
  71. br label %bb80.outer
  72. cond_false43: ; preds = %cond_next27
  73. call void @int2num( %struct.anon** %guess, i32 10 )
  74. %tmp45 = load %struct.anon*, %struct.anon** %num ; <%struct.anon*> [#uses=1]
  75. %tmp46 = getelementptr %struct.anon, %struct.anon* %tmp45, i32 0, i32 1 ; <i32*> [#uses=1]
  76. %tmp47 = load i32, i32* %tmp46 ; <i32> [#uses=1]
  77. call void @int2num( %struct.anon** %guess1, i32 %tmp47 )
  78. %tmp48 = load %struct.anon*, %struct.anon** %guess1 ; <%struct.anon*> [#uses=1]
  79. %tmp49 = load %struct.anon*, %struct.anon** %point5 ; <%struct.anon*> [#uses=1]
  80. call void @bc_multiply( %struct.anon* %tmp48, %struct.anon* %tmp49, %struct.anon** %guess1, i32 %max )
  81. %tmp51 = load %struct.anon*, %struct.anon** %guess1 ; <%struct.anon*> [#uses=1]
  82. %tmp52 = getelementptr %struct.anon, %struct.anon* %tmp51, i32 0, i32 2 ; <i32*> [#uses=1]
  83. store i32 0, i32* %tmp52
  84. %tmp53 = load %struct.anon*, %struct.anon** %guess ; <%struct.anon*> [#uses=1]
  85. %tmp54 = load %struct.anon*, %struct.anon** %guess1 ; <%struct.anon*> [#uses=1]
  86. call void @bc_raise( %struct.anon* %tmp53, %struct.anon* %tmp54, %struct.anon** %guess, i32 %max )
  87. br label %bb80.outer
  88. bb80.outer: ; preds = %cond_true83, %cond_false43, %cond_true40
  89. %done.1.ph = phi i32 [ 1, %cond_true83 ], [ 0, %cond_true40 ], [ 0, %cond_false43 ] ; <i32> [#uses=1]
  90. br label %bb80
  91. bb80: ; preds = %cond_true83, %bb80.outer
  92. %tmp82 = icmp eq i32 %done.1.ph, 0 ; <i1> [#uses=1]
  93. br i1 %tmp82, label %cond_true83, label %bb86
  94. cond_true83: ; preds = %bb80
  95. %tmp71 = call i32 @_do_compare( %struct.anon* null, %struct.anon* null, i32 0, i32 1 ) ; <i32> [#uses=1]
  96. %tmp76 = icmp eq i32 %tmp71, 0 ; <i1> [#uses=1]
  97. br i1 %tmp76, label %bb80.outer, label %bb80
  98. ; CHECK: bb86
  99. bb86: ; preds = %bb80
  100. call void @free_num( %struct.anon** %num )
  101. %tmp88 = load %struct.anon*, %struct.anon** %guess ; <%struct.anon*> [#uses=1]
  102. %tmp89 = load %struct.anon*, %struct.anon** @_one_ ; <%struct.anon*> [#uses=1]
  103. %tmp92 = call i32 @bc_divide( %struct.anon* %tmp88, %struct.anon* %tmp89, %struct.anon** %num, i32 %max ) ; <i32> [#uses=0]
  104. call void @free_num( %struct.anon** %guess )
  105. call void @free_num( %struct.anon** %guess1 )
  106. call void @free_num( %struct.anon** %point5 )
  107. ret i32 1
  108. }