<html>
<head>
<base href="https://bugs.llvm.org/">
</head>
<body><table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Bug ID</th>
<td><a class="bz_bug_link
bz_status_NEW "
title="NEW - ASTImporterLookupTable.cpp:99 -- Assertion `EraseResult == true && "Trying to remove not contained Decl"'"
href="https://bugs.llvm.org/show_bug.cgi?id=48701">48701</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>ASTImporterLookupTable.cpp:99 -- Assertion `EraseResult == true && "Trying to remove not contained Decl"'
</td>
</tr>
<tr>
<th>Product</th>
<td>clang
</td>
</tr>
<tr>
<th>Version</th>
<td>trunk
</td>
</tr>
<tr>
<th>Hardware</th>
<td>PC
</td>
</tr>
<tr>
<th>OS</th>
<td>Windows NT
</td>
</tr>
<tr>
<th>Status</th>
<td>NEW
</td>
</tr>
<tr>
<th>Severity</th>
<td>enhancement
</td>
</tr>
<tr>
<th>Priority</th>
<td>P
</td>
</tr>
<tr>
<th>Component</th>
<td>Static Analyzer
</td>
</tr>
<tr>
<th>Assignee</th>
<td>dcoughlin@apple.com
</td>
</tr>
<tr>
<th>Reporter</th>
<td>vince.a.bridgers@gmail.com
</td>
</tr>
<tr>
<th>CC</th>
<td>dcoughlin@apple.com, llvm-bugs@lists.llvm.org
</td>
</tr></table>
<p>
<div>
<pre>We came across a crash in ASTImporterLookupTable.cpp:99, Assertion `EraseResult
== true && "Trying to remove not contained Decl"'. We narrowed this down due to
a regression caused by the following commit:
commit 3f6c856bb5ae4426a586426bca9f1ef2848a2b12
Author: Raphael Isemann <<a href="mailto:teemperor@gmail.com">teemperor@gmail.com</a>>
Date: Thu Nov 26 17:02:31 2020 +0100
This conclusion is inferred since the crash does not occur if this commit is
reverted.
crash.sh
--
clang -emit-ast -std=c++11 hpp_libc.cpp -o hpp_libc.cpp.ast
clang -emit-ast -std=c++11 hpp_state.cpp -o hpp_state.cpp.ast
clang --analyze -Xclang -analyzer-checker=core -Xclang -analyzer-config -Xclang
experimental-enable-naive-ctu-analysis=true -Xclang -analyzer-config -Xclang
ctu-dir=`pwd` -Xclang -analyzer-config -Xclang display-ctu-progress=true
-std=c++11 hpp_libc.cpp
externalDefMap.txt
--
c:@F@__assert_fail#*1C#S0_#i#S0_# hpp_libc.cpp.ast
c:@F@BHP_assertfail#*1C#S0_#S0_#S0_#1i#1i# hpp_state.cpp.ast
hpp_libc.cpp
--
void BHP_assertfail(const char* str, const char* assertFunction, const char* p,
const char* assertFile, const unsigned int assertLine, const unsigned int pe);
void __assert_fail(const char* __assertion, const char* __file, unsigned int
__line, const char* __function)
{
BHP_assertfail("Assert in %s: %s, file %s, line %d\n", __function,
__assertion, __file, __line, 0);
}
hpp_state.cpp
--
namespace std
{
typedef long unsigned int size_t;
}
namespace std __attribute__ ((__visibility__ ("default")))
{
template<class _CharT>
struct char_traits;
template<> struct char_traits<char>;
}
namespace std __attribute__ ((__visibility__ ("default")))
{
template<typename _CharT, typename _Traits = char_traits<_CharT> >
class istreambuf_iterator;
template<typename _CharT, typename _Traits = char_traits<_CharT> >
class ostreambuf_iterator;
template<typename _CharT, typename _Traits = char_traits<_CharT> >
class basic_fstream;
typedef basic_fstream<char> fstream;
}
extern "C++" {
namespace std
{
class exception
{
public:
exception() noexcept { }
virtual ~exception() noexcept;
};
} // namespace std
namespace std __attribute__ ((__visibility__ ("default")))
{
struct __true_type { };
struct __false_type { };
template<typename _Tp>
struct __is_char
{
enum { __value = 0 };
typedef __false_type __type;
};
template<typename _Tp>
struct __is_move_iterator
{
enum { __value = 0 };
typedef __false_type __type;
};
template<typename _Iterator>
inline _Iterator
__miter_base(_Iterator __it)
{ return __it; }
} // namespace
namespace __gnu_cxx __attribute__ ((__visibility__ ("default")))
{
template<bool, typename>
struct __enable_if
{ };
template<typename _Tp>
struct __enable_if<true, _Tp>
{ typedef _Tp __type; };
} // namespace
} // extern C++
namespace std __attribute__ ((__visibility__ ("default")))
{
template<typename _CharT>
struct char_traits;
template<typename _CharT, typename _Traits>
class istreambuf_iterator;
template<bool _IsMove, typename _CharT>
typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value,
ostreambuf_iterator<_CharT, char_traits<_CharT> > >::__type
__copy_move_a2(_CharT*, _CharT*,
ostreambuf_iterator<_CharT, char_traits<_CharT> >);
template<bool _IsMove, typename _CharT>
typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value,
_CharT*>::__type
__copy_move_a2(istreambuf_iterator<_CharT, char_traits<_CharT> >,
istreambuf_iterator<_CharT, char_traits<_CharT> >, _CharT*);
template<typename _II, typename _OI>
inline _OI
copy(_II __first, _II __last, _OI __result)
{
return (std::__copy_move_a2<__is_move_iterator<_II>::__value>
(std::__miter_base(__first), std::__miter_base(__last),
__result));
}
template<typename _II, typename _OI>
inline _OI
move(_II __first, _II __last, _OI __result)
{
}
} // namespace
namespace __gnu_cxx __attribute__ ((__visibility__ ("default")))
{
template<typename _CharT>
struct char_traits
{
typedef _CharT char_type;
static char_type*
copy(char_type* __s1, const char_type* __s2, std::size_t __n);
};
template<typename _CharT>
typename char_traits<_CharT>::char_type*
char_traits<_CharT>::
copy(char_type* __s1, const char_type* __s2, std::size_t __n)
{
std::copy(__s2, __s2 + __n, __s1);
return __s1;
}
} // namespace
namespace std __attribute__ ((__visibility__ ("default")))
{
template<class _CharT>
struct char_traits : public __gnu_cxx::char_traits<_CharT>
{ };
template<>
struct char_traits<char>
{
typedef char char_type;
};
class runtime_error : public exception {
public:
explicit runtime_error(const char * __arg) ;
};
} // namespace
namespace std __attribute__ ((__visibility__ ("default")))
{
class mutex {
public:
mutex() noexcept = default;
~mutex() = default;
};
template<typename _Mutex>
class unique_lock {
public:
unique_lock& operator=(unique_lock&& __u) noexcept {
unique_lock(std::move(__u)).swap(*this);
return *this;
}
};
} // namespace
void BHP_assertfail(const char* str, const char* assertFunction, const char* p,
const char* assertFile, const unsigned int assertLine, const unsigned int pe);
#pragma clang diagnostic ignored "-Wunused-parameter"
void BHP_assertfail(const char* str, const char* assertFunction, const char* p,
const char* assertFile, const unsigned int assertLine, const unsigned int pe)
{
throw(std::runtime_error("Assert failed"));
}
Top of crash stack (Edited)
---
CTU loaded AST file: hpp_state.cpp.ast
clang-12: <root>/clang/lib/AST/ASTImporterLookupTable.cpp:99: void
clang::ASTImporterLookupTable::remove(clang::DeclContext*, clang::NamedDecl*):
Assertion `EraseResult == true && "Trying to remove not contained Decl"'
failed.
PLEASE submit a bug report to <a href="https://bugs.llvm.org/">https://bugs.llvm.org/</a> and include the crash
backtrace, preprocessed source, and associated run script.
Stack dump:
0. Program arguments: clang-12 --analyze -Xclang -analyzer-checker=core
-Xclang -analyzer-config -Xclang experimental-enable-naive-ctu-analysis=true
-Xclang -analyzer-config -Xclang
ctu-dir=/repo/einvbri/llvm-project-open-famfix/ctu-crash -Xclang
-analyzer-config -Xclang display-ctu-progress=true -std=c++11 hpp_libc.cpp
1. <eof> parser at end of file
2. While analyzing stack:
#0 Calling __assert_fail
3. hpp_libc.cpp:6:3: Error evaluating statement
4. hpp_libc.cpp:6:3: Error evaluating statement
#0 0x0000000003d75077 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int)
<root>/llvm/lib/Support/Unix/Signals.inc:563:22
#1 0x0000000003d7512e PrintStackTraceSignalHandler(void*)
<root>/llvm/lib/Support/Unix/Signals.inc:630:1
#2 0x0000000003d73130 llvm::sys::RunSignalHandlers()
<root>/llvm/lib/Support/Signals.cpp:71:20
#3 0x0000000003d749eb llvm::sys::CleanupOnSignal(unsigned long)
<root>/llvm/lib/Support/Unix/Signals.inc:361:31
#4 0x0000000003cc0c38 (anonymous
namespace)::CrashRecoveryContextImpl::HandleCrash(int, unsigned long)
<root>/llvm/lib/Support/CrashRecoveryContext.cpp:75:5
#5 0x0000000003cc10d8 CrashRecoverySignalHandler(int)
<root>/llvm/lib/Support/CrashRecoveryContext.cpp:389:1
#6 0x00007f36edff4630 __restore_rt (/lib64/libpthread.so.0+0xf630)
#7 0x00007f36eb41c387 raise (/lib64/libc.so.6+0x36387)
#8 0x00007f36eb41da78 abort (/lib64/libc.so.6+0x37a78)
#9 0x00007f36eb4151a6 __assert_fail_base (/lib64/libc.so.6+0x2f1a6)
#10 0x00007f36eb415252 (/lib64/libc.so.6+0x2f252)
#11 0x0000000007fb4c21
clang::ASTImporterLookupTable::remove(clang::DeclContext*, clang::NamedDecl*)
<root>/clang/lib/AST/ASTImporterLookupTable.cpp:100:1
#12 0x0000000007fb4d2b
clang::ASTImporterLookupTable::remove(clang::NamedDecl*)
<root>/clang/lib/AST/ASTImporterLookupTable.cpp:115:64
#13 0x0000000007f727b9
clang::ASTImporterSharedState::removeDeclFromLookup(clang::Decl*)
<root>/clang/include/clang/AST/ASTImporterSharedState.h:65:3
#14 0x0000000007f6a7c8 clang::ASTImporter::Import(clang::Decl*)
<root>/clang/lib/AST/ASTImporter.cpp:8295:32
#15 0x0000000007f7b994 llvm::Expected<clang::NamedDecl*>
clang::ASTNodeImporter::import<clang::NamedDecl>(clang::NamedDecl*)
<root>/clang/lib/AST/ASTImporter.cpp:165:11
#16 0x0000000007f8cf33 llvm::Error
clang::ASTNodeImporter::ImportArrayChecked<clang::NamedDecl* const*,
clang::NamedDecl**>(clang::NamedDecl* const*, clang::NamedDecl* const*,
clang::NamedDecl**) <root>/clang/lib/AST/ASTImporter.cpp:653:13</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are on the CC list for the bug.</li>
</ul>
</body>
</html>