simple.ll 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. ; RUN: opt -S -lowerbitsets < %s | FileCheck %s
  2. ; RUN: opt -S -lowerbitsets -mtriple=x86_64-apple-macosx10.8.0 < %s | FileCheck -check-prefix=CHECK-DARWIN %s
  3. ; RUN: opt -S -O3 < %s | FileCheck -check-prefix=CHECK-NODISCARD %s
  4. target datalayout = "e-p:32:32"
  5. ; CHECK: [[G:@[^ ]*]] = private constant { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] } { i32 1, [0 x i8] zeroinitializer, [63 x i32] zeroinitializer, [4 x i8] zeroinitializer, i32 3, [0 x i8] zeroinitializer, [2 x i32] [i32 4, i32 5] }
  6. @a = constant i32 1
  7. @b = constant [63 x i32] zeroinitializer
  8. @c = constant i32 3
  9. @d = constant [2 x i32] [i32 4, i32 5]
  10. ; CHECK: [[BA:@[^ ]*]] = private constant [68 x i8] c"\03\01\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\02\00\01"
  11. ; Offset 0, 4 byte alignment
  12. !0 = !{!"bitset1", i32* @a, i32 0}
  13. ; CHECK-NODISCARD-DAG: !{!"bitset1", i32* @a, i32 0}
  14. !1 = !{!"bitset1", [63 x i32]* @b, i32 0}
  15. ; CHECK-NODISCARD-DAG: !{!"bitset1", [63 x i32]* @b, i32 0}
  16. !2 = !{!"bitset1", [2 x i32]* @d, i32 4}
  17. ; CHECK-NODISCARD-DAG: !{!"bitset1", [2 x i32]* @d, i32 4}
  18. ; Offset 4, 256 byte alignment
  19. !3 = !{!"bitset2", [63 x i32]* @b, i32 0}
  20. ; CHECK-NODISCARD-DAG: !{!"bitset2", [63 x i32]* @b, i32 0}
  21. !4 = !{!"bitset2", i32* @c, i32 0}
  22. ; CHECK-NODISCARD-DAG: !{!"bitset2", i32* @c, i32 0}
  23. ; Offset 0, 4 byte alignment
  24. !5 = !{!"bitset3", i32* @a, i32 0}
  25. ; CHECK-NODISCARD-DAG: !{!"bitset3", i32* @a, i32 0}
  26. !6 = !{!"bitset3", i32* @c, i32 0}
  27. ; CHECK-NODISCARD-DAG: !{!"bitset3", i32* @c, i32 0}
  28. ; Entries whose second operand is null (the result of a global being DCE'd)
  29. ; should be ignored.
  30. !7 = !{!"bitset2", null, i32 0}
  31. !llvm.bitsets = !{ !0, !1, !2, !3, !4, !5, !6, !7 }
  32. ; CHECK: @bits_use{{[0-9]*}} = private alias i8* @bits{{[0-9]*}}
  33. ; CHECK: @bits_use.{{[0-9]*}} = private alias i8* @bits{{[0-9]*}}
  34. ; CHECK: @bits_use.{{[0-9]*}} = private alias i8* @bits{{[0-9]*}}
  35. ; CHECK: @a = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 0)
  36. ; CHECK: @b = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 2)
  37. ; CHECK: @c = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 4)
  38. ; CHECK: @d = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 6)
  39. ; CHECK-DARWIN: @aptr = constant i32* getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G:@[^ ]*]], i32 0, i32 0)
  40. @aptr = constant i32* @a
  41. ; CHECK-DARWIN: @bptr = constant [63 x i32]* getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 2)
  42. @bptr = constant [63 x i32]* @b
  43. ; CHECK-DARWIN: @cptr = constant i32* getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 4)
  44. @cptr = constant i32* @c
  45. ; CHECK-DARWIN: @dptr = constant [2 x i32]* getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 6)
  46. @dptr = constant [2 x i32]* @d
  47. ; CHECK-DARWIN: [[G]] = private constant
  48. ; CHECK: @bits{{[0-9]*}} = private alias getelementptr inbounds ([68 x i8], [68 x i8]* [[BA]], i32 0, i32 0)
  49. ; CHECK: @bits.{{[0-9]*}} = private alias getelementptr inbounds ([68 x i8], [68 x i8]* [[BA]], i32 0, i32 0)
  50. declare i1 @llvm.bitset.test(i8* %ptr, metadata %bitset) nounwind readnone
  51. ; CHECK: @foo(i32* [[A0:%[^ ]*]])
  52. define i1 @foo(i32* %p) {
  53. ; CHECK-NOT: llvm.bitset.test
  54. ; CHECK: [[R0:%[^ ]*]] = bitcast i32* [[A0]] to i8*
  55. %pi8 = bitcast i32* %p to i8*
  56. ; CHECK: [[R1:%[^ ]*]] = ptrtoint i8* [[R0]] to i32
  57. ; CHECK: [[R2:%[^ ]*]] = sub i32 [[R1]], ptrtoint ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]] to i32)
  58. ; CHECK: [[R3:%[^ ]*]] = lshr i32 [[R2]], 2
  59. ; CHECK: [[R4:%[^ ]*]] = shl i32 [[R2]], 30
  60. ; CHECK: [[R5:%[^ ]*]] = or i32 [[R3]], [[R4]]
  61. ; CHECK: [[R6:%[^ ]*]] = icmp ult i32 [[R5]], 68
  62. ; CHECK: br i1 [[R6]]
  63. ; CHECK: [[R8:%[^ ]*]] = getelementptr i8, i8* @bits_use.{{[0-9]*}}, i32 [[R5]]
  64. ; CHECK: [[R9:%[^ ]*]] = load i8, i8* [[R8]]
  65. ; CHECK: [[R10:%[^ ]*]] = and i8 [[R9]], 1
  66. ; CHECK: [[R11:%[^ ]*]] = icmp ne i8 [[R10]], 0
  67. ; CHECK: [[R16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[R11]], {{%[^ ]*}} ]
  68. %x = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset1")
  69. ; CHECK-NOT: llvm.bitset.test
  70. %y = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset1")
  71. ; CHECK: ret i1 [[R16]]
  72. ret i1 %x
  73. }
  74. ; CHECK: @bar(i32* [[B0:%[^ ]*]])
  75. define i1 @bar(i32* %p) {
  76. ; CHECK: [[S0:%[^ ]*]] = bitcast i32* [[B0]] to i8*
  77. %pi8 = bitcast i32* %p to i8*
  78. ; CHECK: [[S1:%[^ ]*]] = ptrtoint i8* [[S0]] to i32
  79. ; CHECK: [[S2:%[^ ]*]] = sub i32 [[S1]], add (i32 ptrtoint ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]] to i32), i32 4)
  80. ; CHECK: [[S3:%[^ ]*]] = lshr i32 [[S2]], 8
  81. ; CHECK: [[S4:%[^ ]*]] = shl i32 [[S2]], 24
  82. ; CHECK: [[S5:%[^ ]*]] = or i32 [[S3]], [[S4]]
  83. ; CHECK: [[S6:%[^ ]*]] = icmp ult i32 [[S5]], 2
  84. %x = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset2")
  85. ; CHECK: ret i1 [[S6]]
  86. ret i1 %x
  87. }
  88. ; CHECK: @baz(i32* [[C0:%[^ ]*]])
  89. define i1 @baz(i32* %p) {
  90. ; CHECK: [[T0:%[^ ]*]] = bitcast i32* [[C0]] to i8*
  91. %pi8 = bitcast i32* %p to i8*
  92. ; CHECK: [[T1:%[^ ]*]] = ptrtoint i8* [[T0]] to i32
  93. ; CHECK: [[T2:%[^ ]*]] = sub i32 [[T1]], ptrtoint ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]] to i32)
  94. ; CHECK: [[T3:%[^ ]*]] = lshr i32 [[T2]], 2
  95. ; CHECK: [[T4:%[^ ]*]] = shl i32 [[T2]], 30
  96. ; CHECK: [[T5:%[^ ]*]] = or i32 [[T3]], [[T4]]
  97. ; CHECK: [[T6:%[^ ]*]] = icmp ult i32 [[T5]], 66
  98. ; CHECK: br i1 [[T6]]
  99. ; CHECK: [[T8:%[^ ]*]] = getelementptr i8, i8* @bits_use.{{[0-9]*}}, i32 [[T5]]
  100. ; CHECK: [[T9:%[^ ]*]] = load i8, i8* [[T8]]
  101. ; CHECK: [[T10:%[^ ]*]] = and i8 [[T9]], 2
  102. ; CHECK: [[T11:%[^ ]*]] = icmp ne i8 [[T10]], 0
  103. ; CHECK: [[T16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[T11]], {{%[^ ]*}} ]
  104. %x = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset3")
  105. ; CHECK: ret i1 [[T16]]
  106. ret i1 %x
  107. }
  108. ; CHECK-NOT: !llvm.bitsets