diff options
author | Graham Hunter <graham.hunter@arm.com> | 2019-07-05 12:48:16 +0000 |
---|---|---|
committer | Graham Hunter <graham.hunter@arm.com> | 2019-07-05 12:48:16 +0000 |
commit | 957c40db6aebcbcdc4c80614649f917d93b73b4f (patch) | |
tree | f36d9a8b676d948d1bc64b46a5eacce2bc84ae53 /llvm/lib/IR/AsmWriter.cpp | |
parent | 9dcfbbae76234818a748a7745c7ef8c89607f055 (diff) | |
download | bcm5719-llvm-957c40db6aebcbcdc4c80614649f917d93b73b4f.tar.gz bcm5719-llvm-957c40db6aebcbcdc4c80614649f917d93b73b4f.zip |
Scalable Vector IR Type with further LTO fixes
Reintroduces the scalable vector IR type from D32530, after it was reverted
a couple of times due to increasing chromium LTO build times. This latest
incarnation removes the walk over aggregate types from the verifier entirely,
in favor of rejecting scalable vectors in the isValidElementType methods in
ArrayType and StructType. This removes the 70% degradation observed with
the second repro tarball from PR42210.
Reviewers: thakis, hans, rengolin, sdesmalen
Reviewed By: sdesmalen
Differential Revision: https://reviews.llvm.org/D64079
llvm-svn: 365203
Diffstat (limited to 'llvm/lib/IR/AsmWriter.cpp')
-rw-r--r-- | llvm/lib/IR/AsmWriter.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/llvm/lib/IR/AsmWriter.cpp b/llvm/lib/IR/AsmWriter.cpp index a5adfd9c8a6..eb5760daecb 100644 --- a/llvm/lib/IR/AsmWriter.cpp +++ b/llvm/lib/IR/AsmWriter.cpp @@ -620,7 +620,10 @@ void TypePrinting::print(Type *Ty, raw_ostream &OS) { } case Type::VectorTyID: { VectorType *PTy = cast<VectorType>(Ty); - OS << "<" << PTy->getNumElements() << " x "; + OS << "<"; + if (PTy->isScalable()) + OS << "vscale x "; + OS << PTy->getNumElements() << " x "; print(PTy->getElementType(), OS); OS << '>'; return; |