@@ -201,19 +201,19 @@ define { i64, i1 } @cmpxchg_flat_agent_i64__nolocal(ptr %ptr, i64 %val, i64 %swa
201
201
; CHECK-NEXT: [[IS_PRIVATE:%.*]] = call i1 @llvm.amdgcn.is.private(ptr [[PTR]])
202
202
; CHECK-NEXT: br i1 [[IS_PRIVATE]], label %[[ATOMICRMW_PRIVATE:.*]], label %[[ATOMICRMW_GLOBAL:.*]]
203
203
; CHECK: [[ATOMICRMW_PRIVATE]]:
204
- ; CHECK-NEXT: [[TMP3 :%.*]] = addrspacecast ptr [[PTR]] to ptr addrspace(5)
205
- ; CHECK-NEXT: [[TMP4 :%.*]] = load i64, ptr addrspace(5) [[TMP3 ]], align 8
206
- ; CHECK-NEXT: [[TMP5 :%.*]] = icmp eq i64 [[TMP4 ]], [[VAL]]
207
- ; CHECK-NEXT: [[TMP6 :%.*]] = select i1 [[TMP5 ]], i64 [[SWAP]], i64 [[TMP4 ]]
208
- ; CHECK-NEXT: store i64 [[TMP6 ]], ptr addrspace(5) [[TMP3 ]], align 8
209
- ; CHECK-NEXT: [[TMP7 :%.*]] = insertvalue { i64, i1 } poison, i64 [[TMP4 ]], 0
210
- ; CHECK-NEXT: [[TMP8 :%.*]] = insertvalue { i64, i1 } [[TMP7 ]], i1 [[TMP5 ]], 1
204
+ ; CHECK-NEXT: [[TMP1 :%.*]] = addrspacecast ptr [[PTR]] to ptr addrspace(5)
205
+ ; CHECK-NEXT: [[TMP2 :%.*]] = load i64, ptr addrspace(5) [[TMP1 ]], align 8
206
+ ; CHECK-NEXT: [[TMP3 :%.*]] = icmp eq i64 [[TMP2 ]], [[VAL]]
207
+ ; CHECK-NEXT: [[TMP4 :%.*]] = select i1 [[TMP3 ]], i64 [[SWAP]], i64 [[TMP2 ]]
208
+ ; CHECK-NEXT: store i64 [[TMP4 ]], ptr addrspace(5) [[TMP1 ]], align 8
209
+ ; CHECK-NEXT: [[TMP5 :%.*]] = insertvalue { i64, i1 } poison, i64 [[TMP2 ]], 0
210
+ ; CHECK-NEXT: [[TMP6 :%.*]] = insertvalue { i64, i1 } [[TMP5 ]], i1 [[TMP3 ]], 1
211
211
; CHECK-NEXT: br label %[[ATOMICRMW_PHI:.*]]
212
212
; CHECK: [[ATOMICRMW_GLOBAL]]:
213
- ; CHECK-NEXT: [[TMP9 :%.*]] = cmpxchg ptr [[PTR]], i64 [[VAL]], i64 [[SWAP]] syncscope("agent") monotonic seq_cst, align 8, !noalias.addrspace [[META0]]
213
+ ; CHECK-NEXT: [[TMP7 :%.*]] = cmpxchg ptr [[PTR]], i64 [[VAL]], i64 [[SWAP]] syncscope("agent") monotonic seq_cst, align 8, !noalias.addrspace [[META0]]
214
214
; CHECK-NEXT: br label %[[ATOMICRMW_PHI]]
215
215
; CHECK: [[ATOMICRMW_PHI]]:
216
- ; CHECK-NEXT: [[RESULT:%.*]] = phi { i64, i1 } [ [[TMP8 ]], %[[ATOMICRMW_PRIVATE]] ], [ [[TMP9 ]], %[[ATOMICRMW_GLOBAL]] ]
216
+ ; CHECK-NEXT: [[RESULT:%.*]] = phi { i64, i1 } [ [[TMP6 ]], %[[ATOMICRMW_PRIVATE]] ], [ [[TMP7 ]], %[[ATOMICRMW_GLOBAL]] ]
217
217
; CHECK-NEXT: br label %[[ATOMICRMW_END:.*]]
218
218
; CHECK: [[ATOMICRMW_END]]:
219
219
; CHECK-NEXT: ret { i64, i1 } [[RESULT]]
@@ -276,17 +276,86 @@ define { i64, i1 } @cmpxchg_flat_agent_i64_mmra_noprivate(ptr %ptr, i64 %val, i6
276
276
ret { i64 , i1 } %result
277
277
}
278
278
279
+ ; may alias private, wrapped range
280
+ define { i64 , i1 } @cmpxchg_flat_agent_i64__noalias_addrspace_edge_case0 (ptr %ptr , i64 %val , i64 %swap ) {
281
+ ; CHECK-LABEL: define { i64, i1 } @cmpxchg_flat_agent_i64__noalias_addrspace_edge_case0(
282
+ ; CHECK-SAME: ptr [[PTR:%.*]], i64 [[VAL:%.*]], i64 [[SWAP:%.*]]) {
283
+ ; CHECK-NEXT: [[IS_PRIVATE:%.*]] = call i1 @llvm.amdgcn.is.private(ptr [[PTR]])
284
+ ; CHECK-NEXT: br i1 [[IS_PRIVATE]], label %[[ATOMICRMW_PRIVATE:.*]], label %[[ATOMICRMW_GLOBAL:.*]]
285
+ ; CHECK: [[ATOMICRMW_PRIVATE]]:
286
+ ; CHECK-NEXT: [[TMP1:%.*]] = addrspacecast ptr [[PTR]] to ptr addrspace(5)
287
+ ; CHECK-NEXT: [[TMP2:%.*]] = load i64, ptr addrspace(5) [[TMP1]], align 8
288
+ ; CHECK-NEXT: [[TMP3:%.*]] = icmp eq i64 [[TMP2]], [[VAL]]
289
+ ; CHECK-NEXT: [[TMP4:%.*]] = select i1 [[TMP3]], i64 [[SWAP]], i64 [[TMP2]]
290
+ ; CHECK-NEXT: store i64 [[TMP4]], ptr addrspace(5) [[TMP1]], align 8
291
+ ; CHECK-NEXT: [[TMP5:%.*]] = insertvalue { i64, i1 } poison, i64 [[TMP2]], 0
292
+ ; CHECK-NEXT: [[TMP6:%.*]] = insertvalue { i64, i1 } [[TMP5]], i1 [[TMP3]], 1
293
+ ; CHECK-NEXT: br label %[[ATOMICRMW_PHI:.*]]
294
+ ; CHECK: [[ATOMICRMW_GLOBAL]]:
295
+ ; CHECK-NEXT: [[TMP7:%.*]] = cmpxchg ptr [[PTR]], i64 [[VAL]], i64 [[SWAP]] syncscope("agent") monotonic seq_cst, align 8, !noalias.addrspace [[META0]]
296
+ ; CHECK-NEXT: br label %[[ATOMICRMW_PHI]]
297
+ ; CHECK: [[ATOMICRMW_PHI]]:
298
+ ; CHECK-NEXT: [[RESULT:%.*]] = phi { i64, i1 } [ [[TMP6]], %[[ATOMICRMW_PRIVATE]] ], [ [[TMP7]], %[[ATOMICRMW_GLOBAL]] ]
299
+ ; CHECK-NEXT: br label %[[ATOMICRMW_END:.*]]
300
+ ; CHECK: [[ATOMICRMW_END]]:
301
+ ; CHECK-NEXT: ret { i64, i1 } [[RESULT]]
302
+ ;
303
+ %result = cmpxchg ptr %ptr , i64 %val , i64 %swap syncscope("agent" ) monotonic seq_cst , !noalias.addrspace !6
304
+ ret { i64 , i1 } %result
305
+ }
306
+
307
+ ; covers private case, but private isn't the low value.
308
+ define { i64 , i1 } @cmpxchg_flat_agent_i64__no_2_6 (ptr %ptr , i64 %val , i64 %swap ) {
309
+ ; CHECK-LABEL: define { i64, i1 } @cmpxchg_flat_agent_i64__no_2_6(
310
+ ; CHECK-SAME: ptr [[PTR:%.*]], i64 [[VAL:%.*]], i64 [[SWAP:%.*]]) {
311
+ ; CHECK-NEXT: [[IS_PRIVATE:%.*]] = call i1 @llvm.amdgcn.is.private(ptr [[PTR]])
312
+ ; CHECK-NEXT: br i1 [[IS_PRIVATE]], label %[[ATOMICRMW_PRIVATE:.*]], label %[[ATOMICRMW_GLOBAL:.*]]
313
+ ; CHECK: [[ATOMICRMW_PRIVATE]]:
314
+ ; CHECK-NEXT: [[TMP1:%.*]] = addrspacecast ptr [[PTR]] to ptr addrspace(5)
315
+ ; CHECK-NEXT: [[TMP2:%.*]] = load i64, ptr addrspace(5) [[TMP1]], align 8
316
+ ; CHECK-NEXT: [[TMP3:%.*]] = icmp eq i64 [[TMP2]], [[VAL]]
317
+ ; CHECK-NEXT: [[TMP4:%.*]] = select i1 [[TMP3]], i64 [[SWAP]], i64 [[TMP2]]
318
+ ; CHECK-NEXT: store i64 [[TMP4]], ptr addrspace(5) [[TMP1]], align 8
319
+ ; CHECK-NEXT: [[TMP5:%.*]] = insertvalue { i64, i1 } poison, i64 [[TMP2]], 0
320
+ ; CHECK-NEXT: [[TMP6:%.*]] = insertvalue { i64, i1 } [[TMP5]], i1 [[TMP3]], 1
321
+ ; CHECK-NEXT: br label %[[ATOMICRMW_PHI:.*]]
322
+ ; CHECK: [[ATOMICRMW_GLOBAL]]:
323
+ ; CHECK-NEXT: [[TMP7:%.*]] = cmpxchg ptr [[PTR]], i64 [[VAL]], i64 [[SWAP]] syncscope("agent") monotonic seq_cst, align 8, !noalias.addrspace [[META0]]
324
+ ; CHECK-NEXT: br label %[[ATOMICRMW_PHI]]
325
+ ; CHECK: [[ATOMICRMW_PHI]]:
326
+ ; CHECK-NEXT: [[RESULT:%.*]] = phi { i64, i1 } [ [[TMP6]], %[[ATOMICRMW_PRIVATE]] ], [ [[TMP7]], %[[ATOMICRMW_GLOBAL]] ]
327
+ ; CHECK-NEXT: br label %[[ATOMICRMW_END:.*]]
328
+ ; CHECK: [[ATOMICRMW_END]]:
329
+ ; CHECK-NEXT: ret { i64, i1 } [[RESULT]]
330
+ ;
331
+ %result = cmpxchg ptr %ptr , i64 %val , i64 %swap syncscope("agent" ) monotonic seq_cst , !noalias.addrspace !7
332
+ ret { i64 , i1 } %result
333
+ }
334
+
335
+ define { i64 , i1 } @cmpxchg_flat_agent_i64__no_2_3_5 (ptr %ptr , i64 %val , i64 %swap ) {
336
+ ; CHECK-LABEL: define { i64, i1 } @cmpxchg_flat_agent_i64__no_2_3_5(
337
+ ; CHECK-SAME: ptr [[PTR:%.*]], i64 [[VAL:%.*]], i64 [[SWAP:%.*]]) {
338
+ ; CHECK-NEXT: [[RESULT:%.*]] = cmpxchg ptr [[PTR]], i64 [[VAL]], i64 [[SWAP]] syncscope("agent") monotonic seq_cst, align 8, !noalias.addrspace [[META4:![0-9]+]]
339
+ ; CHECK-NEXT: ret { i64, i1 } [[RESULT]]
340
+ ;
341
+ %result = cmpxchg ptr %ptr , i64 %val , i64 %swap syncscope("agent" ) monotonic seq_cst , !noalias.addrspace !8
342
+ ret { i64 , i1 } %result
343
+ }
344
+
279
345
!0 = !{i32 5 , i32 6 }
280
346
!1 = !{i32 3 , i32 4 }
281
347
!2 = !{!"foo" , !"bar" }
282
348
!3 = !{!"bux" , !"baz" }
283
349
!4 = !{!2 , !3 }
284
350
!5 = !{}
285
-
351
+ !6 = !{i32 6 , i32 5 }
352
+ !7 = !{i32 2 , i32 6 }
353
+ !8 = !{i32 2 , i32 4 , i32 5 , i32 6 }
286
354
287
355
;.
288
356
; CHECK: [[META0]] = !{i32 5, i32 6}
289
357
; CHECK: [[META1]] = !{[[META2:![0-9]+]], [[META3:![0-9]+]]}
290
358
; CHECK: [[META2]] = !{!"foo", !"bar"}
291
359
; CHECK: [[META3]] = !{!"bux", !"baz"}
360
+ ; CHECK: [[META4]] = !{i32 2, i32 4, i32 5, i32 6}
292
361
;.
0 commit comments