]> git.ipfire.org Git - thirdparty/gcc.git/commit
re PR target/32889 (ICE in delete_output_reload, at reload1.c:7926)
authorJohn David Anglin <dave.anglin@nrc-cnrc.gc.ca>
Sun, 9 Dec 2007 18:02:08 +0000 (18:02 +0000)
committerJohn David Anglin <danglin@gcc.gnu.org>
Sun, 9 Dec 2007 18:02:08 +0000 (18:02 +0000)
commit6982c5d4c822b89dcfa6b5554505997ab183e39b
tree6c03efab36b85bc299f7ba354cfa23f643d60a6a
parentfad0afd7d72cb63e47e70795baac30cb2880314a
re PR target/32889 (ICE in delete_output_reload, at reload1.c:7926)

PR middle-end/32889
PR target/34091
* pa.md: Consolidate HImode and QImode move patterns into one pattern
each, eliminating floating-point alternatives.
* pa-protos.h (pa_cannot_change_mode_class, pa_modes_tieable_p):
Declare functions.
* pa-64.h (SECONDARY_MEMORY_NEEDED): Define here.
* pa.c (pa_secondary_reload): Use an intermediate general register
for copies to/from floating-point register classes.  Simplify code
SHIFT_REGS class.  Provide additional comments.
(pa_cannot_change_mode_class, pa_modes_tieable_p): New functions.
* pa.h (MODES_TIEABLE_P): Use pa_modes_tieable_p.
(SECONDARY_MEMORY_NEEDED): Delete define.
(INT14_OK_STRICT): Define.
(MODE_OK_FOR_SCALED_INDEXING_P): Allow SFmode and DFmode when using
soft float.
(MODE_OK_FOR_UNSCALED_INDEXING_P): Likewise.
(GO_IF_LEGITIMATE_ADDRESS): Use INT14_OK_STRICT in REG+D case for
SFmode and DFmode.
(LEGITIMIZE_RELOAD_ADDRESS): Use INT14_OK_STRICT in mask selection.
Align DImode offsets when generating 64-bit code.
* pa32-regs.h (VALID_FP_MODE_P): Remove QImode and HImode.
(CANNOT_CHANGE_MODE_CLASS): Define.
* pa64-regs.h (VALID_FP_MODE_P): Remove QImode and HImode.
(CANNOT_CHANGE_MODE_CLASS): Define using pa_cannot_change_mode_class.

From-SVN: r130725
gcc/ChangeLog
gcc/config/pa/pa-64.h
gcc/config/pa/pa-protos.h
gcc/config/pa/pa.c
gcc/config/pa/pa.h
gcc/config/pa/pa.md
gcc/config/pa/pa32-regs.h
gcc/config/pa/pa64-regs.h