cf132.ll 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. ; RUN: %opt-exe %s -scopenested -scopenestinfo -analyze -S | %FileCheck %s
  2. ; CHECK: ScopeNestInfo:
  3. ; CHECK: @TopLevel_Begin
  4. ; CHECK: entry
  5. ; CHECK: @Loop_Begin
  6. ; CHECK: loop0
  7. ; CHECK: @If_Begin
  8. ; CHECK: dx.LoopExitHelper
  9. ; CHECK: @Loop_Break
  10. ; CHECK: @If_Else
  11. ; CHECK: loop0.body1
  12. ; CHECK: @Switch_Begin
  13. ; CHECK: @Switch_Case
  14. ; CHECK: switch0.default
  15. ; CHECK: switch0.end
  16. ; CHECK: dx.SwitchBreak
  17. ; CHECK: @Switch_Break
  18. ; CHECK: @Switch_Break
  19. ; CHECK: @Switch_Case
  20. ; CHECK: switch0.case0
  21. ; CHECK: switch0.end.3
  22. ; CHECK: dx.SwitchBreak.4
  23. ; CHECK: @Switch_Break
  24. ; CHECK: @Switch_Break
  25. ; CHECK: @Switch_Case
  26. ; CHECK: switch0.case1
  27. ; CHECK: dx.SwitchBreak.5
  28. ; CHECK: @Switch_Break
  29. ; CHECK: @Switch_Break
  30. ; CHECK: @Switch_Case
  31. ; CHECK: switch0.case2
  32. ; CHECK: switch0.end.8
  33. ; CHECK: dx.SwitchBreak.9
  34. ; CHECK: @Switch_Break
  35. ; CHECK: @Switch_Break
  36. ; CHECK: @Switch_End
  37. ; CHECK: dx.EndSwitchScope
  38. ; CHECK: loop0.latch
  39. ; CHECK: dx.LoopContinue
  40. ; CHECK: @Loop_Continue
  41. ; CHECK: @If_End
  42. ; CHECK: dx.LoopLatch
  43. ; CHECK: @Loop_End
  44. ; CHECK: dx.LoopExit
  45. ; CHECK: loop0.exit
  46. ; CHECK: @TopLevel_End
  47. define i32 @main(i1 %c1, i1 %c2, i1 %c3, i32 %i1, i32 %i2) {
  48. entry:
  49. %res = alloca i32
  50. store i32 1, i32 *%res
  51. br label %loop0
  52. loop0:
  53. %loop0.0 = load i32, i32 *%res
  54. %loop0.1 = icmp eq i32 %loop0.0, 20
  55. br i1 %loop0.1, label %loop0.exit, label %loop0.body1
  56. ;loop0.body0:
  57. ; %cond2 = icmp eq i32 %i2, 10
  58. ; br i1 %cond2, label %loop0.body1, label %loop0.latch
  59. loop0.body1:
  60. ;;--------------
  61. switch i32 %i1, label %switch0.default [ i32 0, label %switch0.case0
  62. i32 1, label %switch0.case1
  63. i32 12, label %switch0.case2
  64. i32 32, label %switch0.default
  65. i32 21, label %switch0.case1
  66. i32 33, label %switch0.default
  67. i32 11, label %switch0.case1
  68. i32 2, label %switch0.case2
  69. ]
  70. switch0.case0:
  71. store i32 0, i32 *%res
  72. br label %switch0.end
  73. switch0.case1:
  74. store i32 22, i32 *%res
  75. br label %loop0.latch
  76. switch0.case2:
  77. store i32 2, i32 *%res
  78. br label %switch0.end
  79. switch0.default:
  80. store i32 -1, i32 *%res
  81. br label %switch0.end
  82. switch0.end:
  83. %switch0.0 = load i32, i32 *%res
  84. %switch0.1 = add i32 %switch0.0, 1
  85. store i32 %switch0.1, i32 *%res
  86. br label %loop0.latch
  87. ;;-----------
  88. loop0.latch:
  89. store i32 %i2, i32 *%res
  90. br label %loop0
  91. loop0.exit:
  92. %loop0.2 = load i32, i32 *%res
  93. %loop0.3 = add i32 %loop0.2, 1
  94. store i32 %loop0.3, i32 *%res
  95. ret i32 %loop0.3
  96. }