aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorMartin Sebor <msebor@redhat.com>2020-01-28 14:48:52 -0700
committerMartin Sebor <msebor@redhat.com>2020-01-28 14:48:52 -0700
commit4dd27b527c503aa50909fe1eb7d308266b1e103a (patch)
treecedf0cab6949d210af7452dd55289525e60f7a9f /gcc
parenta4b4b1e3ac9a2c97f7550024c3cc5aff52e0614c (diff)
downloadgcc-4dd27b527c503aa50909fe1eb7d308266b1e103a.zip
gcc-4dd27b527c503aa50909fe1eb7d308266b1e103a.tar.gz
gcc-4dd27b527c503aa50909fe1eb7d308266b1e103a.tar.bz2
PR middle-end/93437 - bogus -Warray-bounds on protobuf generated code
gcc/testsuite/ChangeLog: PR middle-end/93437 * g++.dg/warn/Wstringop-overflow-5.C: New test.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/warn/Wstringop-overflow-5.C37
2 files changed, 42 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 8610164..279ab64 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2020-01-28 Martin Sebor <msebor@redhat.com>
+
+ PR middle-end/93437
+ * g++.dg/warn/Wstringop-overflow-5.C: New test.a
+
2020-01-28 Jan Hubicka <hubicka@ucw.cz>
* g++.dg/tree-prof/indir-call-prof.C: Update template.
diff --git a/gcc/testsuite/g++.dg/warn/Wstringop-overflow-5.C b/gcc/testsuite/g++.dg/warn/Wstringop-overflow-5.C
new file mode 100644
index 0000000..3e905fc
--- /dev/null
+++ b/gcc/testsuite/g++.dg/warn/Wstringop-overflow-5.C
@@ -0,0 +1,37 @@
+/* PR middle-end/93437 - bogus -Warray-bounds on protobuf generated code
+ { dg-do compile }
+ { dg-options "-O3 -Wall" } */
+
+typedef __SIZE_TYPE__ size_t;
+typedef __UINT32_TYPE__ uint32_t;
+
+inline void* operator new (size_t, void* p)
+{
+ return p;
+}
+
+extern "C" void* memset(void*, int, size_t);
+
+struct Bucket {
+ Bucket ();
+ uint32_t _has_bits_;
+ uint32_t cumulative_count_;
+ uint32_t upper_bound_;
+};
+
+extern Bucket _Bucket_default_instance_;
+
+Bucket::Bucket ()
+{
+ memset (&_has_bits_, 0, sizeof _has_bits_);
+ memset (&cumulative_count_, 0, // { dg-bogus "\\\[-Warray-bounds|-wstringop-overflow" }
+ static_cast<size_t>(reinterpret_cast<char*>(&upper_bound_)
+ - reinterpret_cast<char*>(&cumulative_count_))
+ + sizeof upper_bound_);
+}
+
+void* InitDefaultsBucket ()
+{
+ void* ptr = &::_Bucket_default_instance_;
+ return new (ptr)::Bucket();
+}