3
3
4
4
;.
5
5
; CHECK: @.memset_pattern = private unnamed_addr constant [2 x i64] [i64 -6148895925951734307, i64 -6148895925951734307], align 16
6
- ; CHECK: @.memset_pattern.1 = private unnamed_addr constant [2 x i64] [i64 4614256656552045848 , i64 4614256656552045848 ], align 16
7
- ; CHECK: @.memset_pattern.2 = private unnamed_addr constant [8 x i16 ] [i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555 ], align 16
8
- ; CHECK: @.memset_pattern.3 = private unnamed_addr constant i128 -113427455635030943652277463699152839203 , align 16
9
- ; CHECK: @.memset_pattern.4 = private unnamed_addr constant i128 -113427455635030943652277463699152839203 , align 16
6
+ ; CHECK: @.memset_pattern.1 = private unnamed_addr constant [2 x i64] [i64 -6148895925951734307 , i64 -6148895925951734307 ], align 16
7
+ ; CHECK: @.memset_pattern.2 = private unnamed_addr constant [2 x i64 ] [i64 -6148895925951734307, i64 -6148895925951734307 ], align 16
8
+ ; CHECK: @.memset_pattern.3 = private unnamed_addr constant [2 x i64] [i64 4614256656552045848, i64 4614256656552045848] , align 16
9
+ ; CHECK: @.memset_pattern.4 = private unnamed_addr constant [8 x i16] [i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555, i16 -21555] , align 16
10
10
; CHECK: @.memset_pattern.5 = private unnamed_addr constant i128 -113427455635030943652277463699152839203, align 16
11
11
; CHECK: @.memset_pattern.6 = private unnamed_addr constant i128 -113427455635030943652277463699152839203, align 16
12
+ ; CHECK: @.memset_pattern.7 = private unnamed_addr constant i128 -113427455635030943652277463699152839203, align 16
13
+ ; CHECK: @.memset_pattern.8 = private unnamed_addr constant i128 -113427455635030943652277463699152839203, align 16
12
14
;.
13
15
define void @memset_pattern_i128_1_dynvalue (ptr %a , i128 %value ) nounwind {
14
16
; CHECK-LABEL: define void @memset_pattern_i128_1_dynvalue(
@@ -31,7 +33,7 @@ define void @memset_pattern_i128_1_dynvalue(ptr %a, i128 %value) nounwind {
31
33
define void @memset_pattern_i128_1 (ptr %a , i128 %value ) nounwind {
32
34
; CHECK-LABEL: define void @memset_pattern_i128_1(
33
35
; CHECK-SAME: ptr [[A:%.*]], i128 [[VALUE:%.*]]) #[[ATTR0]] {
34
- ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.3 , i64 16)
36
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.5 , i64 16)
35
37
; CHECK-NEXT: ret void
36
38
;
37
39
tail call void @llvm.experimental.memset.pattern (ptr %a , i128 u0xaaaaaaaabbbbbbbbccccccccdddddddd, i64 1 , i1 false )
@@ -59,7 +61,7 @@ define void @memset_pattern_i128_1_nz_as(ptr addrspace(1) %a, i128 %value) nounw
59
61
define void @memset_pattern_i128_1_align_attr (ptr align (16 ) %a , i128 %value ) nounwind {
60
62
; CHECK-LABEL: define void @memset_pattern_i128_1_align_attr(
61
63
; CHECK-SAME: ptr align 16 [[A:%.*]], i128 [[VALUE:%.*]]) #[[ATTR0]] {
62
- ; CHECK-NEXT: call void @memset_pattern16(ptr align 16 [[A]], ptr @.memset_pattern.4 , i64 16)
64
+ ; CHECK-NEXT: call void @memset_pattern16(ptr align 16 [[A]], ptr @.memset_pattern.6 , i64 16)
63
65
; CHECK-NEXT: ret void
64
66
;
65
67
tail call void @llvm.experimental.memset.pattern (ptr align (16 ) %a , i128 u0xaaaaaaaabbbbbbbbccccccccdddddddd, i64 1 , i1 false )
@@ -69,7 +71,7 @@ define void @memset_pattern_i128_1_align_attr(ptr align(16) %a, i128 %value) nou
69
71
define void @memset_pattern_i128_16 (ptr %a ) nounwind {
70
72
; CHECK-LABEL: define void @memset_pattern_i128_16(
71
73
; CHECK-SAME: ptr [[A:%.*]]) #[[ATTR0]] {
72
- ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.5 , i64 256)
74
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.7 , i64 256)
73
75
; CHECK-NEXT: ret void
74
76
;
75
77
tail call void @llvm.experimental.memset.pattern (ptr %a , i128 u0xaaaaaaaabbbbbbbbccccccccdddddddd, i64 16 , i1 false )
@@ -80,7 +82,7 @@ define void @memset_pattern_i128_x(ptr %a, i64 %x) nounwind {
80
82
; CHECK-LABEL: define void @memset_pattern_i128_x(
81
83
; CHECK-SAME: ptr [[A:%.*]], i64 [[X:%.*]]) #[[ATTR0]] {
82
84
; CHECK-NEXT: [[TMP1:%.*]] = mul i64 16, [[X]]
83
- ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.6 , i64 [[TMP1]])
85
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.8 , i64 [[TMP1]])
84
86
; CHECK-NEXT: ret void
85
87
;
86
88
tail call void @llvm.experimental.memset.pattern (ptr %a , i128 u0xaaaaaaaabbbbbbbbccccccccdddddddd, i64 %x , i1 false )
@@ -110,7 +112,7 @@ define void @memset_pattern_i16_x(ptr %a, i64 %x) nounwind {
110
112
; CHECK-LABEL: define void @memset_pattern_i16_x(
111
113
; CHECK-SAME: ptr [[A:%.*]], i64 [[X:%.*]]) #[[ATTR0]] {
112
114
; CHECK-NEXT: [[TMP1:%.*]] = mul i64 2, [[X]]
113
- ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.2 , i64 [[TMP1]])
115
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.4 , i64 [[TMP1]])
114
116
; CHECK-NEXT: ret void
115
117
;
116
118
tail call void @llvm.experimental.memset.pattern (ptr %a , i16 u0xabcd, i64 %x , i1 false )
@@ -121,7 +123,7 @@ define void @memset_pattern_i64_x(ptr %a, i64 %x) nounwind {
121
123
; CHECK-LABEL: define void @memset_pattern_i64_x(
122
124
; CHECK-SAME: ptr [[A:%.*]], i64 [[X:%.*]]) #[[ATTR0]] {
123
125
; CHECK-NEXT: [[TMP1:%.*]] = mul i64 8, [[X]]
124
- ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern, i64 [[TMP1]])
126
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.2 , i64 [[TMP1]])
125
127
; CHECK-NEXT: ret void
126
128
;
127
129
tail call void @llvm.experimental.memset.pattern (ptr %a , i64 u0xaaaabbbbccccdddd, i64 %x , i1 false )
@@ -132,13 +134,37 @@ define void @memset_pattern_i64_x(ptr %a, i64 %x) nounwind {
132
134
define void @memset_pattern_i64_128_tbaa (ptr %a ) nounwind {
133
135
; CHECK-LABEL: define void @memset_pattern_i64_128_tbaa(
134
136
; CHECK-SAME: ptr [[A:%.*]]) #[[ATTR0]] {
135
- ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.1 , i64 1024), !tbaa [[TBAA0:![0-9]+]]
137
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.3 , i64 1024), !tbaa [[TBAA0:![0-9]+]]
136
138
; CHECK-NEXT: ret void
137
139
;
138
140
tail call void @llvm.experimental.memset.pattern (ptr %a , i64 u0x400921fb54442d18, i64 128 , i1 false ), !tbaa !5
139
141
ret void
140
142
}
141
143
144
+ define void @memset_pattern_i64_narrow_idx (ptr %a , i32 %x ) nounwind {
145
+ ; CHECK-LABEL: define void @memset_pattern_i64_narrow_idx(
146
+ ; CHECK-SAME: ptr [[A:%.*]], i32 [[X:%.*]]) #[[ATTR0]] {
147
+ ; CHECK-NEXT: [[TMP1:%.*]] = zext i32 [[X]] to i64
148
+ ; CHECK-NEXT: [[TMP2:%.*]] = mul i64 8, [[TMP1]]
149
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern.1, i64 [[TMP2]])
150
+ ; CHECK-NEXT: ret void
151
+ ;
152
+ tail call void @llvm.experimental.memset.pattern (ptr %a , i64 u0xaaaabbbbccccdddd, i32 %x , i1 false )
153
+ ret void
154
+ }
155
+
156
+ define void @memset_pattern_i64_wide_idx (ptr %a , i128 %x ) nounwind {
157
+ ; CHECK-LABEL: define void @memset_pattern_i64_wide_idx(
158
+ ; CHECK-SAME: ptr [[A:%.*]], i128 [[X:%.*]]) #[[ATTR0]] {
159
+ ; CHECK-NEXT: [[TMP1:%.*]] = trunc i128 [[X]] to i64
160
+ ; CHECK-NEXT: [[TMP2:%.*]] = mul i64 8, [[TMP1]]
161
+ ; CHECK-NEXT: call void @memset_pattern16(ptr [[A]], ptr @.memset_pattern, i64 [[TMP2]])
162
+ ; CHECK-NEXT: ret void
163
+ ;
164
+ tail call void @llvm.experimental.memset.pattern (ptr %a , i64 u0xaaaabbbbccccdddd, i128 %x , i1 false )
165
+ ret void
166
+ }
167
+
142
168
!5 = !{!6 , !6 , i64 0 }
143
169
!6 = !{!"double" , !7 , i64 0 }
144
170
!7 = !{!"omnipotent char" , !8 , i64 0 }
0 commit comments