mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-17 03:07:06 +00:00
1887c1c2f9
1. x86-64 byval alignment should be max of 8 and alignment of type. Previously the code was not doing what the commit message was saying. 2. Do not use byte repeat move and store operations. These are slow. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55139 91177308-0d34-0410-b5e6-96231b3b80d8
26 lines
832 B
LLVM
26 lines
832 B
LLVM
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i686-pc-linux-gnu | grep movs | count 1
|
|
|
|
@A = global [32 x i32] zeroinitializer
|
|
@B = global [32 x i32] zeroinitializer
|
|
|
|
declare void @llvm.memcpy.i32(i8*, i8*, i32, i32)
|
|
|
|
define void @main() nounwind {
|
|
; dword copy
|
|
call void @llvm.memcpy.i32(i8* bitcast ([32 x i32]* @A to i8*),
|
|
i8* bitcast ([32 x i32]* @B to i8*),
|
|
i32 128, i32 4 )
|
|
|
|
; word copy
|
|
call void @llvm.memcpy.i32( i8* bitcast ([32 x i32]* @A to i8*),
|
|
i8* bitcast ([32 x i32]* @B to i8*),
|
|
i32 128, i32 2 )
|
|
|
|
; byte copy
|
|
call void @llvm.memcpy.i32( i8* bitcast ([32 x i32]* @A to i8*),
|
|
i8* bitcast ([32 x i32]* @B to i8*),
|
|
i32 128, i32 1 )
|
|
|
|
ret void
|
|
}
|