From: Johannes Doerfert Date: Wed, 4 Sep 2019 16:36:54 +0000 (+0000) Subject: [Attributor][NFC] Add assertion to guard against accidental misuse X-Git-Tag: llvmorg-11-init~10056 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=912edafcf146353997a40466606b730d60f9f8d2;p=platform%2Fupstream%2Fllvm.git [Attributor][NFC] Add assertion to guard against accidental misuse llvm-svn: 370925 --- diff --git a/llvm/include/llvm/Transforms/IPO/Attributor.h b/llvm/include/llvm/Transforms/IPO/Attributor.h index 518f618..88299cd 100644 --- a/llvm/include/llvm/Transforms/IPO/Attributor.h +++ b/llvm/include/llvm/Transforms/IPO/Attributor.h @@ -674,7 +674,10 @@ struct Attributor { // Put the attribute in the lookup map structure and the container we use to // keep track of all attributes. IRPosition &IRP = AA.getIRPosition(); - AAMap[IRP][&AAType::ID] = &AA; + auto &KindToAbstractAttributeMap = AAMap[IRP]; + assert(!KindToAbstractAttributeMap.count(&AAType::ID) && + "Attribute already in map!"); + KindToAbstractAttributeMap[&AAType::ID] = &AA; AllAbstractAttributes.push_back(&AA); return AA; } @@ -821,8 +824,7 @@ private: // Lookup the abstract attribute of type AAType. If found, return it after // registering a dependence of QueryingAA on the one returned attribute. - const auto &KindToAbstractAttributeMap = - AAMap.lookup(const_cast(IRP)); + const auto &KindToAbstractAttributeMap = AAMap.lookup(IRP); if (AAType *AA = static_cast( KindToAbstractAttributeMap.lookup(&AAType::ID))) { // Do not register a dependence on an attribute with an invalid state.