On Mon, Oct 11, 2021 at 1:02 PM Martin Liška <mli...@suse.cz> wrote:
>
> After the recent change in Optimize attribute handling, we need
> finish_option function properly auto-detecting variable tracking options.
>
> Patch can bootstrap on x86_64-linux-gnu and survives regression tests.
>
> Ready to be installed?
> Thanks,
> Martin
>
>         PR debug/102585
>
> gcc/ChangeLog:
>
>         * common.opt: Do not init flag_var_tracking* options.
>         * opts.c (finish_options): Handle flag_var_tracking* options.
>         * toplev.c (process_options): Move to opts.c.
>
> gcc/testsuite/ChangeLog:
>
>         * gcc.dg/pr102585.c: New test.
> ---
>   gcc/common.opt                  | 14 +++++---------
>   gcc/opts.c                      | 28 ++++++++++++++++++++++++++++
>   gcc/testsuite/gcc.dg/pr102585.c |  6 ++++++
>   gcc/toplev.c                    | 33 +++------------------------------
>   4 files changed, 42 insertions(+), 39 deletions(-)
>   create mode 100644 gcc/testsuite/gcc.dg/pr102585.c
>
> diff --git a/gcc/common.opt b/gcc/common.opt
> index 52693e226d2..ec020f4e642 100644
> --- a/gcc/common.opt
> +++ b/gcc/common.opt
> @@ -3003,19 +3003,16 @@ Common Undocumented Var(flag_use_linker_plugin)
>
>   ; Positive if we should track variables, negative if we should run
>   ; the var-tracking pass only to discard debug annotations, zero if
> -; we're not to run it.  When flag_var_tracking == 2 (AUTODETECT_VALUE) it
> -; will be set according to optimize, debug_info_level and debug_hooks
> -; in process_options ().
> +; we're not to run it.
>   fvar-tracking
> -Common Var(flag_var_tracking) Init(2) PerFunction
> +Common Var(flag_var_tracking) PerFunction
>   Perform variable tracking.
>
>   ; Positive if we should track variables at assignments, negative if
>   ; we should run the var-tracking pass only to discard debug
> -; annotations.  When flag_var_tracking_assignments ==
> -; AUTODETECT_VALUE it will be set according to flag_var_tracking.
> +; annotations.
>   fvar-tracking-assignments
> -Common Var(flag_var_tracking_assignments) Init(2) PerFunction
> +Common Var(flag_var_tracking_assignments) PerFunction
>   Perform variable tracking by annotating assignments.
>
>   ; Nonzero if we should toggle flag_var_tracking_assignments after
> @@ -3026,8 +3023,7 @@ Toggle -fvar-tracking-assignments.
>
>   ; Positive if we should track uninitialized variables, negative if
>   ; we should run the var-tracking pass only to discard debug
> -; annotations.  When flag_var_tracking_uninit == AUTODETECT_VALUE it
> -; will be set according to flag_var_tracking.
> +; annotations.
>   fvar-tracking-uninit
>   Common Var(flag_var_tracking_uninit) PerFunction
>   Perform variable tracking and also tag variables that are uninitialized.
> diff --git a/gcc/opts.c b/gcc/opts.c
> index 2116c2991dd..eeb6b1dcc7c 100644
> --- a/gcc/opts.c
> +++ b/gcc/opts.c
> @@ -1353,6 +1353,34 @@ finish_options (struct gcc_options *opts, struct 
> gcc_options *opts_set,
>       SET_OPTION_IF_UNSET (opts, opts_set, flag_vect_cost_model,
>                          VECT_COST_MODEL_CHEAP);
>
> +  /* If the user specifically requested variable tracking with tagging
> +     uninitialized variables, we need to turn on variable tracking.
> +     (We already determined above that variable tracking is feasible.)  */
> +  if (opts->x_flag_var_tracking_uninit == 1)
> +    opts->x_flag_var_tracking = 1;
> +
> +  if (!opts_set->x_flag_var_tracking)
> +    opts->x_flag_var_tracking = optimize >= 1;

That's still not equivalent to the old code for -fvar-tracking-uninit which
sets opts->x_flag_var_tracking to 1 and the old code checked that
for AUTOINIT_VALUE but you override it here for -O0.

> +  if (!opts_set->x_flag_var_tracking_uninit)
> +    opts->x_flag_var_tracking_uninit = opts->x_flag_var_tracking;
> +
> +  if (!opts_set->x_flag_var_tracking_assignments)
> +    opts->x_flag_var_tracking_assignments
> +      = (opts->x_flag_var_tracking
> +        && !(opts->x_flag_selective_scheduling
> +             || opts->x_flag_selective_scheduling2));
> +
> +  if (opts->x_flag_var_tracking_assignments_toggle)
> +    opts->x_flag_var_tracking_assignments = 
> !opts->x_flag_var_tracking_assignments;
> +
> +  if (opts->x_flag_var_tracking_assignments && !opts->x_flag_var_tracking)
> +    opts->x_flag_var_tracking = opts->x_flag_var_tracking_assignments = -1;
> +
> +  if (opts->x_flag_var_tracking_assignments
> +      && (opts->x_flag_selective_scheduling || 
> opts->x_flag_selective_scheduling2))
> +    warning_at (loc, 0,
> +               "var-tracking-assignments changes selective scheduling");
>   }
>
>   #define LEFT_COLUMN   27
> diff --git a/gcc/testsuite/gcc.dg/pr102585.c b/gcc/testsuite/gcc.dg/pr102585.c
> new file mode 100644
> index 00000000000..efd066b4a4e
> --- /dev/null
> +++ b/gcc/testsuite/gcc.dg/pr102585.c
> @@ -0,0 +1,6 @@
> +/* PR debug/102585 */
> +/* { dg-do compile } */
> +/* { dg-options "-fvar-tracking-assignments -fno-var-tracking" } */
> +
> +#pragma GCC optimize 0
> +void d_demangle_callback_Og() { int c = 0; }
> diff --git a/gcc/toplev.c b/gcc/toplev.c
> index 81748b1152a..2f13d740b98 100644
> --- a/gcc/toplev.c
> +++ b/gcc/toplev.c
> @@ -1490,8 +1490,8 @@ process_options (bool no_backend)
>         || !dwarf_debuginfo_p ()
>         || debug_hooks->var_location == do_nothing_debug_hooks.var_location)
>       {
> -      if (flag_var_tracking == 1
> -         || flag_var_tracking_uninit == 1)
> +      if ((OPTION_SET_P (flag_var_tracking) && flag_var_tracking == 1)
> +         || (OPTION_SET_P (flag_var_tracking_uninit) && 
> flag_var_tracking_uninit == 1))
>           {
>           if (debug_info_level < DINFO_LEVEL_NORMAL)
>             warning_at (UNKNOWN_LOCATION, 0,
> @@ -1504,6 +1504,7 @@ process_options (bool no_backend)
>         }
>         flag_var_tracking = 0;
>         flag_var_tracking_uninit = 0;
> +      flag_var_tracking_assignments = 0;
>       }
>
>     /* The debug hooks are used to implement -fdump-go-spec because it
> @@ -1512,34 +1513,6 @@ process_options (bool no_backend)
>     if (flag_dump_go_spec != NULL)
>       debug_hooks = dump_go_spec_init (flag_dump_go_spec, debug_hooks);
>
> -  /* If the user specifically requested variable tracking with tagging
> -     uninitialized variables, we need to turn on variable tracking.
> -     (We already determined above that variable tracking is feasible.)  */
> -  if (flag_var_tracking_uninit == 1)
> -    flag_var_tracking = 1;
> -
> -  if (flag_var_tracking == AUTODETECT_VALUE)
> -    flag_var_tracking = optimize >= 1;
> -
> -  if (flag_var_tracking_uninit == AUTODETECT_VALUE)
> -    flag_var_tracking_uninit = flag_var_tracking;
> -
> -  if (flag_var_tracking_assignments == AUTODETECT_VALUE)
> -    flag_var_tracking_assignments
> -      = (flag_var_tracking
> -        && !(flag_selective_scheduling || flag_selective_scheduling2));
> -
> -  if (flag_var_tracking_assignments_toggle)
> -    flag_var_tracking_assignments = !flag_var_tracking_assignments;
> -
> -  if (flag_var_tracking_assignments && !flag_var_tracking)
> -    flag_var_tracking = flag_var_tracking_assignments = -1;
> -
> -  if (flag_var_tracking_assignments
> -      && (flag_selective_scheduling || flag_selective_scheduling2))
> -    warning_at (UNKNOWN_LOCATION, 0,
> -               "var-tracking-assignments changes selective scheduling");
> -
>     if (debug_nonbind_markers_p == AUTODETECT_VALUE)
>       debug_nonbind_markers_p
>         = (optimize
> --
> 2.33.0
>

Reply via email to