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/fortran | |
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/fortran')
0 files changed, 0 insertions, 0 deletions