cf085.ll 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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.latch
  12. ; CHECK: dx.LoopContinue
  13. ; CHECK: @Loop_Continue
  14. ; CHECK: @If_End
  15. ; CHECK: dx.LoopLatch
  16. ; CHECK: @Loop_End
  17. ; CHECK: dx.LoopExit
  18. ; CHECK: switch0
  19. ; CHECK: @Switch_Begin
  20. ; CHECK: @Switch_Case
  21. ; CHECK: switch0.default
  22. ; CHECK: dx.SwitchBreak
  23. ; CHECK: @Switch_Break
  24. ; CHECK: @Switch_Break
  25. ; CHECK: @Switch_Case
  26. ; CHECK: switch0.case0
  27. ; CHECK: dx.SwitchBreak.1
  28. ; CHECK: @Switch_Break
  29. ; CHECK: @Switch_Break
  30. ; CHECK: @Switch_Case
  31. ; CHECK: switch0.case1
  32. ; CHECK: dx.SwitchBreak.2
  33. ; CHECK: @Switch_Break
  34. ; CHECK: @Switch_Break
  35. ; CHECK: @Switch_Case
  36. ; CHECK: switch0.case2
  37. ; CHECK: dx.SwitchBreak.3
  38. ; CHECK: @Switch_Break
  39. ; CHECK: @Switch_Break
  40. ; CHECK: @Switch_End
  41. ; CHECK: dx.EndSwitchScope
  42. ; CHECK: switch0.end
  43. ; CHECK: @TopLevel_End
  44. define i32 @main(i1 %c1, i1 %c2, i1 %c3, i32 %i1, i32 %i2) {
  45. entry:
  46. %res = alloca i32
  47. store i32 1, i32 *%res
  48. br label %loop0
  49. loop0:
  50. %loop0.0 = load i32, i32 *%res
  51. %loop0.1 = icmp eq i32 %loop0.0, 20
  52. br i1 %loop0.1, label %switch0, label %loop0.latch
  53. loop0.latch:
  54. store i32 %i2, i32 *%res
  55. br label %loop0
  56. switch0:
  57. switch i32 %i1, label %switch0.default [ i32 0, label %switch0.case0
  58. i32 1, label %switch0.case1
  59. i32 2, label %switch0.case2 ]
  60. switch0.case0:
  61. store i32 0, i32 *%res
  62. br label %switch0.end
  63. switch0.case1:
  64. store i32 1, i32 *%res
  65. br label %switch0.end
  66. switch0.case2:
  67. store i32 2, i32 *%res
  68. br label %switch0.end
  69. switch0.default:
  70. store i32 -1, i32 *%res
  71. br label %switch0.end
  72. switch0.end:
  73. %0 = load i32, i32 *%res
  74. ret i32 %0
  75. }