MagicPointer.ll 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. ; Test that simplifycfg can create switch instructions from constant pointers.
  2. ;
  3. ; RUN: opt < %s -simplifycfg -S | FileCheck %s
  4. target datalayout = "e-p:64:64:64-p1:16:16:16-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
  5. target triple = "x86_64-apple-darwin10.0.0"
  6. @.str = private constant [5 x i8] c"null\00" ; <[5 x i8]*> [#uses=2]
  7. @.str1 = private constant [4 x i8] c"one\00" ; <[4 x i8]*> [#uses=2]
  8. @.str2 = private constant [4 x i8] c"two\00" ; <[4 x i8]*> [#uses=2]
  9. @.str3 = private constant [5 x i8] c"four\00" ; <[5 x i8]*> [#uses=2]
  10. @.str_as1 = private addrspace(1) constant [5 x i8] c"null\00" ; <[5 x i8]*> [#uses=2]
  11. @.str1_as1 = private addrspace(1) constant [4 x i8] c"one\00" ; <[4 x i8]*> [#uses=2]
  12. @.str2_as1 = private addrspace(1) constant [4 x i8] c"two\00" ; <[4 x i8]*> [#uses=2]
  13. @.str3_as1 = private addrspace(1) constant [5 x i8] c"four\00" ; <[5 x i8]*> [#uses=2]
  14. declare i32 @puts(i8*)
  15. declare i32 @puts_as1(i8 addrspace(1)*)
  16. define void @f(i8* %x) nounwind ssp {
  17. ; CHECK-LABEL: @f(
  18. ; CHECK: switch i64 %magicptr
  19. ; CHECK: i64 0, label
  20. ; CHECK: i64 1, label
  21. ; CHECK: i64 2, label
  22. ; CHECK: i64 3, label
  23. ; CHECK: i64 4, label
  24. ; CHECK: }
  25. entry:
  26. %tobool = icmp eq i8* %x, null ; <i1> [#uses=1]
  27. br i1 %tobool, label %if.then, label %if.else
  28. if.then: ; preds = %entry
  29. %call = call i32 @puts(i8* getelementptr inbounds ([5 x i8], [5 x i8]* @.str, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  30. br label %if.end21
  31. if.else: ; preds = %entry
  32. %cmp = icmp eq i8* %x, inttoptr (i64 1 to i8*) ; <i1> [#uses=1]
  33. br i1 %cmp, label %if.then2, label %if.else4
  34. if.then2: ; preds = %if.else
  35. %call3 = call i32 @puts(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str1, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  36. br label %if.end20
  37. if.else4: ; preds = %if.else
  38. %cmp6 = icmp eq i8* %x, inttoptr (i64 2 to i8*) ; <i1> [#uses=1]
  39. br i1 %cmp6, label %if.then9, label %lor.lhs.false
  40. lor.lhs.false: ; preds = %if.else4
  41. %cmp8 = icmp eq i8* %x, inttoptr (i64 3 to i8*) ; <i1> [#uses=1]
  42. br i1 %cmp8, label %if.then9, label %if.else11
  43. if.then9: ; preds = %lor.lhs.false, %if.else4
  44. %call10 = call i32 @puts(i8* getelementptr inbounds ([4 x i8], [4 x i8]* @.str2, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  45. br label %if.end19
  46. if.else11: ; preds = %lor.lhs.false
  47. %cmp13 = icmp eq i8* %x, inttoptr (i64 4 to i8*) ; <i1> [#uses=1]
  48. br i1 %cmp13, label %if.then14, label %if.else16
  49. if.then14: ; preds = %if.else11
  50. %call15 = call i32 @puts(i8* getelementptr inbounds ([5 x i8], [5 x i8]* @.str3, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  51. br label %if.end
  52. if.else16: ; preds = %if.else11
  53. %call18 = call i32 @puts(i8* %x) nounwind ; <i32> [#uses=0]
  54. br label %if.end
  55. if.end: ; preds = %if.else16, %if.then14
  56. br label %if.end19
  57. if.end19: ; preds = %if.end, %if.then9
  58. br label %if.end20
  59. if.end20: ; preds = %if.end19, %if.then2
  60. br label %if.end21
  61. if.end21: ; preds = %if.end20, %if.then
  62. ret void
  63. }
  64. ; Is it useful to test a version where the ptrtoints are to the same
  65. ; size?
  66. define void @f_as1(i8 addrspace(1)* %x) nounwind ssp {
  67. ; CHECK-LABEL: @f_as1(
  68. ; CHECK: ptrtoint i8 addrspace(1)* %x to i16
  69. ; CHECK: switch i16 %magicptr
  70. ; CHECK: i16 0, label
  71. ; CHECK: i16 1, label
  72. ; CHECK: i16 2, label
  73. ; CHECK: i16 3, label
  74. ; CHECK: i16 4, label
  75. ; CHECK: }
  76. entry:
  77. %tobool = icmp eq i8 addrspace(1)* %x, null ; <i1> [#uses=1]
  78. br i1 %tobool, label %if.then, label %if.else
  79. if.then: ; preds = %entry
  80. %call = call i32 @puts_as1(i8 addrspace(1)* getelementptr inbounds ([5 x i8], [5 x i8] addrspace(1)* @.str_as1, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  81. br label %if.end21
  82. if.else: ; preds = %entry
  83. %cmp = icmp eq i8 addrspace(1)* %x, inttoptr (i64 1 to i8 addrspace(1)*) ; <i1> [#uses=1]
  84. br i1 %cmp, label %if.then2, label %if.else4
  85. if.then2: ; preds = %if.else
  86. %call3 = call i32 @puts_as1(i8 addrspace(1)* getelementptr inbounds ([4 x i8], [4 x i8] addrspace(1)* @.str1_as1, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  87. br label %if.end20
  88. if.else4: ; preds = %if.else
  89. %cmp6 = icmp eq i8 addrspace(1)* %x, inttoptr (i64 2 to i8 addrspace(1)*) ; <i1> [#uses=1]
  90. br i1 %cmp6, label %if.then9, label %lor.lhs.false
  91. lor.lhs.false: ; preds = %if.else4
  92. %cmp8 = icmp eq i8 addrspace(1)* %x, inttoptr (i64 3 to i8 addrspace(1)*) ; <i1> [#uses=1]
  93. br i1 %cmp8, label %if.then9, label %if.else11
  94. if.then9: ; preds = %lor.lhs.false, %if.else4
  95. %call10 = call i32 @puts_as1(i8 addrspace(1)* getelementptr inbounds ([4 x i8], [4 x i8] addrspace(1)* @.str2_as1, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  96. br label %if.end19
  97. if.else11: ; preds = %lor.lhs.false
  98. %cmp13 = icmp eq i8 addrspace(1)* %x, inttoptr (i64 4 to i8 addrspace(1)*) ; <i1> [#uses=1]
  99. br i1 %cmp13, label %if.then14, label %if.else16
  100. if.then14: ; preds = %if.else11
  101. %call15 = call i32 @puts_as1(i8 addrspace(1)* getelementptr inbounds ([5 x i8], [5 x i8] addrspace(1)* @.str3_as1, i64 0, i64 0)) nounwind ; <i32> [#uses=0]
  102. br label %if.end
  103. if.else16: ; preds = %if.else11
  104. %call18 = call i32 @puts_as1(i8 addrspace(1)* %x) nounwind ; <i32> [#uses=0]
  105. br label %if.end
  106. if.end: ; preds = %if.else16, %if.then14
  107. br label %if.end19
  108. if.end19: ; preds = %if.end, %if.then9
  109. br label %if.end20
  110. if.end20: ; preds = %if.end19, %if.then2
  111. br label %if.end21
  112. if.end21: ; preds = %if.end20, %if.then
  113. ret void
  114. }