aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2018-08-08 10:31:40 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2018-08-08 10:31:40 +0200
commitbf533db8059e25668db76845390786e7fa5f3a76 (patch)
treef6a530fb390a2247b815a755871606b62181913b
parente75bc10e68f2c154eea18b87486e9da5cad0efaa (diff)
downloadgcc-bf533db8059e25668db76845390786e7fa5f3a76.zip
gcc-bf533db8059e25668db76845390786e7fa5f3a76.tar.gz
gcc-bf533db8059e25668db76845390786e7fa5f3a76.tar.bz2
re PR c++/86738 (gcc 8.2: Internal compiler error memcpy)
PR c++/86738 * constexpr.c (cxx_eval_binary_expression): For arithmetics involving NULL pointer set *non_constant_p to true. (cxx_eval_component_reference): For dereferencing of a NULL pointer, set *non_constant_p to true and return t. * g++.dg/opt/pr86738.C: New test. From-SVN: r263390
-rw-r--r--gcc/cp/ChangeLog8
-rw-r--r--gcc/cp/constexpr.c11
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/opt/pr86738.C12
4 files changed, 33 insertions, 3 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 0d4377c..ed3ad71 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,11 @@
+2018-08-08 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/86738
+ * constexpr.c (cxx_eval_binary_expression): For arithmetics involving
+ NULL pointer set *non_constant_p to true.
+ (cxx_eval_component_reference): For dereferencing of a NULL pointer,
+ set *non_constant_p to true and return t.
+
2018-08-07 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/59480, DR 136
diff --git a/gcc/cp/constexpr.c b/gcc/cp/constexpr.c
index 79039ff..d796e8b 100644
--- a/gcc/cp/constexpr.c
+++ b/gcc/cp/constexpr.c
@@ -2082,6 +2082,7 @@ cxx_eval_binary_expression (const constexpr_ctx *ctx, tree t,
{
if (!ctx->quiet)
error ("arithmetic involving a null pointer in %qE", lhs);
+ *non_constant_p = true;
return t;
}
else if (code == POINTER_PLUS_EXPR)
@@ -2522,9 +2523,13 @@ cxx_eval_component_reference (const constexpr_ctx *ctx, tree t,
lval,
non_constant_p, overflow_p);
if (INDIRECT_REF_P (whole)
- && integer_zerop (TREE_OPERAND (whole, 0))
- && !ctx->quiet)
- error ("dereferencing a null pointer in %qE", orig_whole);
+ && integer_zerop (TREE_OPERAND (whole, 0)))
+ {
+ if (!ctx->quiet)
+ error ("dereferencing a null pointer in %qE", orig_whole);
+ *non_constant_p = true;
+ return t;
+ }
if (TREE_CODE (whole) == PTRMEM_CST)
whole = cplus_expand_constant (whole);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index c4aaa44..6eb02bb 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2018-08-08 Jakub Jelinek <jakub@redhat.com>
+
+ PR c++/86738
+ * g++.dg/opt/pr86738.C: New test.
+
2018-08-07 Richard Sandiford <richard.sandiford@arm.com>
PR target/86838
diff --git a/gcc/testsuite/g++.dg/opt/pr86738.C b/gcc/testsuite/g++.dg/opt/pr86738.C
new file mode 100644
index 0000000..f5079ff
--- /dev/null
+++ b/gcc/testsuite/g++.dg/opt/pr86738.C
@@ -0,0 +1,12 @@
+// PR c++/86738
+// { dg-do compile }
+
+struct S { int s; };
+unsigned char a[20];
+unsigned char *p = &a[(__UINTPTR_TYPE__) &((S *) 0)->s];
+
+void
+foo ()
+{
+ __builtin_memcpy (&a[15], &a[(__UINTPTR_TYPE__) &((S *) 0)->s], 2);
+}