From 3acab9c5fe1f6b4818217820d65b4067ec51ad73 Mon Sep 17 00:00:00 2001 From: David Greene Date: Fri, 29 Jul 2011 19:07:19 +0000 Subject: [PATCH] [AVX] Make BinOpInit Unique Make sure BinOpInits are unique and created only once. This will be important for AVX/SIMD as many operators will be used to generate patterns and other relevant data. llvm-svn: 136495 --- llvm/utils/TableGen/Record.cpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/llvm/utils/TableGen/Record.cpp b/llvm/utils/TableGen/Record.cpp index 8fc0c18cd4b5..56a46e195b47 100644 --- a/llvm/utils/TableGen/Record.cpp +++ b/llvm/utils/TableGen/Record.cpp @@ -860,7 +860,20 @@ std::string UnOpInit::getAsString() const { const BinOpInit *BinOpInit::get(BinaryOp opc, const Init *lhs, const Init *rhs, RecTy *Type) { - return new BinOpInit(opc, lhs, rhs, Type); + typedef std::pair< + std::pair, const Init *>, + RecTy * + > Key; + + typedef DenseMap Pool; + static Pool ThePool; + + Key TheKey(std::make_pair(std::make_pair(std::make_pair(opc, lhs), rhs), + Type)); + + BinOpInit *&I = ThePool[TheKey]; + if (!I) I = new BinOpInit(opc, lhs, rhs, Type); + return I; } const Init *BinOpInit::Fold(Record *CurRec, MultiClass *CurMultiClass) const {