2025-02-19 21:21:20 +01:00
|
|
|
@shared_mem = external addrspace(3) global [0 x i32]
|
|
|
|
|
2025-03-17 21:37:26 +01:00
|
|
|
define amdgpu_kernel void @extern_shared(ptr addrspace(4) byref(i64) %"31", ptr addrspace(4) byref(i64) %"32") #0 {
|
|
|
|
%"33" = alloca i64, align 8, addrspace(5)
|
|
|
|
%"34" = alloca i64, align 8, addrspace(5)
|
|
|
|
%"35" = alloca i64, align 8, addrspace(5)
|
2025-02-19 21:21:20 +01:00
|
|
|
br label %1
|
|
|
|
|
|
|
|
1: ; preds = %0
|
2025-03-17 21:37:26 +01:00
|
|
|
br label %"30"
|
|
|
|
|
|
|
|
"30": ; preds = %1
|
|
|
|
%"36" = load i64, ptr addrspace(4) %"31", align 4
|
|
|
|
store i64 %"36", ptr addrspace(5) %"33", align 4
|
|
|
|
%"37" = load i64, ptr addrspace(4) %"32", align 4
|
|
|
|
store i64 %"37", ptr addrspace(5) %"34", align 4
|
|
|
|
%"39" = load i64, ptr addrspace(5) %"33", align 4
|
|
|
|
%"44" = inttoptr i64 %"39" to ptr addrspace(1)
|
|
|
|
%"38" = load i64, ptr addrspace(1) %"44", align 4
|
|
|
|
store i64 %"38", ptr addrspace(5) %"35", align 4
|
|
|
|
%"40" = load i64, ptr addrspace(5) %"35", align 4
|
|
|
|
store i64 %"40", ptr addrspace(3) @shared_mem, align 4
|
|
|
|
%"41" = load i64, ptr addrspace(3) @shared_mem, align 4
|
|
|
|
store i64 %"41", ptr addrspace(5) %"35", align 4
|
|
|
|
%"42" = load i64, ptr addrspace(5) %"34", align 4
|
|
|
|
%"43" = load i64, ptr addrspace(5) %"35", align 4
|
|
|
|
%"47" = inttoptr i64 %"42" to ptr addrspace(1)
|
|
|
|
store i64 %"43", ptr addrspace(1) %"47", align 4
|
2025-02-19 21:21:20 +01:00
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2025-03-17 21:37:26 +01:00
|
|
|
attributes #0 = { "amdgpu-unsafe-fp-atomics"="true" "denormal-fp-math"="preserve-sign" "denormal-fp-math-f32"="preserve-sign" "no-trapping-math"="true" "uniform-work-group-size"="true" }
|