diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2012-05-27 22:41:08 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2012-05-27 22:41:08 +0000 |
commit | ea388a2832e997171cfddefc710d10543dcba2fd (patch) | |
tree | eb3afb451622548fae0bf069bd6d795c49001f58 /clang/lib | |
parent | 152f106e5f49f503168a7df8a672ea0f3332290a (diff) | |
download | bcm5719-llvm-ea388a2832e997171cfddefc710d10543dcba2fd.tar.gz bcm5719-llvm-ea388a2832e997171cfddefc710d10543dcba2fd.zip |
PR12962: Fix a rare use after free when collecting virtual overrides.
The DenseMap reallocates after 64 insertions so this only happened in
large test cases under very specific circumstances.
llvm-svn: 157549
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/AST/CXXInheritance.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/AST/CXXInheritance.cpp b/clang/lib/AST/CXXInheritance.cpp index 218673090aa..7e278ff234e 100644 --- a/clang/lib/AST/CXXInheritance.cpp +++ b/clang/lib/AST/CXXInheritance.cpp @@ -505,12 +505,17 @@ void FinalOverriderCollector::Collect(const CXXRecordDecl *RD, CXXFinalOverriderMap *BaseOverriders = &ComputedBaseOverriders; if (Base->isVirtual()) { CXXFinalOverriderMap *&MyVirtualOverriders = VirtualOverriders[BaseDecl]; + BaseOverriders = MyVirtualOverriders; if (!MyVirtualOverriders) { MyVirtualOverriders = new CXXFinalOverriderMap; + + // Collect may cause VirtualOverriders to reallocate, invalidating the + // MyVirtualOverriders reference. Set BaseOverriders to the right + // value now. + BaseOverriders = MyVirtualOverriders; + Collect(BaseDecl, true, BaseDecl, *MyVirtualOverriders); } - - BaseOverriders = MyVirtualOverriders; } else Collect(BaseDecl, false, InVirtualSubobject, ComputedBaseOverriders); |