mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-24 12:55:45 +00:00
Adding support for Microsoft's thiscall calling convention. LLVM side of the patch.
llvm-svn: 151123
This commit is contained in:
parent
87b4f40d41
commit
a76a5b7265
@ -331,8 +331,8 @@ def CC_X86_32_ThisCall : CallingConv<[
|
||||
// Promote i8/i16 arguments to i32.
|
||||
CCIfType<[i8, i16], CCPromoteToType<i32>>,
|
||||
|
||||
// The 'nest' parameter, if any, is passed in EAX.
|
||||
CCIfNest<CCAssignToReg<[EAX]>>,
|
||||
// Pass sret arguments indirectly through EAX
|
||||
CCIfSRet<CCAssignToReg<[EAX]>>,
|
||||
|
||||
// The first integer argument is passed in ECX
|
||||
CCIfType<[i32], CCAssignToReg<[ECX]>>,
|
||||
|
47
test/CodeGen/X86/thiscall-struct-return.ll
Normal file
47
test/CodeGen/X86/thiscall-struct-return.ll
Normal file
@ -0,0 +1,47 @@
|
||||
; RUN: llc < %s -mtriple=i386-PC-Win32 | FileCheck %s
|
||||
|
||||
%class.C = type { i8 }
|
||||
%struct.S = type { i32 }
|
||||
%struct.M = type { i32, i32 }
|
||||
|
||||
declare void @_ZN1CC1Ev(%class.C* %this) unnamed_addr nounwind align 2
|
||||
declare x86_thiscallcc void @_ZNK1C5SmallEv(%struct.S* noalias sret %agg.result, %class.C* %this) nounwind align 2
|
||||
declare x86_thiscallcc void @_ZNK1C6MediumEv(%struct.M* noalias sret %agg.result, %class.C* %this) nounwind align 2
|
||||
|
||||
define void @testv() nounwind {
|
||||
; CHECK: testv:
|
||||
; CHECK: leal
|
||||
; CHECK-NEXT: movl %esi, (%esp)
|
||||
; CHECK-NEXT: calll _ZN1CC1Ev
|
||||
; CHECK: leal 8(%esp), %eax
|
||||
; CHECK-NEXT: movl %esi, %ecx
|
||||
; CHECK-NEXT: calll _ZNK1C5SmallEv
|
||||
entry:
|
||||
%c = alloca %class.C, align 1
|
||||
%tmp = alloca %struct.S, align 4
|
||||
call void @_ZN1CC1Ev(%class.C* %c)
|
||||
; This call should put the return structure as a pointer
|
||||
; into EAX instead of returning directly in EAX. The this
|
||||
; pointer should go into ECX
|
||||
call x86_thiscallcc void @_ZNK1C5SmallEv(%struct.S* sret %tmp, %class.C* %c)
|
||||
ret void
|
||||
}
|
||||
|
||||
define void @test2v() nounwind {
|
||||
; CHECK: test2v:
|
||||
; CHECK: leal
|
||||
; CHECK-NEXT: movl %esi, (%esp)
|
||||
; CHECK-NEXT: calll _ZN1CC1Ev
|
||||
; CHECK: leal 8(%esp), %eax
|
||||
; CHECK-NEXT: movl %esi, %ecx
|
||||
; CHECK-NEXT: calll _ZNK1C6MediumEv
|
||||
entry:
|
||||
%c = alloca %class.C, align 1
|
||||
%tmp = alloca %struct.M, align 4
|
||||
call void @_ZN1CC1Ev(%class.C* %c)
|
||||
; This call should put the return structure as a pointer
|
||||
; into EAX instead of returning directly in EAX/EDX. The this
|
||||
; pointer should go into ECX
|
||||
call x86_thiscallcc void @_ZNK1C6MediumEv(%struct.M* sret %tmp, %class.C* %c)
|
||||
ret void
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user