blob: 704ab720cbf835050070f9a5d38ec16ffaa73e37 [file] [log] [blame]
Peter Collingbournee6909c82015-02-20 20:30:47 +00001; RUN: opt -S -lowerbitsets < %s | FileCheck %s
2; RUN: opt -S -O3 < %s | FileCheck -check-prefix=CHECK-NODISCARD %s
3
4target datalayout = "e-p:32:32"
5
Peter Collingbourneeba7f732015-02-25 20:42:41 +00006; 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] }
Peter Collingbournee6909c82015-02-20 20:30:47 +00007@a = constant i32 1
8@b = constant [63 x i32] zeroinitializer
9@c = constant i32 3
10@d = constant [2 x i32] [i32 4, i32 5]
11
12; Offset 0, 4 byte alignment
Peter Collingbourneeba7f732015-02-25 20:42:41 +000013; CHECK: @bitset1.bits = private constant [9 x i8] c"\03\00\00\00\00\00\00\00\08"
Peter Collingbournee6909c82015-02-20 20:30:47 +000014!0 = !{!"bitset1", i32* @a, i32 0}
15; CHECK-NODISCARD-DAG: !{!"bitset1", i32* @a, i32 0}
16!1 = !{!"bitset1", [63 x i32]* @b, i32 0}
17; CHECK-NODISCARD-DAG: !{!"bitset1", [63 x i32]* @b, i32 0}
18!2 = !{!"bitset1", [2 x i32]* @d, i32 4}
19; CHECK-NODISCARD-DAG: !{!"bitset1", [2 x i32]* @d, i32 4}
20
Peter Collingbourneeba7f732015-02-25 20:42:41 +000021; Offset 4, 256 byte alignment
22; CHECK: @bitset2.bits = private constant [1 x i8] c"\03"
Peter Collingbournee6909c82015-02-20 20:30:47 +000023!3 = !{!"bitset2", [63 x i32]* @b, i32 0}
24; CHECK-NODISCARD-DAG: !{!"bitset2", [63 x i32]* @b, i32 0}
25!4 = !{!"bitset2", i32* @c, i32 0}
26; CHECK-NODISCARD-DAG: !{!"bitset2", i32* @c, i32 0}
27
Peter Collingbourneeba7f732015-02-25 20:42:41 +000028; Offset 0, 4 byte alignment
29; CHECK: @bitset3.bits = private constant [9 x i8] c"\01\00\00\00\00\00\00\00\02"
Peter Collingbournee6909c82015-02-20 20:30:47 +000030!5 = !{!"bitset3", i32* @a, i32 0}
31; CHECK-NODISCARD-DAG: !{!"bitset3", i32* @a, i32 0}
32!6 = !{!"bitset3", i32* @c, i32 0}
33; CHECK-NODISCARD-DAG: !{!"bitset3", i32* @c, i32 0}
34
35; Entries whose second operand is null (the result of a global being DCE'd)
36; should be ignored.
37!7 = !{!"bitset2", null, i32 0}
38
39!llvm.bitsets = !{ !0, !1, !2, !3, !4, !5, !6, !7 }
40
Peter Collingbourneeba7f732015-02-25 20:42:41 +000041; CHECK: @a = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 0)
42; CHECK: @b = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 2)
43; CHECK: @c = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 4)
44; CHECK: @d = alias getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 6)
Peter Collingbournee6909c82015-02-20 20:30:47 +000045
46declare i1 @llvm.bitset.test(i8* %ptr, metadata %bitset) nounwind readnone
47
48; CHECK: @foo(i32* [[A0:%[^ ]*]])
49define i1 @foo(i32* %p) {
50 ; CHECK-NOT: llvm.bitset.test
51
52 ; CHECK: [[R0:%[^ ]*]] = bitcast i32* [[A0]] to i8*
53 %pi8 = bitcast i32* %p to i8*
54 ; CHECK: [[R1:%[^ ]*]] = ptrtoint i8* [[R0]] to i32
Peter Collingbourneeba7f732015-02-25 20:42:41 +000055 ; 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)
Peter Collingbournee6909c82015-02-20 20:30:47 +000056 ; CHECK: [[R3:%[^ ]*]] = lshr i32 [[R2]], 2
57 ; CHECK: [[R4:%[^ ]*]] = shl i32 [[R2]], 30
58 ; CHECK: [[R5:%[^ ]*]] = or i32 [[R3]], [[R4]]
Peter Collingbourneeba7f732015-02-25 20:42:41 +000059 ; CHECK: [[R6:%[^ ]*]] = icmp ult i32 [[R5]], 68
Peter Collingbournee6909c82015-02-20 20:30:47 +000060 ; CHECK: br i1 [[R6]]
61
62 ; CHECK: [[R8:%[^ ]*]] = lshr i32 [[R5]], 5
David Blaikie79e6c742015-02-27 19:29:02 +000063 ; CHECK: [[R9:%[^ ]*]] = getelementptr i32, i32* bitcast ([9 x i8]* @bitset1.bits to i32*), i32 [[R8]]
David Blaikiea79ac142015-02-27 21:17:42 +000064 ; CHECK: [[R10:%[^ ]*]] = load i32, i32* [[R9]]
Peter Collingbournee6909c82015-02-20 20:30:47 +000065 ; CHECK: [[R11:%[^ ]*]] = and i32 [[R5]], 31
66 ; CHECK: [[R12:%[^ ]*]] = shl i32 1, [[R11]]
67 ; CHECK: [[R13:%[^ ]*]] = and i32 [[R10]], [[R12]]
68 ; CHECK: [[R14:%[^ ]*]] = icmp ne i32 [[R13]], 0
69
70 ; CHECK: [[R16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[R14]], {{%[^ ]*}} ]
71 %x = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset1")
72
73 ; CHECK-NOT: llvm.bitset.test
74 %y = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset1")
75
76 ; CHECK: ret i1 [[R16]]
77 ret i1 %x
78}
79
80; CHECK: @bar(i32* [[B0:%[^ ]*]])
81define i1 @bar(i32* %p) {
82 ; CHECK: [[S0:%[^ ]*]] = bitcast i32* [[B0]] to i8*
83 %pi8 = bitcast i32* %p to i8*
84 ; CHECK: [[S1:%[^ ]*]] = ptrtoint i8* [[S0]] to i32
Peter Collingbourneeba7f732015-02-25 20:42:41 +000085 ; 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)
86 ; CHECK: [[S3:%[^ ]*]] = lshr i32 [[S2]], 8
87 ; CHECK: [[S4:%[^ ]*]] = shl i32 [[S2]], 24
Peter Collingbournee6909c82015-02-20 20:30:47 +000088 ; CHECK: [[S5:%[^ ]*]] = or i32 [[S3]], [[S4]]
Peter Collingbourneeba7f732015-02-25 20:42:41 +000089 ; CHECK: [[S6:%[^ ]*]] = icmp ult i32 [[S5]], 2
Peter Collingbournee6909c82015-02-20 20:30:47 +000090 %x = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset2")
Peter Collingbourneeba7f732015-02-25 20:42:41 +000091
92 ; CHECK: ret i1 [[S6]]
Peter Collingbournee6909c82015-02-20 20:30:47 +000093 ret i1 %x
94}
95
96; CHECK: @baz(i32* [[C0:%[^ ]*]])
97define i1 @baz(i32* %p) {
98 ; CHECK: [[T0:%[^ ]*]] = bitcast i32* [[C0]] to i8*
99 %pi8 = bitcast i32* %p to i8*
100 ; CHECK: [[T1:%[^ ]*]] = ptrtoint i8* [[T0]] to i32
Peter Collingbourneeba7f732015-02-25 20:42:41 +0000101 ; 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)
102 ; CHECK: [[T3:%[^ ]*]] = lshr i32 [[T2]], 2
103 ; CHECK: [[T4:%[^ ]*]] = shl i32 [[T2]], 30
Peter Collingbournee6909c82015-02-20 20:30:47 +0000104 ; CHECK: [[T5:%[^ ]*]] = or i32 [[T3]], [[T4]]
Peter Collingbourneeba7f732015-02-25 20:42:41 +0000105 ; CHECK: [[T6:%[^ ]*]] = icmp ult i32 [[T5]], 66
Peter Collingbournee6909c82015-02-20 20:30:47 +0000106 ; CHECK: br i1 [[T6]]
107
Peter Collingbourneeba7f732015-02-25 20:42:41 +0000108 ; CHECK: [[T8:%[^ ]*]] = lshr i32 [[T5]], 5
David Blaikie79e6c742015-02-27 19:29:02 +0000109 ; CHECK: [[T9:%[^ ]*]] = getelementptr i32, i32* bitcast ([9 x i8]* @bitset3.bits to i32*), i32 [[T8]]
David Blaikiea79ac142015-02-27 21:17:42 +0000110 ; CHECK: [[T10:%[^ ]*]] = load i32, i32* [[T9]]
Peter Collingbourneeba7f732015-02-25 20:42:41 +0000111 ; CHECK: [[T11:%[^ ]*]] = and i32 [[T5]], 31
112 ; CHECK: [[T12:%[^ ]*]] = shl i32 1, [[T11]]
113 ; CHECK: [[T13:%[^ ]*]] = and i32 [[T10]], [[T12]]
114 ; CHECK: [[T14:%[^ ]*]] = icmp ne i32 [[T13]], 0
Peter Collingbournee6909c82015-02-20 20:30:47 +0000115
Peter Collingbourneeba7f732015-02-25 20:42:41 +0000116 ; CHECK: [[T16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[T14]], {{%[^ ]*}} ]
Peter Collingbournee6909c82015-02-20 20:30:47 +0000117 %x = call i1 @llvm.bitset.test(i8* %pi8, metadata !"bitset3")
118 ; CHECK: ret i1 [[T16]]
119 ret i1 %x
120}
121
122; CHECK-NOT: !llvm.bitsets