Please use GitHub pull requests for new patches. Phabricator shutdown timeline
Changeset View
Changeset View
Standalone View
Standalone View
llvm/trunk/test/CodeGen/AMDGPU/shift-and-i64-ubfe.ll
Show First 20 Lines • Show All 301 Lines • ▼ Show 20 Lines | define amdgpu_kernel void @v_uextract_bit_31_32_i64_trunc_i32(i32 addrspace(1)* %out, i64 addrspace(1)* %in) #1 { | ||||
%srl = lshr i64 %ld.64, 31 | %srl = lshr i64 %ld.64, 31 | ||||
%trunc = trunc i64 %srl to i32 | %trunc = trunc i64 %srl to i32 | ||||
%bit = and i32 %trunc, 3 | %bit = and i32 %trunc, 3 | ||||
store i32 %bit, i32 addrspace(1)* %out.gep | store i32 %bit, i32 addrspace(1)* %out.gep | ||||
ret void | ret void | ||||
} | } | ||||
; GCN-LABEL: {{^}}and_not_mask_i64: | ; GCN-LABEL: {{^}}and_not_mask_i64: | ||||
; GCN-DAG: buffer_load_dwordx2 v{{\[}}[[VALLO:[0-9]+]]:[[VALHI:[0-9]+]]{{\]}} | ; GCN-DAG: buffer_load_dword v[[VAL:[0-9]+]] | ||||
; GCN-DAG: v_mov_b32_e32 v[[ZERO:[0-9]+]], 0{{$}} | ; GCN-DAG: v_mov_b32_e32 v[[ZERO:[0-9]+]], 0{{$}} | ||||
; GCN-DAG: v_mov_b32_e32 v[[SHRHI:[0-9]+]], v[[ZERO]]{{$}} | ; GCN-DAG: v_mov_b32_e32 v[[SHRHI:[0-9]+]], v[[ZERO]]{{$}} | ||||
; GCN: v_lshrrev_b32_e32 [[SHR:v[0-9]+]], 20, v[[VALLO]] | ; GCN: v_lshrrev_b32_e32 [[SHR:v[0-9]+]], 20, v[[VAL]] | ||||
; GCN-DAG: v_and_b32_e32 v[[SHRLO:[0-9]+]], 4, [[SHR]] | ; GCN-DAG: v_and_b32_e32 v[[SHRLO:[0-9]+]], 4, [[SHR]] | ||||
; GCN-NOT: v[[SHRLO]] | ; GCN-NOT: v[[SHRLO]] | ||||
; GCN-NOT: v[[SHRHI]] | ; GCN-NOT: v[[SHRHI]] | ||||
; GCN: buffer_store_dwordx2 v{{\[}}[[SHRLO]]:[[SHRHI]]{{\]}} | ; GCN: buffer_store_dwordx2 v{{\[}}[[SHRLO]]:[[SHRHI]]{{\]}} | ||||
define amdgpu_kernel void @and_not_mask_i64(i64 addrspace(1)* %out, i64 addrspace(1)* %in) #1 { | define amdgpu_kernel void @and_not_mask_i64(i64 addrspace(1)* %out, i64 addrspace(1)* %in) #1 { | ||||
%id.x = tail call i32 @llvm.amdgcn.workitem.id.x() | %id.x = tail call i32 @llvm.amdgcn.workitem.id.x() | ||||
%in.gep = getelementptr i64, i64 addrspace(1)* %in, i32 %id.x | %in.gep = getelementptr i64, i64 addrspace(1)* %in, i32 %id.x | ||||
%out.gep = getelementptr i64, i64 addrspace(1)* %out, i32 %id.x | %out.gep = getelementptr i64, i64 addrspace(1)* %out, i32 %id.x | ||||
▲ Show 20 Lines • Show All 77 Lines • Show Last 20 Lines |