diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2007-08-10 14:44:42 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2007-08-10 14:44:42 +0000 |
commit | 66011c17d539d1ec93a145d7db6c0381494a826f (patch) | |
tree | 0d9ce18681afc45758931ed86a970699dcae4734 /llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | |
parent | 7014615087b8f4cdc65cff301c79f30dfb5a2734 (diff) | |
download | bcm5719-llvm-66011c17d539d1ec93a145d7db6c0381494a826f.tar.gz bcm5719-llvm-66011c17d539d1ec93a145d7db6c0381494a826f.zip |
propagate struct size and alignment of byval arguments to the DAG
llvm-svn: 40986
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index afb681f9bd6..df40972196b 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -3836,8 +3836,15 @@ TargetLowering::LowerArguments(Function &F, SelectionDAG &DAG) { Flags |= ISD::ParamFlags::InReg; if (Attrs && Attrs->paramHasAttr(j, ParamAttr::StructRet)) Flags |= ISD::ParamFlags::StructReturn; - if (Attrs && Attrs->paramHasAttr(j, ParamAttr::ByVal)) + if (Attrs && Attrs->paramHasAttr(j, ParamAttr::ByVal)) { Flags |= ISD::ParamFlags::ByVal; + const PointerType *Ty = cast<PointerType>(I->getType()); + const StructType *STy = cast<StructType>(Ty->getElementType()); + unsigned StructAlign = Log2_32(getTargetData()->getABITypeAlignment(STy)); + unsigned StructSize = getTargetData()->getTypeSize(STy); + Flags |= (StructAlign << ISD::ParamFlags::ByValAlignOffs); + Flags |= (StructSize << ISD::ParamFlags::ByValSizeOffs); + } if (Attrs && Attrs->paramHasAttr(j, ParamAttr::Nest)) Flags |= ISD::ParamFlags::Nest; Flags |= (OriginalAlignment << ISD::ParamFlags::OrigAlignmentOffs); |