diff --git a/gcc/ChangeLog b/gcc/ChangeLog index cd6be7d578c..da2edc71a18 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,17 @@ +2016-12-15 Richard Earnshaw + + * arm-protos.h (arm_configure_build_target): Change second argument + to cl_target_options. + * arm.c (arm_configure_build_target): Likewise. + (arm_option_restore): Update accordingly. + (arm_option_override): Create the target_option_default_node before + calling arm_configure_build_target. Use it in call of latter. + Resynchronize after all other overrides have been calculated. + (arm_valid_target_attribute_tree): Use the target options for + reconfiguration. Resynchronize after performing override checks. + * arm-c.c (arm_pragma_target_parse): Use target optiosn from cur_tree + to reconfigure the build target. + 2016-12-15 Richard Earnshaw * arm.h (TARGET_VFPD32): Use arm_active_target. diff --git a/gcc/config/arm/arm-c.c b/gcc/config/arm/arm-c.c index 9dd9a8d59c8..b57af695400 100644 --- a/gcc/config/arm/arm-c.c +++ b/gcc/config/arm/arm-c.c @@ -243,7 +243,8 @@ arm_pragma_target_parse (tree args, tree pop_target) /* handle_pragma_pop_options and handle_pragma_reset_options will set target_option_current_node, but not handle_pragma_target. */ target_option_current_node = cur_tree; - arm_configure_build_target (&arm_active_target, &global_options, + arm_configure_build_target (&arm_active_target, + TREE_TARGET_OPTION (cur_tree), &global_options_set, false); } diff --git a/gcc/config/arm/arm-protos.h b/gcc/config/arm/arm-protos.h index da3484f3294..d418ca9cc79 100644 --- a/gcc/config/arm/arm-protos.h +++ b/gcc/config/arm/arm-protos.h @@ -225,7 +225,7 @@ extern bool arm_change_mode_p (tree); extern tree arm_valid_target_attribute_tree (tree, struct gcc_options *, struct gcc_options *); extern void arm_configure_build_target (struct arm_build_target *, - struct gcc_options *, + struct cl_target_option *, struct gcc_options *, bool); extern void arm_pr_long_calls (struct cpp_reader *); extern void arm_pr_no_long_calls (struct cpp_reader *); diff --git a/gcc/config/arm/arm.c b/gcc/config/arm/arm.c index 676c78bbb54..df520e5792e 100644 --- a/gcc/config/arm/arm.c +++ b/gcc/config/arm/arm.c @@ -2936,16 +2936,17 @@ arm_override_options_after_change_1 (struct gcc_options *opts) static void arm_override_options_after_change (void) { - arm_configure_build_target (&arm_active_target, &global_options, + arm_configure_build_target (&arm_active_target, + TREE_TARGET_OPTION (target_option_default_node), &global_options_set, false); arm_override_options_after_change_1 (&global_options); } static void -arm_option_restore (struct gcc_options *opts, struct cl_target_option *ptr) +arm_option_restore (struct gcc_options *, struct cl_target_option *ptr) { - arm_configure_build_target (&arm_active_target, opts, &global_options_set, + arm_configure_build_target (&arm_active_target, ptr, &global_options_set, false); } @@ -3070,7 +3071,7 @@ static sbitmap isa_quirkbits; architecture have been specified, but the two are not identical. */ void arm_configure_build_target (struct arm_build_target *target, - struct gcc_options *opts, + struct cl_target_option *opts, struct gcc_options *opts_set, bool warn_compatible) { @@ -3306,7 +3307,13 @@ arm_option_override (void) gcc_assert (ok); } - arm_configure_build_target (&arm_active_target, &global_options, + /* Create the default target_options structure. We need this early + to configure the overall build target. */ + target_option_default_node = target_option_current_node + = build_target_option_node (&global_options); + + arm_configure_build_target (&arm_active_target, + TREE_TARGET_OPTION (target_option_default_node), &global_options_set, true); #ifdef SUBTARGET_OVERRIDE_OPTIONS @@ -3657,14 +3664,12 @@ arm_option_override (void) arm_option_check_internal (&global_options); arm_option_params_internal (); + /* Resynchronize the saved target options. */ + cl_target_option_save (TREE_TARGET_OPTION (target_option_default_node), + &global_options); /* Register global variables with the garbage collector. */ arm_add_gc_roots (); - /* Save the initial options in case the user does function specific - options or #pragma target. */ - target_option_default_node = target_option_current_node - = build_target_option_node (&global_options); - /* Init initial mode for testing. */ thumb_flipper = TARGET_THUMB; } @@ -30326,15 +30331,22 @@ tree arm_valid_target_attribute_tree (tree args, struct gcc_options *opts, struct gcc_options *opts_set) { + tree t; + if (!arm_valid_target_attribute_rec (args, opts)) return NULL_TREE; - arm_configure_build_target (&arm_active_target, opts, opts_set, false); + t = build_target_option_node (opts); + arm_configure_build_target (&arm_active_target, TREE_TARGET_OPTION (t), + opts_set, false); arm_option_check_internal (opts); /* Do any overrides, such as global options arch=xxx. */ arm_option_override_internal (opts, opts_set); - return build_target_option_node (opts); + /* Resynchronize the saved target options. */ + cl_target_option_save (TREE_TARGET_OPTION (t), opts); + + return t; } static void