Tweak interface to ira-build.c:ior_hard_reg_conflicts
authorRichard Sandiford <richard.sandiford@arm.com>
Mon, 9 Sep 2019 17:59:54 +0000 (17:59 +0000)
committerRichard Sandiford <rsandifo@gcc.gnu.org>
Mon, 9 Sep 2019 17:59:54 +0000 (17:59 +0000)
This patch makes ior_hard_reg_conflicts take a const_hard_reg_set
rather than a pointer, so that it can be passed a temporary object
in later patches.

2019-09-09  Richard Sandiford  <richard.sandiford@arm.com>

gcc/
* ira-int.h (ior_hard_reg_conflicts): Take a const_hard_reg_set
instead of a HARD_REG_SET *.
* ira-build.c (ior_hard_reg_conflicts): Likewise.
(ira_build): Update call accordingly.
* ira-emit.c (add_range_and_copies_from_move_list): Likewise.

From-SVN: r275535

gcc/ChangeLog
gcc/ira-build.c
gcc/ira-emit.c
gcc/ira-int.h

index 8c791dd71318ae2715ad01164d46b8fbb6187f42..7ae8c4333f9e9f9c03ce7a2cee9319c7cc9f84d6 100644 (file)
@@ -1,3 +1,11 @@
+2019-09-09  Richard Sandiford  <richard.sandiford@arm.com>
+
+       * ira-int.h (ior_hard_reg_conflicts): Take a const_hard_reg_set
+       instead of a HARD_REG_SET *.
+       * ira-build.c (ior_hard_reg_conflicts): Likewise.
+       (ira_build): Update call accordingly.
+       * ira-emit.c (add_range_and_copies_from_move_list): Likewise.
+
 2019-09-09  Richard Sandiford  <richard.sandiford@arm.com>
 
        * hard-reg-set.h (HARD_REG_SET::operator==): New function.
index 3170d7d16891a36364ad0fbb1cee3fe272ccc7d5..834bea71011531df07cc3e51b5ef80005345720b 100644 (file)
@@ -614,15 +614,15 @@ merge_hard_reg_conflicts (ira_allocno_t from, ira_allocno_t to,
 /* Update hard register conflict information for all objects associated with
    A to include the regs in SET.  */
 void
-ior_hard_reg_conflicts (ira_allocno_t a, HARD_REG_SET *set)
+ior_hard_reg_conflicts (ira_allocno_t a, const_hard_reg_set set)
 {
   ira_allocno_object_iterator i;
   ira_object_t obj;
 
   FOR_EACH_ALLOCNO_OBJECT (a, obj, i)
     {
-      OBJECT_CONFLICT_HARD_REGS (obj) |= *set;
-      OBJECT_TOTAL_CONFLICT_HARD_REGS (obj) |= *set;
+      OBJECT_CONFLICT_HARD_REGS (obj) |= set;
+      OBJECT_TOTAL_CONFLICT_HARD_REGS (obj) |= set;
     }
 }
 
@@ -3462,7 +3462,7 @@ ira_build (void)
         allocno crossing calls.  */
       FOR_EACH_ALLOCNO (a, ai)
        if (ALLOCNO_CALLS_CROSSED_NUM (a) != 0)
-         ior_hard_reg_conflicts (a, &call_used_reg_set);
+         ior_hard_reg_conflicts (a, call_used_reg_set);
     }
   if (internal_flag_ira_verbose > 2 && ira_dump_file != NULL)
     print_copies (ira_dump_file);
index 255af307b3c83ba3d7173598928ccb836e65643c..9ac052107214697d56b5d482b8184b7851d15b71 100644 (file)
@@ -1122,8 +1122,8 @@ add_range_and_copies_from_move_list (move_t list, ira_loop_tree_node_t node,
              ira_allocate_object_conflicts (to_obj, n);
            }
        }
-      ior_hard_reg_conflicts (from, &hard_regs_live);
-      ior_hard_reg_conflicts (to, &hard_regs_live);
+      ior_hard_reg_conflicts (from, hard_regs_live);
+      ior_hard_reg_conflicts (to, hard_regs_live);
 
       update_costs (from, true, freq);
       update_costs (to, false, freq);
index 92b7dfb11198695c6f866c6a587ed84b454e6011..95e22aa26b177a30f02a76fa2fd08a855a1a95b7 100644 (file)
@@ -998,7 +998,7 @@ extern void ira_set_allocno_class (ira_allocno_t, enum reg_class);
 extern bool ira_conflict_vector_profitable_p (ira_object_t, int);
 extern void ira_allocate_conflict_vec (ira_object_t, int);
 extern void ira_allocate_object_conflicts (ira_object_t, int);
-extern void ior_hard_reg_conflicts (ira_allocno_t, HARD_REG_SET *);
+extern void ior_hard_reg_conflicts (ira_allocno_t, const_hard_reg_set);
 extern void ira_print_expanded_allocno (ira_allocno_t);
 extern void ira_add_live_range_to_object (ira_object_t, int, int);
 extern live_range_t ira_create_live_range (ira_object_t, int, int,