diff options
author | Alexandre Oliva <oliva@adacore.com> | 2022-04-05 01:28:20 -0300 |
---|---|---|
committer | Alexandre Oliva <oliva@gnu.org> | 2022-04-05 01:28:20 -0300 |
commit | 418967ca275853a570b0ae566d7022ff38e7cd0d (patch) | |
tree | 151cad8b0371780b64ba9d9ded748720d1b66636 /gcc/regs.h | |
parent | 5e09bb1b2e7ccea480a448fc45db3f3e1c1ae081 (diff) | |
download | gcc-418967ca275853a570b0ae566d7022ff38e7cd0d.zip gcc-418967ca275853a570b0ae566d7022ff38e7cd0d.tar.gz gcc-418967ca275853a570b0ae566d7022ff38e7cd0d.tar.bz2 |
try multi-reg dest in default_zero_call_used_regs
When the mode of regno_reg_rtx is not hard_regno_mode_ok for the
target, try grouping the register with subsequent ones. This enables
s16 to s31 and their hidden pairs to be zeroed with the default logic
on some arm variants.
for gcc/ChangeLog
* targhooks.cc (default_zero_call_used_regs): Attempt to group
regs that the target refuses to use in their natural modes.
(zcur_select_mode_rtx): New.
* regs.h (struct target_regs): Add x_hard_regno_max_nregs.
(hard_regno_max_nregs): Define.
* reginfo.cc (init_reg_modes_target): Set hard_regno_max_nregs.
Diffstat (limited to 'gcc/regs.h')
-rw-r--r-- | gcc/regs.h | 5 |
1 files changed, 5 insertions, 0 deletions
@@ -202,6 +202,9 @@ struct target_regs { registers that a given machine mode occupies. */ unsigned char x_hard_regno_nregs[FIRST_PSEUDO_REGISTER][MAX_MACHINE_MODE]; + /* The max value found in x_hard_regno_nregs. */ + unsigned char x_hard_regno_max_nregs; + /* For each hard register, the widest mode object that it can contain. This will be a MODE_INT mode if the register can hold integers. Otherwise it will be a MODE_FLOAT or a MODE_CC mode, whichever is valid for the @@ -235,6 +238,8 @@ extern struct target_regs *this_target_regs; #else #define this_target_regs (&default_target_regs) #endif +#define hard_regno_max_nregs \ + (this_target_regs->x_hard_regno_max_nregs) #define reg_raw_mode \ (this_target_regs->x_reg_raw_mode) #define have_regs_of_mode \ |