]> granicus.if.org Git - clang/commitdiff
Prevent use after free caused by accessing a member into a dense set.
authorDaniel Jasper <djasper@google.com>
Wed, 18 Feb 2015 14:13:46 +0000 (14:13 +0000)
committerDaniel Jasper <djasper@google.com>
Wed, 18 Feb 2015 14:13:46 +0000 (14:13 +0000)
The member gets invalidated as elements are added to the dense set. Directly
access the underlying pointer instead. Not sure how to create a test case for
this :-(. Maybe Richard can help.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@229673 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Serialization/ASTReader.cpp

index a0cb7b506bdba7cb1d7e5403ed54018784048718..3125b8e43e9450152ab21a0b7a7588f4ab65d0b2 100644 (file)
@@ -6628,7 +6628,8 @@ ASTReader::FindExternalVisibleDeclsByName(const DeclContext *DC,
       auto Merged = MergedLookups.find(DC);
       if (Merged != MergedLookups.end()) {
         for (unsigned I = 0; I != Merged->second.size(); ++I) {
-          LookUpInContexts(Merged->second[I]);
+          const DeclContext *Context = Merged->second[I];
+          LookUpInContexts(Context);
           // We might have just added some more merged lookups. If so, our
           // iterator is now invalid, so grab a fresh one before continuing.
           Merged = MergedLookups.find(DC);