From: Matthias Braun Date: Sun, 4 Dec 2016 05:48:06 +0000 (+0000) Subject: TableGen: Optimize common string concatenation with SmallString X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=607c68326d6351e3f88983d67f966ff2f120b344;p=llvm TableGen: Optimize common string concatenation with SmallString git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@288611 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/TableGen/Record.cpp b/lib/TableGen/Record.cpp index 3e1be837039..a82c38186db 100644 --- a/lib/TableGen/Record.cpp +++ b/lib/TableGen/Record.cpp @@ -15,6 +15,7 @@ #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/FoldingSet.h" #include "llvm/ADT/Hashing.h" +#include "llvm/ADT/SmallString.h" #include "llvm/ADT/SmallVector.h" #include "llvm/ADT/StringExtras.h" #include "llvm/ADT/StringMap.h" @@ -839,8 +840,12 @@ Init *BinOpInit::Fold(Record *CurRec, MultiClass *CurMultiClass) const { case STRCONCAT: { StringInit *LHSs = dyn_cast(LHS); StringInit *RHSs = dyn_cast(RHS); - if (LHSs && RHSs) - return StringInit::get(LHSs->getValue() + RHSs->getValue()); + if (LHSs && RHSs) { + // STRCONCAT is common; Use a SmallString to avoid most heap allocations. + SmallString<80> Concat(LHSs->getValue()); + Concat.append(RHSs->getValue()); + return StringInit::get(Concat); + } break; } case EQ: {