diff options
author | George Karpenkov <ekarpenkov@apple.com> | 2018-09-06 23:07:26 +0000 |
---|---|---|
committer | George Karpenkov <ekarpenkov@apple.com> | 2018-09-06 23:07:26 +0000 |
commit | e40d4053ba8a3ef9eb22eddb8a747e3a1c8a2450 (patch) | |
tree | 607e61f91162b280e2e2afe60a6f453ac1de24d0 /clang/lib/StaticAnalyzer/Core | |
parent | 459732edbb741ba3794a82de80b91b7bc014860b (diff) | |
download | bcm5719-llvm-e40d4053ba8a3ef9eb22eddb8a747e3a1c8a2450.tar.gz bcm5719-llvm-e40d4053ba8a3ef9eb22eddb8a747e3a1c8a2450.zip |
[analyzer] Dump a reproducible, deterministic ID of program state to exploded graph
Differential Revision: https://reviews.llvm.org/D51395
llvm-svn: 341600
Diffstat (limited to 'clang/lib/StaticAnalyzer/Core')
-rw-r--r-- | clang/lib/StaticAnalyzer/Core/ExprEngine.cpp | 3 | ||||
-rw-r--r-- | clang/lib/StaticAnalyzer/Core/ProgramState.cpp | 7 |
2 files changed, 9 insertions, 1 deletions
diff --git a/clang/lib/StaticAnalyzer/Core/ExprEngine.cpp b/clang/lib/StaticAnalyzer/Core/ExprEngine.cpp index 04190deb7a8..a9901a6cd7d 100644 --- a/clang/lib/StaticAnalyzer/Core/ExprEngine.cpp +++ b/clang/lib/StaticAnalyzer/Core/ExprEngine.cpp @@ -3141,7 +3141,8 @@ struct DOTGraphTraits<ExplodedNode*> : public DefaultDOTGraphTraits { } ProgramStateRef state = N->getState(); - Out << "\\|StateID: " << (const void*) state.get() + Out << "\\|StateID: " << state->getID() << " (" + << (const void*) state.get() << ")" << " NodeID: " << (const void*) N << "\\|"; state->printDOT(Out, N->getLocationContext()); diff --git a/clang/lib/StaticAnalyzer/Core/ProgramState.cpp b/clang/lib/StaticAnalyzer/Core/ProgramState.cpp index 94e2e00d8bb..361255b4b18 100644 --- a/clang/lib/StaticAnalyzer/Core/ProgramState.cpp +++ b/clang/lib/StaticAnalyzer/Core/ProgramState.cpp @@ -69,6 +69,13 @@ ProgramState::~ProgramState() { stateMgr->getStoreManager().decrementReferenceCount(store); } +int64_t ProgramState::getID() const { + Optional<int64_t> Out = getStateManager().Alloc.identifyObject(this); + assert(Out && "Wrong allocator used"); + assert(*Out % alignof(ProgramState) == 0 && "Wrong alignment information"); + return *Out / alignof(ProgramState); +} + ProgramStateManager::ProgramStateManager(ASTContext &Ctx, StoreManagerCreator CreateSMgr, ConstraintManagerCreator CreateCMgr, |