llvm-6502/test/CodeGen/X86/cdecl-method-return.ll
2014-01-31 22:58:10 +00:00

70 lines
1.8 KiB
LLVM

; RUN: llc < %s -mtriple=i686-pc-win32 -mcpu=core2 | FileCheck %s
; The sret flag causes the first two parameters to be reordered on the stack.
define x86_cdeclmethodcc void @foo(i32* sret %dst, i32* %src) {
%v = load i32* %src
store i32 %v, i32* %dst
ret void
}
; CHECK-LABEL: _foo:
; CHECK: movl 8(%esp), %[[dst:[^ ]*]]
; CHECK: movl 4(%esp), %[[src:[^ ]*]]
; CHECK: movl (%[[src]]), %[[v:[^ ]*]]
; CHECK: movl %[[v]], (%[[dst]])
; CHECK: retl
define i32 @bar() {
%src = alloca i32
%dst = alloca i32
store i32 42, i32* %src
call x86_cdeclmethodcc void @foo(i32* sret %dst, i32* %src)
%v = load i32* %dst
ret i32 %v
}
; CHECK-LABEL: _bar:
; CHECK: movl $42, [[src:[^,]*]]
; CHECK: leal [[src]], %[[reg:[^ ]*]]
; CHECK: movl %[[reg]], (%esp)
; CHECK: leal [[dst:[^,]*]], %[[reg:[^ ]*]]
; CHECK: movl %[[reg]], 4(%esp)
; CHECK: calll _foo
; CHECK: movl [[dst]], %eax
; CHECK: retl
; If we don't have the sret flag, parameters are not reordered.
define x86_cdeclmethodcc void @baz(i32* %dst, i32* %src) {
%v = load i32* %src
store i32 %v, i32* %dst
ret void
}
; CHECK-LABEL: _baz:
; CHECK: movl 4(%esp), %[[dst:[^ ]*]]
; CHECK: movl 8(%esp), %[[src:[^ ]*]]
; CHECK: movl (%[[src]]), %[[v:[^ ]*]]
; CHECK: movl %[[v]], (%[[dst]])
; CHECK: retl
define i32 @qux() {
%src = alloca i32
%dst = alloca i32
store i32 42, i32* %src
call x86_cdeclmethodcc void @baz(i32* %dst, i32* %src)
%v = load i32* %dst
ret i32 %v
}
; CHECK-LABEL: _qux:
; CHECK: movl $42, [[src:[^,]*]]
; CHECK: leal [[src]], %[[reg:[^ ]*]]
; CHECK: movl %[[reg]], 4(%esp)
; CHECK: leal [[dst:[^,]*]], %[[reg:[^ ]*]]
; CHECK: movl %[[reg]], (%esp)
; CHECK: calll _baz
; CHECK: movl [[dst]], %eax
; CHECK: retl