From: Andrew MacLeod Date: Thu, 25 Jun 2015 17:03:33 +0000 (+0000) Subject: tree-core.h (struct tree_optimization_option): Make opts a pointer to struct cl_optim... X-Git-Tag: basepoints/gcc-7~6108 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=fbf196a2560584a0c71b7c44e6354eac93721888;p=thirdparty%2Fgcc.git tree-core.h (struct tree_optimization_option): Make opts a pointer to struct cl_optimization. 2015-06-25 Andrew MacLeod * tree-core.h (struct tree_optimization_option): Make opts a pointer to struct cl_optimization. * tree.h (TREE_OPTIMIZATION): Return the pointer, not the address of it. * tree.c (make_node_stat): Allocate cl_optimization struct. (copy_node_stat): Allocate and copy cl_optimization struct. From-SVN: r224952 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a45adfd715f6..202c3a71949e 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2015-06-25 Andrew MacLeod + + * tree-core.h (struct tree_optimization_option): Make opts a pointer to + struct cl_optimization. + * tree.h (TREE_OPTIMIZATION): Return the pointer, not the address of it. + * tree.c (make_node_stat): Allocate cl_optimization struct. + (copy_node_stat): Allocate and copy cl_optimization struct. + 2015-06-25 Andrew MacLeod * function.h (struct incoming_args): Move struct. diff --git a/gcc/tree-core.h b/gcc/tree-core.h index 58dc301b9909..f23abe2bb430 100644 --- a/gcc/tree-core.h +++ b/gcc/tree-core.h @@ -1652,7 +1652,7 @@ struct GTY(()) tree_optimization_option { struct tree_common common; /* The optimization options used by the user. */ - struct cl_optimization opts; + struct cl_optimization *opts; /* Target optabs for this set of optimization options. This is of type `struct target_optabs *'. */ diff --git a/gcc/tree.c b/gcc/tree.c index f6ab441ae03f..d44bc180f518 100644 --- a/gcc/tree.c +++ b/gcc/tree.c @@ -1095,9 +1095,20 @@ make_node_stat (enum tree_code code MEM_STAT_DECL) break; case tcc_exceptional: - if (code == TARGET_OPTION_NODE) - { - TREE_TARGET_OPTION(t) = ggc_cleared_alloc (); + switch (code) + { + case TARGET_OPTION_NODE: + TREE_TARGET_OPTION(t) + = ggc_cleared_alloc (); + break; + + case OPTIMIZATION_NODE: + TREE_OPTIMIZATION (t) + = ggc_cleared_alloc (); + break; + + default: + break; } break; @@ -1188,6 +1199,12 @@ copy_node_stat (tree node MEM_STAT_DECL) memcpy (TREE_TARGET_OPTION (t), TREE_TARGET_OPTION (node), sizeof (struct cl_target_option)); } + else if (code == OPTIMIZATION_NODE) + { + TREE_OPTIMIZATION (t) = ggc_alloc(); + memcpy (TREE_OPTIMIZATION (t), TREE_OPTIMIZATION (node), + sizeof (struct cl_optimization)); + } return t; } diff --git a/gcc/tree.h b/gcc/tree.h index 34b93681140d..e9f0d734a43a 100644 --- a/gcc/tree.h +++ b/gcc/tree.h @@ -2827,7 +2827,7 @@ extern vec **decl_debug_args_insert (tree); (STATEMENT_LIST_CHECK (NODE)->stmt_list.tail) #define TREE_OPTIMIZATION(NODE) \ - (&OPTIMIZATION_NODE_CHECK (NODE)->optimization.opts) + (OPTIMIZATION_NODE_CHECK (NODE)->optimization.opts) #define TREE_OPTIMIZATION_OPTABS(NODE) \ (OPTIMIZATION_NODE_CHECK (NODE)->optimization.optabs)