summaryrefslogtreecommitdiffstats
path: root/clang/test/Analysis/placement-new-user-defined.cpp
diff options
context:
space:
mode:
authorGabor Marton <gabor.marton@ericsson.com>2020-01-10 16:51:14 +0100
committerGabor Marton <gabor.marton@ericsson.com>2020-01-10 17:59:06 +0100
commit5e7beb0a4146267f1d65c57543e67ca158aca4aa (patch)
tree5252392205ad00370004e139557f6f4e9f1381bf /clang/test/Analysis/placement-new-user-defined.cpp
parente9331a56fead1823d528d6412828fb9e16fd62ff (diff)
downloadbcm5719-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.cpp22
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;
+}
OpenPOWER on IntegriCloud