diff options
Diffstat (limited to 'test/CodeGen/R600/trunc.ll')
-rw-r--r-- | test/CodeGen/R600/trunc.ll | 36 |
1 files changed, 30 insertions, 6 deletions
diff --git a/test/CodeGen/R600/trunc.ll b/test/CodeGen/R600/trunc.ll index 0bd320a..8a759dc 100644 --- a/test/CodeGen/R600/trunc.ll +++ b/test/CodeGen/R600/trunc.ll @@ -16,15 +16,39 @@ define void @trunc_i64_to_i32_store(i32 addrspace(1)* %out, i64 %in) { ret void } +; SI-LABEL: @trunc_load_shl_i64: +; SI-DAG: S_LOAD_DWORDX2 +; SI-DAG: S_LOAD_DWORD [[SREG:s[0-9]+]], +; SI: S_LSHL_B32 [[SHL:s[0-9]+]], [[SREG]], 2 +; SI: V_MOV_B32_e32 [[VSHL:v[0-9]+]], [[SHL]] +; SI: BUFFER_STORE_DWORD [[VSHL]], +define void @trunc_load_shl_i64(i32 addrspace(1)* %out, i64 %a) { + %b = shl i64 %a, 2 + %result = trunc i64 %b to i32 + store i32 %result, i32 addrspace(1)* %out, align 4 + ret void +} + ; SI-LABEL: @trunc_shl_i64: -; SI: S_LOAD_DWORDX2 -; SI: S_LOAD_DWORDX2 [[SREG:s\[[0-9]+:[0-9]+\]]] -; SI: S_LSHL_B64 s{{\[}}[[LO_SREG:[0-9]+]]:{{[0-9]+\]}}, [[SREG]], 2 -; SI: MOV_B32_e32 v[[LO_VREG:[0-9]+]], s[[LO_SREG]] +; SI: S_LOAD_DWORDX2 s{{\[}}[[LO_SREG:[0-9]+]]:{{[0-9]+\]}}, +; SI: V_ADD_I32_e32 v[[LO_ADD:[0-9]+]], s[[LO_SREG]], +; SI: V_LSHL_B64 v{{\[}}[[LO_VREG:[0-9]+]]:{{[0-9]+\]}}, v{{\[}}[[LO_ADD]]:{{[0-9]+\]}}, 2 ; SI: BUFFER_STORE_DWORD v[[LO_VREG]], -define void @trunc_shl_i64(i32 addrspace(1)* %out, i64 %a) { - %b = shl i64 %a, 2 +define void @trunc_shl_i64(i64 addrspace(1)* %out2, i32 addrspace(1)* %out, i64 %a) { + %aa = add i64 %a, 234 ; Prevent shrinking store. + %b = shl i64 %aa, 2 %result = trunc i64 %b to i32 store i32 %result, i32 addrspace(1)* %out, align 4 + store i64 %b, i64 addrspace(1)* %out2, align 8 ; Prevent reducing ops to 32-bits + ret void +} + +; SI-LABEL: @trunc_i32_to_i1: +; SI: V_AND_B32 +; SI: V_CMP_EQ_I32 +define void @trunc_i32_to_i1(i32 addrspace(1)* %out, i32 %a) { + %trunc = trunc i32 %a to i1 + %result = select i1 %trunc, i32 1, i32 0 + store i32 %result, i32 addrspace(1)* %out, align 4 ret void } |