forked from OSchip/llvm-project
XCore target: fix bug in aligning 'byval i8*' on the stack
llvm-svn: 194466
This commit is contained in:
parent
f7f0c5e326
commit
494591b87f
|
@ -1224,7 +1224,7 @@ XCoreTargetLowering::LowerCCCArguments(SDValue Chain,
|
|||
ArgDI != ArgDE; ++ArgDI) {
|
||||
if (ArgDI->Flags.isByVal() && ArgDI->Flags.getByValSize()) {
|
||||
unsigned Size = ArgDI->Flags.getByValSize();
|
||||
unsigned Align = ArgDI->Flags.getByValAlign();
|
||||
unsigned Align = std::max(StackSlotSize, ArgDI->Flags.getByValAlign());
|
||||
// Create a new object on the stack and copy the pointee into it.
|
||||
int FI = MFI->CreateStackObject(Size, Align, false, false);
|
||||
SDValue FIN = DAG.getFrameIndex(FI, MVT::i32);
|
||||
|
|
|
@ -56,3 +56,18 @@ entry:
|
|||
call void @f2(i32 %i, %struct.st2* %s2)
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK-LABEL: f3Test
|
||||
; CHECK: entsp 2
|
||||
; CHECK: ldc r1, 0
|
||||
; CHECK: ld8u r2, r0[r1]
|
||||
; CHECK: ldaw r0, sp[1]
|
||||
; CHECK: st8 r2, r0[r1]
|
||||
; CHECK: bl f
|
||||
; CHECK: retsp 2
|
||||
declare void @f3(i8*) nounwind
|
||||
define void @f3Test(i8* byval %v) nounwind {
|
||||
entry:
|
||||
call void @f3(i8* %v) nounwind
|
||||
ret void
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue