This revision was automatically updated to reflect the committed changes. Closed by commit rGdf4fa53fddb6: [clang][Checkers] Extend PthreadLockChecker state dump (NFC). (authored by balazske).
Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D98502/new/ https://reviews.llvm.org/D98502 Files: clang/lib/StaticAnalyzer/Checkers/PthreadLockChecker.cpp clang/test/Analysis/pthreadlock_state.c clang/test/Analysis/pthreadlock_state_nottracked.c
Index: clang/test/Analysis/pthreadlock_state_nottracked.c =================================================================== --- /dev/null +++ clang/test/Analysis/pthreadlock_state_nottracked.c @@ -0,0 +1,22 @@ +// RUN: %clang_analyze_cc1 -analyzer-checker=core,alpha.unix.PthreadLock,debug.ExprInspection 2>&1 %s | FileCheck %s + +#include "Inputs/system-header-simulator-for-pthread-lock.h" + +#define NULL 0 + +void clang_analyzer_printState(); + +void test(pthread_mutex_t *mtx) { + int ret = pthread_mutex_destroy(mtx); + clang_analyzer_printState(); + // CHECK: { "checker": "alpha.core.PthreadLockBase", "messages": [ + // CHECK-NEXT: "Mutex states:", + // CHECK-NEXT: "SymRegion{reg_$[[REG:[0-9]+]]<pthread_mutex_t * mtx>}: not tracked, possibly destroyed", + // CHECK-NEXT: "Mutexes in unresolved possibly destroyed state:", + // CHECK-NEXT: "SymRegion{reg_$[[REG]]<pthread_mutex_t * mtx>}: conj_$ + // CHECK-NEXT: "" + // CHECK-NEXT: ]} + if (ret) + return; + pthread_mutex_init(mtx, NULL); +} Index: clang/test/Analysis/pthreadlock_state.c =================================================================== --- /dev/null +++ clang/test/Analysis/pthreadlock_state.c @@ -0,0 +1,60 @@ +// RUN: %clang_analyze_cc1 -analyzer-checker=core,alpha.unix.PthreadLock,debug.ExprInspection 2>&1 %s | FileCheck %s + +#include "Inputs/system-header-simulator-for-pthread-lock.h" + +#define NULL 0 + +void clang_analyzer_printState(); + +pthread_mutex_t mtx; + +void test() { + clang_analyzer_printState(); + // CHECK: "checker_messages": null + + pthread_mutex_init(&mtx, NULL); + clang_analyzer_printState(); + // CHECK: { "checker": "alpha.core.PthreadLockBase", "messages": [ + // CHECK-NEXT: "Mutex states:", + // CHECK-NEXT: "mtx: unlocked", + // CHECK-NEXT: "" + // CHECK-NEXT: ]} + + pthread_mutex_lock(&mtx); + clang_analyzer_printState(); + // CHECK: { "checker": "alpha.core.PthreadLockBase", "messages": [ + // CHECK-NEXT: "Mutex states:", + // CHECK-NEXT: "mtx: locked", + // CHECK-NEXT: "Mutex lock order:", + // CHECK-NEXT: "mtx", + // CHECK-NEXT: "" + // CHECK-NEXT: ]} + + pthread_mutex_unlock(&mtx); + clang_analyzer_printState(); + // CHECK: { "checker": "alpha.core.PthreadLockBase", "messages": [ + // CHECK-NEXT: "Mutex states:", + // CHECK-NEXT: "mtx: unlocked", + // CHECK-NEXT: "" + // CHECK-NEXT: ]} + + int ret = pthread_mutex_destroy(&mtx); + clang_analyzer_printState(); + // CHECK: { "checker": "alpha.core.PthreadLockBase", "messages": [ + // CHECK-NEXT: "Mutex states:", + // CHECK-NEXT: "mtx: unlocked, possibly destroyed", + // CHECK-NEXT: "Mutexes in unresolved possibly destroyed state:", + // CHECK-NEXT: "mtx: conj_$ + // CHECK-NEXT: "" + // CHECK-NEXT: ]} + + if (ret) + return; + + clang_analyzer_printState(); + // CHECK: { "checker": "alpha.core.PthreadLockBase", "messages": [ + // CHECK-NEXT: "Mutex states:", + // CHECK-NEXT: "mtx: destroyed", + // CHECK-NEXT: "" + // CHECK-NEXT: ]} +} Index: clang/lib/StaticAnalyzer/Checkers/PthreadLockChecker.cpp =================================================================== --- clang/lib/StaticAnalyzer/Checkers/PthreadLockChecker.cpp +++ clang/lib/StaticAnalyzer/Checkers/PthreadLockChecker.cpp @@ -339,7 +339,16 @@ } } - // TODO: Dump destroyed mutex symbols? + DestroyRetValTy DRV = State->get<DestroyRetVal>(); + if (!DRV.isEmpty()) { + Out << Sep << "Mutexes in unresolved possibly destroyed state:" << NL; + for (auto I : DRV) { + I.first->dumpToStream(Out); + Out << ": "; + I.second->dumpToStream(Out); + Out << NL; + } + } } void PthreadLockChecker::AcquirePthreadLock(const CallEvent &Call,
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits