preserve-analyses.ll 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. ; RUN: opt -loop-unswitch -verify-loop-info -verify-dom-info -disable-output < %s
  2. ; Loop unswitch should be able to unswitch these loops and
  3. ; preserve LCSSA and LoopSimplify forms.
  4. target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:64"
  5. target triple = "armv6-apple-darwin9"
  6. @delim1 = external global i32 ; <i32*> [#uses=1]
  7. @delim2 = external global i32 ; <i32*> [#uses=1]
  8. define i32 @ineqn(i8* %s, i8* %p) nounwind readonly {
  9. entry:
  10. %0 = load i32, i32* @delim1, align 4 ; <i32> [#uses=1]
  11. %1 = load i32, i32* @delim2, align 4 ; <i32> [#uses=1]
  12. br label %bb8.outer
  13. bb: ; preds = %bb8
  14. %2 = icmp eq i8* %p_addr.0, %s ; <i1> [#uses=1]
  15. br i1 %2, label %bb10, label %bb2
  16. bb2: ; preds = %bb
  17. %3 = getelementptr inbounds i8, i8* %p_addr.0, i32 1 ; <i8*> [#uses=3]
  18. switch i32 %ineq.0.ph, label %bb8.backedge [
  19. i32 0, label %bb3
  20. i32 1, label %bb6
  21. ]
  22. bb8.backedge: ; preds = %bb6, %bb5, %bb2
  23. br label %bb8
  24. bb3: ; preds = %bb2
  25. %4 = icmp eq i32 %8, %0 ; <i1> [#uses=1]
  26. br i1 %4, label %bb8.outer.loopexit, label %bb5
  27. bb5: ; preds = %bb3
  28. br i1 %6, label %bb6, label %bb8.backedge
  29. bb6: ; preds = %bb5, %bb2
  30. %5 = icmp eq i32 %8, %1 ; <i1> [#uses=1]
  31. br i1 %5, label %bb7, label %bb8.backedge
  32. bb7: ; preds = %bb6
  33. %.lcssa1 = phi i8* [ %3, %bb6 ] ; <i8*> [#uses=1]
  34. br label %bb8.outer.backedge
  35. bb8.outer.backedge: ; preds = %bb8.outer.loopexit, %bb7
  36. %.lcssa2 = phi i8* [ %.lcssa1, %bb7 ], [ %.lcssa, %bb8.outer.loopexit ] ; <i8*> [#uses=1]
  37. %ineq.0.ph.be = phi i32 [ 0, %bb7 ], [ 1, %bb8.outer.loopexit ] ; <i32> [#uses=1]
  38. br label %bb8.outer
  39. bb8.outer.loopexit: ; preds = %bb3
  40. %.lcssa = phi i8* [ %3, %bb3 ] ; <i8*> [#uses=1]
  41. br label %bb8.outer.backedge
  42. bb8.outer: ; preds = %bb8.outer.backedge, %entry
  43. %ineq.0.ph = phi i32 [ 0, %entry ], [ %ineq.0.ph.be, %bb8.outer.backedge ] ; <i32> [#uses=3]
  44. %p_addr.0.ph = phi i8* [ %p, %entry ], [ %.lcssa2, %bb8.outer.backedge ] ; <i8*> [#uses=1]
  45. %6 = icmp eq i32 %ineq.0.ph, 1 ; <i1> [#uses=1]
  46. br label %bb8
  47. bb8: ; preds = %bb8.outer, %bb8.backedge
  48. %p_addr.0 = phi i8* [ %p_addr.0.ph, %bb8.outer ], [ %3, %bb8.backedge ] ; <i8*> [#uses=3]
  49. %7 = load i8, i8* %p_addr.0, align 1 ; <i8> [#uses=2]
  50. %8 = sext i8 %7 to i32 ; <i32> [#uses=2]
  51. %9 = icmp eq i8 %7, 0 ; <i1> [#uses=1]
  52. br i1 %9, label %bb10, label %bb
  53. bb10: ; preds = %bb8, %bb
  54. %.0 = phi i32 [ %ineq.0.ph, %bb ], [ 0, %bb8 ] ; <i32> [#uses=1]
  55. ret i32 %.0
  56. }
  57. ; This is a simplified form of ineqn from above. It triggers some
  58. ; different cases in the loop-unswitch code.
  59. define void @simplified_ineqn() nounwind readonly {
  60. entry:
  61. br label %bb8.outer
  62. bb8.outer: ; preds = %bb6, %bb2, %entry
  63. %x = phi i32 [ 0, %entry ], [ 0, %bb6 ], [ 1, %bb2 ] ; <i32> [#uses=1]
  64. br i1 undef, label %return, label %bb2
  65. bb2: ; preds = %bb
  66. switch i32 %x, label %bb6 [
  67. i32 0, label %bb8.outer
  68. ]
  69. bb6: ; preds = %bb2
  70. br i1 undef, label %bb8.outer, label %bb2
  71. return: ; preds = %bb8, %bb
  72. ret void
  73. }
  74. ; This function requires special handling to preserve LCSSA form.
  75. ; PR4934
  76. define void @pnp_check_irq() nounwind noredzone {
  77. entry:
  78. %conv56 = trunc i64 undef to i32 ; <i32> [#uses=1]
  79. br label %while.cond.i
  80. while.cond.i: ; preds = %while.cond.i.backedge, %entry
  81. %call.i25 = call i8* @pci_get_device() nounwind noredzone ; <i8*> [#uses=2]
  82. br i1 undef, label %if.then65, label %while.body.i
  83. while.body.i: ; preds = %while.cond.i
  84. br i1 undef, label %if.then31.i.i, label %while.cond.i.backedge
  85. while.cond.i.backedge: ; preds = %if.then31.i.i, %while.body.i
  86. br label %while.cond.i
  87. if.then31.i.i: ; preds = %while.body.i
  88. switch i32 %conv56, label %while.cond.i.backedge [
  89. i32 14, label %if.then42.i.i
  90. i32 15, label %if.then42.i.i
  91. ]
  92. if.then42.i.i: ; preds = %if.then31.i.i, %if.then31.i.i
  93. %call.i25.lcssa48 = phi i8* [ %call.i25, %if.then31.i.i ], [ %call.i25, %if.then31.i.i ] ; <i8*> [#uses=0]
  94. unreachable
  95. if.then65: ; preds = %while.cond.i
  96. unreachable
  97. }
  98. declare i8* @pci_get_device() noredzone