@@ -294,4 +294,59 @@ define float @no_unsafe(ptr %addr, float %val) {
294
294
ret float %res
295
295
}
296
296
297
+ define float @flat_atomicrmw_fadd_f32__align32 (ptr %addr , float %val ) {
298
+ ; GFX908-LABEL: @flat_atomicrmw_fadd_f32__align32(
299
+ ; GFX908-NEXT: [[TMP1:%.*]] = load float, ptr [[ADDR:%.*]], align 32
300
+ ; GFX908-NEXT: br label [[ATOMICRMW_START:%.*]]
301
+ ; GFX908: atomicrmw.start:
302
+ ; GFX908-NEXT: [[LOADED:%.*]] = phi float [ [[TMP1]], [[TMP0:%.*]] ], [ [[TMP5:%.*]], [[ATOMICRMW_START]] ]
303
+ ; GFX908-NEXT: [[NEW:%.*]] = fadd float [[LOADED]], [[VAL:%.*]]
304
+ ; GFX908-NEXT: [[TMP2:%.*]] = bitcast float [[NEW]] to i32
305
+ ; GFX908-NEXT: [[TMP3:%.*]] = bitcast float [[LOADED]] to i32
306
+ ; GFX908-NEXT: [[TMP4:%.*]] = cmpxchg ptr [[ADDR]], i32 [[TMP3]], i32 [[TMP2]] seq_cst seq_cst, align 32
307
+ ; GFX908-NEXT: [[SUCCESS:%.*]] = extractvalue { i32, i1 } [[TMP4]], 1
308
+ ; GFX908-NEXT: [[NEWLOADED:%.*]] = extractvalue { i32, i1 } [[TMP4]], 0
309
+ ; GFX908-NEXT: [[TMP5]] = bitcast i32 [[NEWLOADED]] to float
310
+ ; GFX908-NEXT: br i1 [[SUCCESS]], label [[ATOMICRMW_END:%.*]], label [[ATOMICRMW_START]]
311
+ ; GFX908: atomicrmw.end:
312
+ ; GFX908-NEXT: ret float [[TMP5]]
313
+ ;
314
+ ; GFX90A-LABEL: @flat_atomicrmw_fadd_f32__align32(
315
+ ; GFX90A-NEXT: [[IS_SHARED:%.*]] = call i1 @llvm.amdgcn.is.shared(ptr [[ADDR:%.*]])
316
+ ; GFX90A-NEXT: br i1 [[IS_SHARED]], label [[ATOMICRMW_SHARED:%.*]], label [[ATOMICRMW_CHECK_PRIVATE:%.*]]
317
+ ; GFX90A: atomicrmw.shared:
318
+ ; GFX90A-NEXT: [[TMP1:%.*]] = addrspacecast ptr [[ADDR]] to ptr addrspace(3)
319
+ ; GFX90A-NEXT: [[TMP2:%.*]] = atomicrmw fadd ptr addrspace(3) [[TMP1]], float [[VAL:%.*]] seq_cst, align 32, !amdgpu.no.fine.grained.memory [[META0]], !amdgpu.ignore.denormal.mode [[META0]]
320
+ ; GFX90A-NEXT: br label [[ATOMICRMW_PHI:%.*]]
321
+ ; GFX90A: atomicrmw.check.private:
322
+ ; GFX90A-NEXT: [[IS_PRIVATE:%.*]] = call i1 @llvm.amdgcn.is.private(ptr [[ADDR]])
323
+ ; GFX90A-NEXT: br i1 [[IS_PRIVATE]], label [[ATOMICRMW_PRIVATE:%.*]], label [[ATOMICRMW_GLOBAL:%.*]]
324
+ ; GFX90A: atomicrmw.private:
325
+ ; GFX90A-NEXT: [[TMP3:%.*]] = addrspacecast ptr [[ADDR]] to ptr addrspace(5)
326
+ ; GFX90A-NEXT: [[LOADED_PRIVATE:%.*]] = load float, ptr addrspace(5) [[TMP3]], align 32
327
+ ; GFX90A-NEXT: [[NEW:%.*]] = fadd float [[LOADED_PRIVATE]], [[VAL]]
328
+ ; GFX90A-NEXT: store float [[NEW]], ptr addrspace(5) [[TMP3]], align 32
329
+ ; GFX90A-NEXT: br label [[ATOMICRMW_PHI]]
330
+ ; GFX90A: atomicrmw.global:
331
+ ; GFX90A-NEXT: [[TMP4:%.*]] = addrspacecast ptr [[ADDR]] to ptr addrspace(1)
332
+ ; GFX90A-NEXT: [[TMP5:%.*]] = atomicrmw fadd ptr addrspace(1) [[TMP4]], float [[VAL]] seq_cst, align 32, !amdgpu.no.fine.grained.memory [[META0]], !amdgpu.ignore.denormal.mode [[META0]]
333
+ ; GFX90A-NEXT: br label [[ATOMICRMW_PHI]]
334
+ ; GFX90A: atomicrmw.phi:
335
+ ; GFX90A-NEXT: [[RES:%.*]] = phi float [ [[TMP2]], [[ATOMICRMW_SHARED]] ], [ [[LOADED_PRIVATE]], [[ATOMICRMW_PRIVATE]] ], [ [[TMP5]], [[ATOMICRMW_GLOBAL]] ]
336
+ ; GFX90A-NEXT: br label [[ATOMICRMW_END:%.*]]
337
+ ; GFX90A: atomicrmw.end:
338
+ ; GFX90A-NEXT: ret float [[RES]]
339
+ ;
340
+ ; GFX940-LABEL: @flat_atomicrmw_fadd_f32__align32(
341
+ ; GFX940-NEXT: [[RES:%.*]] = atomicrmw fadd ptr [[ADDR:%.*]], float [[VAL:%.*]] seq_cst, align 32, !amdgpu.no.fine.grained.memory [[META0]], !amdgpu.ignore.denormal.mode [[META0]]
342
+ ; GFX940-NEXT: ret float [[RES]]
343
+ ;
344
+ ; GFX1100-LABEL: @flat_atomicrmw_fadd_f32__align32(
345
+ ; GFX1100-NEXT: [[RES:%.*]] = atomicrmw fadd ptr [[ADDR:%.*]], float [[VAL:%.*]] seq_cst, align 32, !amdgpu.no.fine.grained.memory [[META0]], !amdgpu.ignore.denormal.mode [[META0]]
346
+ ; GFX1100-NEXT: ret float [[RES]]
347
+ ;
348
+ %res = atomicrmw fadd ptr %addr , float %val seq_cst , align 32 , !amdgpu.no.fine.grained.memory !0 , !amdgpu.ignore.denormal.mode !0
349
+ ret float %res
350
+ }
351
+
297
352
!0 = !{}
0 commit comments