diff options
author | jason <jason@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-01-08 16:01:12 +0000 |
---|---|---|
committer | jason <jason@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-01-08 16:01:12 +0000 |
commit | 1fe75cf21288105fe5628a856f90440a77f614f0 (patch) | |
tree | a6a87fb093cb967de90353ff866ccad75a8602eb | |
parent | 74a96ca91ee8e189726369fbad1179c50826148c (diff) | |
download | gcc-1fe75cf21288105fe5628a856f90440a77f614f0.tar.gz |
PR c++/68983 (BE)
PR c++/67557
gcc/
* function.c (assign_temp): Guard against TREE_ADDRESSABLE types here.
* expr.c (store_field): Not here.
* tree-cfgcleanup.c (fixup_noreturn_call): Don't clear LHS of a
call with TREE_ADDRESSABLE type.
* tree-cfg.c (verify_gimple_call): Adjust.
gcc/cp/
* cvt.c (convert_to_void): Don't strip a TARGET_EXPR of
TREE_ADDRESSABLE type.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@232167 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/ChangeLog | 10 | ||||
-rw-r--r-- | gcc/cp/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/cp/cvt.c | 5 | ||||
-rw-r--r-- | gcc/expr.c | 3 | ||||
-rw-r--r-- | gcc/function.c | 4 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/init/base1.C | 14 | ||||
-rw-r--r-- | gcc/tree-cfg.c | 3 | ||||
-rw-r--r-- | gcc/tree-cfgcleanup.c | 6 |
8 files changed, 42 insertions, 8 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 858938afb98..4ffc776839f 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,13 @@ +2016-01-08 Jason Merrill <jason@redhat.com> + + PR c++/68983 + PR c++/67557 + * function.c (assign_temp): Guard against TREE_ADDRESSABLE types here. + * expr.c (store_field): Not here. + * tree-cfgcleanup.c (fixup_noreturn_call): Don't clear LHS of a + call with TREE_ADDRESSABLE type. + * tree-cfg.c (verify_gimple_call): Adjust. + 2016-01-08 Olivier Hainque <hainque@adacore.com> * config/vxworks.h (VXWORKS_LIBGCC_SPEC): Don't link shared RTPs with diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 33680a4fcd7..4e32d0dcd21 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -2,6 +2,11 @@ PR c++/68983 PR c++/67557 + * cvt.c (convert_to_void): Don't strip a TARGET_EXPR of + TREE_ADDRESSABLE type. + + PR c++/68983 + PR c++/67557 * call.c (unsafe_copy_elision_p): Look through COMPOUND_EXPR. 2016-01-05 Nathan Sidwell <nathan@acm.org> diff --git a/gcc/cp/cvt.c b/gcc/cp/cvt.c index d79f13bce70..f381f9b3800 100644 --- a/gcc/cp/cvt.c +++ b/gcc/cp/cvt.c @@ -1229,11 +1229,12 @@ convert_to_void (tree expr, impl_conv_void implicit, tsubst_flags_t complain) case TARGET_EXPR: /* Don't bother with the temporary object returned from a function if - we don't use it and don't need to destroy it. We'll still + we don't use it, don't need to destroy it, and won't abort in + assign_temp. We'll still allocate space for it in expand_call or declare_return_variable, but we don't need to track it through all the tree phases. */ if (TARGET_EXPR_IMPLICIT_P (expr) - && TYPE_HAS_TRIVIAL_DESTRUCTOR (TREE_TYPE (expr))) + && !TREE_ADDRESSABLE (TREE_TYPE (expr))) { tree init = TARGET_EXPR_INITIAL (expr); if (TREE_CODE (init) == AGGR_INIT_EXPR diff --git a/gcc/expr.c b/gcc/expr.c index 8973893fad6..0c5dff8be97 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -6655,9 +6655,6 @@ store_field (rtx target, HOST_WIDE_INT bitsize, HOST_WIDE_INT bitpos, rtx temp; gimple *nop_def; - /* Using bitwise copy is not safe for TREE_ADDRESSABLE types. */ - gcc_assert (!TREE_ADDRESSABLE (TREE_TYPE (exp))); - /* If EXP is a NOP_EXPR of precision less than its mode, then that implies a mask operation. If the precision is the same size as the field we're storing into, that mask is redundant. This is diff --git a/gcc/function.c b/gcc/function.c index 603ea80e977..1ac8e26daab 100644 --- a/gcc/function.c +++ b/gcc/function.c @@ -956,6 +956,10 @@ assign_temp (tree type_or_decl, int memory_required, unsignedp = TYPE_UNSIGNED (type); #endif + /* Allocating temporaries of TREE_ADDRESSABLE type must be done in the front + end. See also create_tmp_var for the gimplification-time check. */ + gcc_assert (!TREE_ADDRESSABLE (type) && COMPLETE_TYPE_P (type)); + if (mode == BLKmode || memory_required) { HOST_WIDE_INT size = int_size_in_bytes (type); diff --git a/gcc/testsuite/g++.dg/init/base1.C b/gcc/testsuite/g++.dg/init/base1.C new file mode 100644 index 00000000000..bce2f17e79f --- /dev/null +++ b/gcc/testsuite/g++.dg/init/base1.C @@ -0,0 +1,14 @@ +// PR c++/68983 + +class SvxOptionsGrid { + int nFldDrawX; + bool bEqualGrid; +public: + ~SvxOptionsGrid(); +}; +class A : SvxOptionsGrid { +public: + A(SvxOptionsGrid p1) : SvxOptionsGrid(p1) {} +}; +SvxOptionsGrid a; +void fn1() { A b(a); } diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index e75774ebc9b..dbfa506c5d8 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -3371,7 +3371,8 @@ verify_gimple_call (gcall *stmt) if (lhs && gimple_call_ctrl_altering_p (stmt) && gimple_call_noreturn_p (stmt) - && TREE_CODE (TYPE_SIZE_UNIT (TREE_TYPE (lhs))) == INTEGER_CST) + && TREE_CODE (TYPE_SIZE_UNIT (TREE_TYPE (lhs))) == INTEGER_CST + && !TREE_ADDRESSABLE (TREE_TYPE (lhs))) { error ("LHS in noreturn call"); return true; diff --git a/gcc/tree-cfgcleanup.c b/gcc/tree-cfgcleanup.c index bd7c3c973e8..46d0fa3ee0d 100644 --- a/gcc/tree-cfgcleanup.c +++ b/gcc/tree-cfgcleanup.c @@ -601,9 +601,11 @@ fixup_noreturn_call (gimple *stmt) /* If there is an LHS, remove it, but only if its type has fixed size. The LHS will need to be recreated during RTL expansion and creating - temporaries of variable-sized types is not supported. */ + temporaries of variable-sized types is not supported. Also don't + do this with TREE_ADDRESSABLE types, as assign_temp will abort. */ tree lhs = gimple_call_lhs (stmt); - if (lhs && TREE_CODE (TYPE_SIZE_UNIT (TREE_TYPE (lhs))) == INTEGER_CST) + if (lhs && TREE_CODE (TYPE_SIZE_UNIT (TREE_TYPE (lhs))) == INTEGER_CST + && !TREE_ADDRESSABLE (TREE_TYPE (lhs))) { gimple_call_set_lhs (stmt, NULL_TREE); |