mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-10 22:43:53 +00:00
![Matt Arsenault](/assets/img/avatar_default.png)
This was for some reason skipping operands that are subregisters instead of keeping the same subregister index. v_movreld_b32 expects src0 to be the subregister of the tied super register use/def. e.g. v_movreld_b32 v0, v9, <imp-def, tied3> v[0:3], <imp-use, tied2> v[0:3] was being replaced with v[4:7] = copy v[0:3] v_movreld_b32 v0, v9, <imp-def, tied3> v[4:7], <imp-use, tied2> v[4:7], which really writes to v[0:3] llvm-svn: 279804
20 lines
701 B
LLVM
20 lines
701 B
LLVM
; RUN: llc -O0 -march=amdgcn -verify-machineinstrs < %s | FileCheck %s
|
|
|
|
; FIXME: Merge into indirect-addressing-si.ll
|
|
|
|
; Make sure that TwoAddressInstructions keeps src0 as subregister sub0
|
|
; of the tied implicit use and def of the super register.
|
|
|
|
; CHECK-LABEL: {{^}}insert_wo_offset:
|
|
; CHECK: s_load_dword [[IN:s[0-9]+]]
|
|
; CHECK: s_mov_b32 m0, [[IN]]
|
|
; CHECK: v_movreld_b32_e32 v[[ELT0:[0-9]+]]
|
|
; CHECK-NEXT: buffer_store_dwordx4 v{{\[}}[[ELT0]]:
|
|
define void @insert_wo_offset(<4 x float> addrspace(1)* %out, i32 %in) {
|
|
entry:
|
|
%ins = insertelement <4 x float> <float 1.0, float 2.0, float 3.0, float 4.0>, float 5.0, i32 %in
|
|
store <4 x float> %ins, <4 x float> addrspace(1)* %out
|
|
ret void
|
|
}
|
|
|