diff options
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/rtl.c | 1 | ||||
-rw-r--r-- | gcc/varasm.c | 8 |
3 files changed, 13 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ba3e1fb..76c84a4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,10 @@ 2005-01-30 Richard Henderson <rth@redhat.com> + * rtl.c (rtx_equal_p): No early exit for CONST_VECTOR. + * varasm.c (const_rtx_hash_1): Handle CONST_VECTOR. + +2005-01-30 Richard Henderson <rth@redhat.com> + PR target/19700 * config/i386/i386.c (ix86_expand_copysign): New. (ix86_split_copysign_const): New. @@ -364,7 +364,6 @@ rtx_equal_p (rtx x, rtx y) case SCRATCH: case CONST_DOUBLE: case CONST_INT: - case CONST_VECTOR: return 0; default: diff --git a/gcc/varasm.c b/gcc/varasm.c index d37bee8..12ab1b7 100644 --- a/gcc/varasm.c +++ b/gcc/varasm.c @@ -2874,6 +2874,14 @@ const_rtx_hash_1 (rtx *xp, void *data) h ^= real_hash (CONST_DOUBLE_REAL_VALUE (x)); break; + case CONST_VECTOR: + { + int i; + for (i = XVECLEN (x, 0); i-- > 0; ) + h = h * 251 + const_rtx_hash_1 (&XVECEXP (x, 0, i), data); + } + break; + case SYMBOL_REF: h ^= htab_hash_string (XSTR (x, 0)); break; |