mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
a377b2bbd1
Before: _main: subq $8, %rsp leaq _X(%rip), %rax movsd 8(%rax), %xmm1 movss _X(%rip), %xmm0 call _t xorl %ecx, %ecx movl %ecx, %eax addq $8, %rsp ret Now: _main: subq $8, %rsp movsd _X+8(%rip), %xmm1 movss _X(%rip), %xmm0 call _t xorl %ecx, %ecx movl %ecx, %eax addq $8, %rsp ret Notice there is another idiotic codegen issue that needs to be fixed asap: xorl %ecx, %ecx movl %ecx, %eax llvm-svn: 46850
15 lines
544 B
LLVM
15 lines
544 B
LLVM
; RUN: llvm-as < %s | llc -mtriple=x86_64-apple-darwin | not grep lea
|
|
|
|
%struct.x = type { float, double }
|
|
@X = global %struct.x { float 1.000000e+00, double 2.000000e+00 }, align 16 ; <%struct.x*> [#uses=2]
|
|
|
|
define i32 @main() nounwind {
|
|
entry:
|
|
%tmp2 = load float* getelementptr (%struct.x* @X, i32 0, i32 0), align 16 ; <float> [#uses=1]
|
|
%tmp4 = load double* getelementptr (%struct.x* @X, i32 0, i32 1), align 8 ; <double> [#uses=1]
|
|
tail call void @t( float %tmp2, double %tmp4 ) nounwind
|
|
ret i32 0
|
|
}
|
|
|
|
declare void @t(float, double)
|