mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-23 15:29:51 +00:00
707e018423
on any current target and aren't optimized in DAGCombiner. Instead of using intermediate nodes, expand the operations, choosing between simple loads/stores, target-specific code, and library calls, immediately. Previously, the code to emit optimized code for these operations was only used at initial SelectionDAG construction time; now it is used at all times. This fixes some cases where rep;movs was being used for small copies where simple loads/stores would be better. This also cleans up code that checks for alignments less than 4; let the targets make that decision instead of doing it in target-independent code. This allows x86 to use rep;movs in low-alignment cases. Also, this fixes a bug that resulted in the use of rep;stos for memsets of 0 with non-constant memory size when the alignment was at least 4. It's better to use the library in this case, which can be significantly faster when the size is large. This also preserves more SourceValue information when memory intrinsics are lowered into simple loads/stores. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49572 91177308-0d34-0410-b5e6-96231b3b80d8
37 lines
1.5 KiB
LLVM
37 lines
1.5 KiB
LLVM
; RUN: llvm-as < %s | llc -march=x86-64 | grep rep.movsw | count 2
|
|
; RUN: llvm-as < %s | llc -march=x86 | grep rep.movsl | count 2
|
|
|
|
%struct.s = type { i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16, i16, i16, i16, i16, i16, i16, i16,
|
|
i16 }
|
|
|
|
|
|
define void @g(i16 signext %a1, i16 signext %a2, i16 signext %a3,
|
|
i16 signext %a4, i16 signext %a5, i16 signext %a6) {
|
|
entry:
|
|
%a = alloca %struct.s, align 16
|
|
%tmp = getelementptr %struct.s* %a, i32 0, i32 0
|
|
store i16 %a1, i16* %tmp, align 16
|
|
%tmp2 = getelementptr %struct.s* %a, i32 0, i32 1
|
|
store i16 %a2, i16* %tmp2, align 16
|
|
%tmp4 = getelementptr %struct.s* %a, i32 0, i32 2
|
|
store i16 %a3, i16* %tmp4, align 16
|
|
%tmp6 = getelementptr %struct.s* %a, i32 0, i32 3
|
|
store i16 %a4, i16* %tmp6, align 16
|
|
%tmp8 = getelementptr %struct.s* %a, i32 0, i32 4
|
|
store i16 %a5, i16* %tmp8, align 16
|
|
%tmp10 = getelementptr %struct.s* %a, i32 0, i32 5
|
|
store i16 %a6, i16* %tmp10, align 16
|
|
call void @f( %struct.s* %a byval )
|
|
call void @f( %struct.s* %a byval )
|
|
ret void
|
|
}
|
|
|
|
declare void @f(%struct.s* byval)
|