From 8dc19053e1f5af5af97ce7b9e8ebd6e657b23277 Mon Sep 17 00:00:00 2001 From: Martin Liska Date: Thu, 9 Mar 2017 10:22:29 +0100 Subject: [PATCH] Get bounds for a PARM_DECL (PR ipa/79761). 2017-03-09 Martin Liska PR ipa/79761 * tree-chkp.c (chkp_get_bound_for_parm): Get bounds for a param. (chkp_find_bounds_1): Remove gcc_unreachable. 2017-03-09 Martin Liska PR ipa/79761 * g++.dg/pr79761.C: New test. From-SVN: r245993 --- gcc/ChangeLog | 6 ++++++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/pr79761.C | 34 ++++++++++++++++++++++++++++++++++ gcc/tree-chkp.c | 4 ++-- 4 files changed, 47 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/g++.dg/pr79761.C diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 80d0aeaa6e4..b3ab72b3d82 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-03-09 Martin Liska + + PR ipa/79761 + * tree-chkp.c (chkp_get_bound_for_parm): Get bounds for a param. + (chkp_find_bounds_1): Remove gcc_unreachable. + 2017-03-09 Jakub Jelinek PR sanitizer/79944 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 13218ac30eb..371fdbb8428 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-03-09 Martin Liska + + PR ipa/79761 + * g++.dg/pr79761.C: New test. + 2017-03-09 Jakub Jelinek PR sanitizer/79944 diff --git a/gcc/testsuite/g++.dg/pr79761.C b/gcc/testsuite/g++.dg/pr79761.C new file mode 100644 index 00000000000..a97325a1fc4 --- /dev/null +++ b/gcc/testsuite/g++.dg/pr79761.C @@ -0,0 +1,34 @@ +/* { dg-do compile { target { { i?86-*-* x86_64-*-* } && { ! x32 } } } } */ +/* { dg-options "-fcheck-pointer-bounds -mmpx -mabi=ms" } */ + +struct Foo +{ + Foo() : a(1), b(1), c('a') {} + int a; + int b; + char c; +}; + +static Foo copy_foo(Foo) __attribute__((noinline, noclone)); + +static Foo copy_foo(Foo A) +{ + return A; +} + +struct Bar : Foo +{ + Bar(Foo t) : Foo(copy_foo(t)) {} +}; + +Foo F; + +int main (void) +{ + Bar B (F); + + if (B.a != 1 || B.b != 1 || B.c != 'a') + __builtin_abort (); + + return 0; +} diff --git a/gcc/tree-chkp.c b/gcc/tree-chkp.c index b7b412efcef..66612baaaff 100644 --- a/gcc/tree-chkp.c +++ b/gcc/tree-chkp.c @@ -3604,8 +3604,8 @@ chkp_find_bounds_1 (tree ptr, tree ptr_src, gimple_stmt_iterator *iter) break; case PARM_DECL: - gcc_unreachable (); - bounds = chkp_get_bound_for_parm (ptr_src); + /* Handled above but failed. */ + bounds = chkp_get_invalid_op_bounds (); break; case TARGET_MEM_REF: -- 2.30.2