diff options
| -rw-r--r-- | gcc/ChangeLog | 6 | ||||
| -rw-r--r-- | gcc/rtlanal.c | 6 |
2 files changed, 9 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e450bd7..a6829c9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2006-12-21 Joseph Myers <joseph@codesourcery.com> + + * rtlanal.c (subreg_get_info): Do not make register size + computations for mode sizes not divisible by the number of + registers. + 2006-12-21 Daniel Berlin <dberlin@dberlin.org> * tree-ssa-structalias.c (build_constraint_graph): Insert complex diff --git a/gcc/rtlanal.c b/gcc/rtlanal.c index c45a020..bc2da3c 100644 --- a/gcc/rtlanal.c +++ b/gcc/rtlanal.c @@ -3028,12 +3028,12 @@ subreg_get_info (unsigned int xregno, enum machine_mode xmode, /* If registers store different numbers of bits in the different modes, we cannot generally form this subreg. */ if (!HARD_REGNO_NREGS_HAS_PADDING (xregno, xmode) - && !HARD_REGNO_NREGS_HAS_PADDING (xregno, ymode)) + && !HARD_REGNO_NREGS_HAS_PADDING (xregno, ymode) + && (GET_MODE_SIZE (xmode) % nregs_xmode) == 0 + && (GET_MODE_SIZE (ymode) % nregs_ymode) == 0) { regsize_xmode = GET_MODE_SIZE (xmode) / nregs_xmode; - gcc_assert (regsize_xmode * nregs_xmode == GET_MODE_SIZE (xmode)); regsize_ymode = GET_MODE_SIZE (ymode) / nregs_ymode; - gcc_assert (regsize_ymode * nregs_ymode == GET_MODE_SIZE (ymode)); if (!rknown && regsize_xmode > regsize_ymode && nregs_ymode > 1) { info->representable_p = false; |
