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) {
|
ArgDI != ArgDE; ++ArgDI) {
|
||||||
if (ArgDI->Flags.isByVal() && ArgDI->Flags.getByValSize()) {
|
if (ArgDI->Flags.isByVal() && ArgDI->Flags.getByValSize()) {
|
||||||
unsigned Size = 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.
|
// Create a new object on the stack and copy the pointee into it.
|
||||||
int FI = MFI->CreateStackObject(Size, Align, false, false);
|
int FI = MFI->CreateStackObject(Size, Align, false, false);
|
||||||
SDValue FIN = DAG.getFrameIndex(FI, MVT::i32);
|
SDValue FIN = DAG.getFrameIndex(FI, MVT::i32);
|
||||||
|
|
|
@ -56,3 +56,18 @@ entry:
|
||||||
call void @f2(i32 %i, %struct.st2* %s2)
|
call void @f2(i32 %i, %struct.st2* %s2)
|
||||||
ret void
|
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