Fix noreorder symbol partitioning reversion.
authorMartin Liska <mliska@suse.cz>
Thu, 16 Jan 2020 19:44:27 +0000 (20:44 +0100)
committerMartin Liska <mliska@suse.cz>
Thu, 16 Jan 2020 19:44:27 +0000 (20:44 +0100)
* lto-partition.c (lto_balanced_map): Remember
best_noreorder_pos and then restore to it
when we revert.

gcc/lto/ChangeLog
gcc/lto/lto-partition.c

index 821a6fa9dc62bb13df8c06b00b99a1466424e477..2b930cb33df33c5edc578fc9cc0b833b9f82b590 100644 (file)
@@ -1,3 +1,9 @@
+2020-01-16  Martin Liska  <mliska@suse.cz>
+
+       * lto-partition.c (lto_balanced_map): Remember
+       best_noreorder_pos and then restore to it
+       when we revert.
+
 2020-01-08  Martin Liska  <mliska@suse.cz>
 
        * lto-partition.c (add_symbol_to_partition_1): Use ::dump_name or
index 3a9990903c77713555c67b51bdd0b7217ab263b9..8e0488ab13e182a8d8a0d753939ff438eb7f9bb9 100644 (file)
@@ -471,6 +471,7 @@ void
 lto_balanced_map (int n_lto_partitions, int max_partition_size)
 {
   int n_varpool_nodes = 0, varpool_pos = 0, best_varpool_pos = 0;
+  int best_noreorder_pos = 0;
   auto_vec <cgraph_node *> order (symtab->cgraph_count);
   auto_vec<cgraph_node *> noreorder;
   auto_vec<varpool_node *> varpool_order;
@@ -732,6 +733,7 @@ lto_balanced_map (int n_lto_partitions, int max_partition_size)
          best_i = i;
          best_n_nodes = lto_symtab_encoder_size (partition->encoder);
          best_varpool_pos = varpool_pos;
+         best_noreorder_pos = noreorder_pos;
        }
       if (dump_file)
        fprintf (dump_file, "Step %i: added %s, size %i, "
@@ -752,6 +754,7 @@ lto_balanced_map (int n_lto_partitions, int max_partition_size)
                         i - best_i, best_i);
              undo_partition (partition, best_n_nodes);
              varpool_pos = best_varpool_pos;
+             noreorder_pos = best_noreorder_pos;
            }
          gcc_assert (best_size == partition->insns);
          i = best_i;