2011-10-03-CritEdgeMerge.ll 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. ; RUN: opt -loop-reduce -S < %s | FileCheck %s
  2. ;
  3. ; Test LSR's use of SplitCriticalEdge during phi rewriting.
  4. target triple = "x86-apple-darwin"
  5. ; Provide legal integer types.
  6. target datalayout = "n8:16:32:64"
  7. ; Verify that identical edges are merged. rdar://problem/6453893
  8. ; CHECK-LABEL: @test1(
  9. ; CHECK: bb89:
  10. ; CHECK: phi i8* [ %lsr.iv.next1, %bbA.bb89_crit_edge ], [ %lsr.iv.next1, %bbB.bb89_crit_edge ]{{$}}
  11. define i8* @test1() {
  12. entry:
  13. br label %loop
  14. loop:
  15. %rec = phi i32 [ %next, %loop ], [ 0, %entry ]
  16. %next = add i32 %rec, 1
  17. %tmp75 = getelementptr i8, i8* null, i32 %next
  18. br i1 false, label %loop, label %loopexit
  19. loopexit:
  20. br i1 false, label %bbA, label %bbB
  21. bbA:
  22. switch i32 0, label %bb89 [
  23. i32 47, label %bb89
  24. i32 58, label %bb89
  25. ]
  26. bbB:
  27. switch i8 0, label %bb89 [
  28. i8 47, label %bb89
  29. i8 58, label %bb89
  30. ]
  31. bb89:
  32. %tmp75phi = phi i8* [ %tmp75, %bbA ], [ %tmp75, %bbA ], [ %tmp75, %bbA ], [ %tmp75, %bbB ], [ %tmp75, %bbB ], [ %tmp75, %bbB ]
  33. br label %exit
  34. exit:
  35. ret i8* %tmp75phi
  36. }
  37. ; Handle single-predecessor phis: PR13756
  38. ; CHECK-LABEL: @test2(
  39. ; CHECK: bb89:
  40. ; CHECK: phi i8* [ %lsr.iv.next1, %bbA ], [ %lsr.iv.next1, %bbA ], [ %lsr.iv.next1, %bbA ]{{$}}
  41. define i8* @test2() {
  42. entry:
  43. br label %loop
  44. loop:
  45. %rec = phi i32 [ %next, %loop ], [ 0, %entry ]
  46. %next = add i32 %rec, 1
  47. %tmp75 = getelementptr i8, i8* null, i32 %next
  48. br i1 false, label %loop, label %loopexit
  49. loopexit:
  50. br i1 false, label %bbA, label %bbB
  51. bbA:
  52. switch i32 0, label %bb89 [
  53. i32 47, label %bb89
  54. i32 58, label %bb89
  55. ]
  56. bbB:
  57. switch i8 0, label %exit [
  58. i8 47, label %exit
  59. i8 58, label %exit
  60. ]
  61. bb89:
  62. %tmp75phi = phi i8* [ %tmp75, %bbA ], [ %tmp75, %bbA ], [ %tmp75, %bbA ]
  63. br label %exit
  64. exit:
  65. %result = phi i8* [ %tmp75phi, %bb89 ], [ %tmp75, %bbB ], [ %tmp75, %bbB ], [ %tmp75, %bbB ]
  66. ret i8* %result
  67. }