Skip to content

Commit 0da7585

Browse files
[NVPTX] Just use getTypeAllocSize() when computing return value size for structures and vectors
llvm-svn: 211925
1 parent dcb8632 commit 0da7585

File tree

1 file changed

+1
-17
lines changed

1 file changed

+1
-17
lines changed

llvm/lib/Target/NVPTX/NVPTXAsmPrinter.cpp

Lines changed: 1 addition & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -734,23 +734,7 @@ void NVPTXAsmPrinter::printReturnValStr(const Function *F, raw_ostream &O) {
734734
<< " func_retval0";
735735
} else {
736736
if ((Ty->getTypeID() == Type::StructTyID) || isa<VectorType>(Ty)) {
737-
SmallVector<EVT, 16> vtparts;
738-
ComputeValueVTs(*TLI, Ty, vtparts);
739-
unsigned totalsz = 0;
740-
for (unsigned i = 0, e = vtparts.size(); i != e; ++i) {
741-
unsigned elems = 1;
742-
EVT elemtype = vtparts[i];
743-
if (vtparts[i].isVector()) {
744-
elems = vtparts[i].getVectorNumElements();
745-
elemtype = vtparts[i].getVectorElementType();
746-
}
747-
for (unsigned j = 0, je = elems; j != je; ++j) {
748-
unsigned sz = elemtype.getSizeInBits();
749-
if (elemtype.isInteger() && (sz < 8))
750-
sz = 8;
751-
totalsz += sz / 8;
752-
}
753-
}
737+
unsigned totalsz = TD->getTypeAllocSize(Ty);
754738
unsigned retAlignment = 0;
755739
if (!llvm::getAlign(*F, 0, retAlignment))
756740
retAlignment = TD->getABITypeAlignment(Ty);

0 commit comments

Comments
 (0)