https://gcc.gnu.org/g:173f8763a66622f2a70ad66f60573fcff7d6b49e

commit r13-8811-g173f8763a66622f2a70ad66f60573fcff7d6b49e
Author: Hongyu Wang <hongyu.w...@intel.com>
Date:   Wed May 15 11:24:34 2024 +0800

    i386: Fix ix86_option override after change [PR 113719]
    
    In ix86_override_options_after_change, calls to ix86_default_align
    and ix86_recompute_optlev_based_flags will cause mismatched target
    opt_set when doing cl_optimization_restore. Move them back to
    ix86_option_override_internal to solve the issue.
    
    gcc/ChangeLog:
    
            PR target/113719
            * config/i386/i386-options.cc (ix86_override_options_after_change):
            Remove call to ix86_default_align and
            ix86_recompute_optlev_based_flags.
            (ix86_option_override_internal): Call ix86_default_align and
            ix86_recompute_optlev_based_flags.
    
    (cherry picked from commit 499d00127d39ba894b0f7216d73660b380bdc325)

Diff:
---
 gcc/config/i386/i386-options.cc | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)

diff --git a/gcc/config/i386/i386-options.cc b/gcc/config/i386/i386-options.cc
index c1229475138..cdbe2dc6201 100644
--- a/gcc/config/i386/i386-options.cc
+++ b/gcc/config/i386/i386-options.cc
@@ -1875,11 +1875,6 @@ ix86_recompute_optlev_based_flags (struct gcc_options 
*opts,
 void
 ix86_override_options_after_change (void)
 {
-  /* Default align_* from the processor table.  */
-  ix86_default_align (&global_options);
-
-  ix86_recompute_optlev_based_flags (&global_options, &global_options_set);
-
   /* Disable unrolling small loops when there's explicit
      -f{,no}unroll-loop.  */
   if ((OPTION_SET_P (flag_unroll_loops))
@@ -2420,6 +2415,8 @@ ix86_option_override_internal (bool main_args_p,
 
   set_ix86_tune_features (opts, ix86_tune, opts->x_ix86_dump_tunes);
 
+  ix86_recompute_optlev_based_flags (opts, opts_set);
+
   ix86_override_options_after_change ();
 
   ix86_tune_cost = processor_cost_table[ix86_tune];
@@ -2451,6 +2448,9 @@ ix86_option_override_internal (bool main_args_p,
       || TARGET_64BIT_P (opts->x_ix86_isa_flags))
     opts->x_ix86_regparm = REGPARM_MAX;
 
+  /* Default align_* from the processor table.  */
+  ix86_default_align (&global_options);
+
   /* Provide default for -mbranch-cost= value.  */
   SET_OPTION_IF_UNSET (opts, opts_set, ix86_branch_cost,
                       ix86_tune_cost->branch_cost);

Reply via email to