Add A0 and A1 to the list of registers used for returning a value in order to

handle functions with return type Complex long long.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133497 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Akira Hatanaka 2011-06-21 01:28:11 +00:00
parent 5f7451ff6e
commit 805569f54a

View File

@ -20,8 +20,8 @@ class CCIfSubtarget<string F, CCAction A>:
// Only the return rules are defined here for O32. The rules for argument // Only the return rules are defined here for O32. The rules for argument
// passing are defined in MipsISelLowering.cpp. // passing are defined in MipsISelLowering.cpp.
def RetCC_MipsO32 : CallingConv<[ def RetCC_MipsO32 : CallingConv<[
// i32 are returned in registers V0, V1 // i32 are returned in registers V0, V1, A0, A1
CCIfType<[i32], CCAssignToReg<[V0, V1]>>, CCIfType<[i32], CCAssignToReg<[V0, V1, A0, A1]>>,
// f32 are returned in registers F0, F2 // f32 are returned in registers F0, F2
CCIfType<[f32], CCAssignToReg<[F0, F2]>>, CCIfType<[f32], CCAssignToReg<[F0, F2]>>,