forked from OSchip/llvm-project
[analyzer][UninitializedObjectChecker] PR41590: Regard _Atomic types as primitive
https://bugs.llvm.org/show_bug.cgi?id=41590 For the following code snippet, UninitializedObjectChecker crashed: struct MyAtomicInt { _Atomic(int) x; MyAtomicInt() {} }; void entry() { MyAtomicInt b; } The problem was that _Atomic types were not regular records, unions, dereferencable or primitive, making the checker hit the llvm_unreachable at lib/StaticAnalyzer/Checkers/UninitializedObject/UninitializedObjectChecker.cpp:347. The solution is to regard these types as primitive as well. The test case shows that with this addition, not only are we able to get rid of the crash, but we can identify x as uninitialized. Differential Revision: https://reviews.llvm.org/D61106 llvm-svn: 359230
This commit is contained in:
parent
65d4d5e9e7
commit
f46c58e0c6
|
@ -324,7 +324,7 @@ private:
|
|||
inline bool isPrimitiveType(const QualType &T) {
|
||||
return T->isBuiltinType() || T->isEnumeralType() ||
|
||||
T->isMemberPointerType() || T->isBlockPointerType() ||
|
||||
T->isFunctionType();
|
||||
T->isFunctionType() || T->isAtomicType();
|
||||
}
|
||||
|
||||
inline bool isDereferencableType(const QualType &T) {
|
||||
|
|
|
@ -1130,3 +1130,18 @@ void fCXX11MemberInitTest2() {
|
|||
// TODO: we'd expect the warning: {{2 uninitializeds field}}
|
||||
CXX11MemberInitTest2(); // no-warning
|
||||
}
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// _Atomic tests.
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
struct MyAtomicInt {
|
||||
_Atomic(int) x; // expected-note{{uninitialized field 'this->x'}}
|
||||
int dontGetFilteredByNonPedanticMode = 0;
|
||||
|
||||
MyAtomicInt() {} // expected-warning{{1 uninitialized field}}
|
||||
};
|
||||
|
||||
void entry() {
|
||||
MyAtomicInt b;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue