2014-01-31 22:58:10 +00:00
|
|
|
; RUN: llc < %s -mtriple=i686-pc-win32 -mcpu=core2 | FileCheck %s
|
2014-01-31 17:41:22 +00:00
|
|
|
|
|
|
|
; 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
|