diff options
author | Gabor Marton <gabor.marton@ericsson.com> | 2020-01-10 16:51:14 +0100 |
---|---|---|
committer | Gabor Marton <gabor.marton@ericsson.com> | 2020-01-10 17:59:06 +0100 |
commit | 5e7beb0a4146267f1d65c57543e67ca158aca4aa (patch) | |
tree | 5252392205ad00370004e139557f6f4e9f1381bf /clang/test/Analysis/placement-new-user-defined.cpp | |
parent | e9331a56fead1823d528d6412828fb9e16fd62ff (diff) | |
download | bcm5719-llvm-5e7beb0a4146267f1d65c57543e67ca158aca4aa.tar.gz bcm5719-llvm-5e7beb0a4146267f1d65c57543e67ca158aca4aa.zip |
[analyzer] Add PlacementNewChecker
Summary:
This checker verifies if default placement new is provided with pointers
to sufficient storage capacity.
Noncompliant Code Example:
#include <new>
void f() {
short s;
long *lp = ::new (&s) long;
}
Based on SEI CERT rule MEM54-CPP
https://wiki.sei.cmu.edu/confluence/display/cplusplus/MEM54-CPP.+Provide+placement+new+with+properly+aligned+pointe
This patch does not implement checking of the alignment.
Reviewers: NoQ, xazax.hun
Subscribers: mgorny, whisperity, xazax.hun, baloghadamsoftware, szepet,
rnkovacs, a.sidorin, mikhail.ramalho, donat
Tags: #clang
Differential Revision: https://reviews.llvm.org/D71612
Diffstat (limited to 'clang/test/Analysis/placement-new-user-defined.cpp')
-rw-r--r-- | clang/test/Analysis/placement-new-user-defined.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/clang/test/Analysis/placement-new-user-defined.cpp b/clang/test/Analysis/placement-new-user-defined.cpp new file mode 100644 index 00000000000..b3fe47057f8 --- /dev/null +++ b/clang/test/Analysis/placement-new-user-defined.cpp @@ -0,0 +1,22 @@ +// RUN: %clang_analyze_cc1 -std=c++11 %s \ +// RUN: -analyzer-checker=core \ +// RUN: -analyzer-checker=cplusplus.NewDelete \ +// RUN: -analyzer-checker=cplusplus.PlacementNew \ +// RUN: -analyzer-output=text -verify \ +// RUN: -triple x86_64-unknown-linux-gnu + +// expected-no-diagnostics + +#include "Inputs/system-header-simulator-cxx.h" + +struct X { + static void *operator new(std::size_t sz, void *b) { + return ::operator new(sz, b); + } + long l; +}; +void f() { + short buf; + X *p1 = new (&buf) X; + (void)p1; +} |