From 9e62bc99ae7c485f7162b257af9366940a075045 Mon Sep 17 00:00:00 2001 From: Hans-Peter Nilsson Date: Tue, 13 Oct 2009 23:48:39 +0000 Subject: [PATCH] re PR rtl-optimization/38948 (unrecognizable insn, postreload.c:395) PR target/38948 * config/cris/cris.h (SECONDARY_RELOAD_CLASS): Handle reload requests between special registers. From-SVN: r152736 --- gcc/ChangeLog | 6 ++++++ gcc/config/cris/cris.h | 17 +++++++++++------ 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8a5b06777227..dbd7ada215e7 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2009-10-14 Hans-Peter Nilsson + + PR target/38948 + * config/cris/cris.h (SECONDARY_RELOAD_CLASS): Handle reload + requests between special registers. + 2009-10-12 Hans-Peter Nilsson PR target/26515 diff --git a/gcc/config/cris/cris.h b/gcc/config/cris/cris.h index b8f4ae567132..061f98882144 100644 --- a/gcc/config/cris/cris.h +++ b/gcc/config/cris/cris.h @@ -642,12 +642,17 @@ enum reg_class ? GENERAL_REGS : (CLASS)) /* We can't move special registers to and from memory in smaller than - word_mode. */ -#define SECONDARY_RELOAD_CLASS(CLASS, MODE, X) \ - (((CLASS) != SPECIAL_REGS && (CLASS) != MOF_REGS) \ - || GET_MODE_SIZE (MODE) == 4 \ - || !MEM_P (X) \ - ? NO_REGS : GENERAL_REGS) + word_mode. We also can't move between special registers. Luckily, + -1, as returned by true_regnum for non-sub/registers, is valid as a + parameter to our REGNO_REG_CLASS, returning GENERAL_REGS, so we get + the effect that any X that isn't a special-register is treated as + a non-empty intersection with GENERAL_REGS. */ +#define SECONDARY_RELOAD_CLASS(CLASS, MODE, X) \ + ((((CLASS) == SPECIAL_REGS || (CLASS) == MOF_REGS) \ + && ((GET_MODE_SIZE (MODE) < 4 && MEM_P (X)) \ + || !reg_classes_intersect_p (REGNO_REG_CLASS (true_regnum (X)), \ + GENERAL_REGS))) \ + ? GENERAL_REGS : NO_REGS) /* FIXME: Fix regrename.c; it should check validity of replacements, not just with a silly pass-specific macro. We may miss some -- 2.47.2