cf080.ll 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. ; RUN: %opt-exe %s -scopenested -scopenestinfo -analyze -S | %FileCheck %s
  2. ; CHECK: ScopeNestInfo:
  3. ; CHECK: @TopLevel_Begin
  4. ; CHECK: entry
  5. ; CHECK: @If_Begin
  6. ; CHECK: if0.T
  7. ; CHECK: @If_Else
  8. ; CHECK: if0.F
  9. ; CHECK: @If_End
  10. ; CHECK: dx.EndIfScope
  11. ; CHECK: switch0
  12. ; CHECK: @Switch_Begin
  13. ; CHECK: @Switch_Case
  14. ; CHECK: switch0.default
  15. ; CHECK: dx.SwitchBreak
  16. ; CHECK: @Switch_Break
  17. ; CHECK: @Switch_Break
  18. ; CHECK: @Switch_Case
  19. ; CHECK: switch0.case0
  20. ; CHECK: dx.SwitchBreak.1
  21. ; CHECK: @Switch_Break
  22. ; CHECK: @Switch_Break
  23. ; CHECK: @Switch_Case
  24. ; CHECK: switch0.case1
  25. ; CHECK: dx.SwitchBreak.2
  26. ; CHECK: @Switch_Break
  27. ; CHECK: @Switch_Break
  28. ; CHECK: @Switch_Case
  29. ; CHECK: switch0.case2
  30. ; CHECK: dx.SwitchBreak.3
  31. ; CHECK: @Switch_Break
  32. ; CHECK: @Switch_Break
  33. ; CHECK: @Switch_End
  34. ; CHECK: dx.EndSwitchScope
  35. ; CHECK: switch0.end
  36. ; CHECK: @TopLevel_End
  37. define i32 @main(i1 %c1, i1 %c2, i1 %c3, i32 %i1, i32 %i2) {
  38. entry:
  39. %res = alloca i32
  40. store i32 1, i32 *%res
  41. br i1 %c1, label %if0.T, label %if0.F
  42. if0.T:
  43. store i32 20, i32 *%res
  44. br label %switch0
  45. if0.F:
  46. store i32 21, i32 *%res
  47. br label %switch0
  48. switch0:
  49. switch i32 %i1, label %switch0.default [ i32 0, label %switch0.case0
  50. i32 1, label %switch0.case1
  51. i32 2, label %switch0.case2 ]
  52. switch0.case0:
  53. store i32 0, i32 *%res
  54. br label %switch0.end
  55. switch0.case1:
  56. store i32 1, i32 *%res
  57. br label %switch0.end
  58. switch0.case2:
  59. store i32 2, i32 *%res
  60. br label %switch0.end
  61. switch0.default:
  62. store i32 -1, i32 *%res
  63. br label %switch0.end
  64. switch0.end:
  65. %0 = load i32, i32 *%res
  66. ret i32 %0
  67. }