preserve-branchweights-switch-create.ll 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. ; RUN: opt -simplifycfg -S -o - < %s | FileCheck %s
  2. declare void @func2(i32)
  3. declare void @func4(i32)
  4. declare void @func6(i32)
  5. declare void @func8(i32)
  6. ;; test1 - create a switch with case 2 and case 4 from two branches: N == 2
  7. ;; and N == 4.
  8. define void @test1(i32 %N) nounwind uwtable {
  9. entry:
  10. %cmp = icmp eq i32 %N, 2
  11. br i1 %cmp, label %if.then, label %if.else, !prof !0
  12. ; CHECK: test1
  13. ; CHECK: switch i32 %N
  14. ; CHECK: ], !prof !0
  15. if.then:
  16. call void @func2(i32 %N) nounwind
  17. br label %if.end9
  18. if.else:
  19. %cmp2 = icmp eq i32 %N, 4
  20. br i1 %cmp2, label %if.then7, label %if.else8, !prof !1
  21. if.then7:
  22. call void @func4(i32 %N) nounwind
  23. br label %if.end
  24. if.else8:
  25. call void @func8(i32 %N) nounwind
  26. br label %if.end
  27. if.end:
  28. br label %if.end9
  29. if.end9:
  30. ret void
  31. }
  32. ;; test2 - Merge two switches where PredDefault == BB.
  33. define void @test2(i32 %M, i32 %N) nounwind uwtable {
  34. entry:
  35. %cmp = icmp sgt i32 %M, 2
  36. br i1 %cmp, label %sw1, label %sw2
  37. sw1:
  38. switch i32 %N, label %sw2 [
  39. i32 2, label %sw.bb
  40. i32 3, label %sw.bb1
  41. ], !prof !2
  42. ; CHECK: test2
  43. ; CHECK: switch i32 %N, label %sw.epilog
  44. ; CHECK: i32 2, label %sw.bb
  45. ; CHECK: i32 3, label %sw.bb1
  46. ; CHECK: i32 4, label %sw.bb5
  47. ; CHECK: ], !prof !1
  48. sw.bb:
  49. call void @func2(i32 %N) nounwind
  50. br label %sw.epilog
  51. sw.bb1:
  52. call void @func4(i32 %N) nounwind
  53. br label %sw.epilog
  54. sw2:
  55. ;; Here "case 2" is invalidated if control is transferred through default case
  56. ;; of the first switch.
  57. switch i32 %N, label %sw.epilog [
  58. i32 2, label %sw.bb4
  59. i32 4, label %sw.bb5
  60. ], !prof !3
  61. sw.bb4:
  62. call void @func6(i32 %N) nounwind
  63. br label %sw.epilog
  64. sw.bb5:
  65. call void @func8(i32 %N) nounwind
  66. br label %sw.epilog
  67. sw.epilog:
  68. ret void
  69. }
  70. ;; test3 - Merge two switches where PredDefault != BB.
  71. define void @test3(i32 %M, i32 %N) nounwind uwtable {
  72. entry:
  73. %cmp = icmp sgt i32 %M, 2
  74. br i1 %cmp, label %sw1, label %sw2
  75. sw1:
  76. switch i32 %N, label %sw.bb [
  77. i32 2, label %sw2
  78. i32 3, label %sw2
  79. i32 1, label %sw.bb1
  80. ], !prof !4
  81. ; CHECK: test3
  82. ; CHECK: switch i32 %N, label %sw.bb
  83. ; CHECK: i32 1, label %sw.bb1
  84. ; CHECK: i32 3, label %sw.bb4
  85. ; CHECK: i32 2, label %sw.epilog
  86. ; CHECK: ], !prof !3
  87. sw.bb:
  88. call void @func2(i32 %N) nounwind
  89. br label %sw.epilog
  90. sw.bb1:
  91. call void @func4(i32 %N) nounwind
  92. br label %sw.epilog
  93. sw2:
  94. switch i32 %N, label %sw.epilog [
  95. i32 3, label %sw.bb4
  96. i32 4, label %sw.bb5
  97. ], !prof !5
  98. sw.bb4:
  99. call void @func6(i32 %N) nounwind
  100. br label %sw.epilog
  101. sw.bb5:
  102. call void @func8(i32 %N) nounwind
  103. br label %sw.epilog
  104. sw.epilog:
  105. ret void
  106. }
  107. !0 = !{!"branch_weights", i32 64, i32 4}
  108. !1 = !{!"branch_weights", i32 4, i32 64}
  109. ; CHECK: !0 = !{!"branch_weights", i32 256, i32 4352, i32 16}
  110. !2 = !{!"branch_weights", i32 4, i32 4, i32 8}
  111. !3 = !{!"branch_weights", i32 8, i32 8, i32 4}
  112. ; CHECK: !1 = !{!"branch_weights", i32 32, i32 48, i32 96, i32 16}
  113. !4 = !{!"branch_weights", i32 7, i32 6, i32 4, i32 3}
  114. !5 = !{!"branch_weights", i32 17, i32 13, i32 9}
  115. ; CHECK: !3 = !{!"branch_weights", i32 7, i32 3, i32 4, i32 6}