diff options
author | Olivier Hainque <hainque@act-europe.fr> | 2003-04-15 00:08:51 +0200 |
---|---|---|
committer | Richard Kenner <kenner@gcc.gnu.org> | 2003-04-14 18:08:51 -0400 |
commit | 41ee320444443de9d720893df8064319da2d2f78 (patch) | |
tree | 087f3164c82e2febf197e1d13ad11f7bdbcf7783 | |
parent | 39d658e3950054b6f18727d907a047a4dd6c10d4 (diff) | |
download | gcc-41ee320444443de9d720893df8064319da2d2f78.zip gcc-41ee320444443de9d720893df8064319da2d2f78.tar.gz gcc-41ee320444443de9d720893df8064319da2d2f78.tar.bz2 |
explow.c (round_push): Use HOST_WIDE_INT instead of int for the temporary used to round CONST_INT sizes.
* explow.c (round_push): Use HOST_WIDE_INT instead of int for the
temporary used to round CONST_INT sizes.
From-SVN: r65600
-rw-r--r-- | gcc/ChangeLog | 3 | ||||
-rw-r--r-- | gcc/explow.c | 6 |
2 files changed, 8 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b7c4690..8b5988b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -23,6 +23,9 @@ 2003-04-14 Olivier Hainque <hainque@act-europe.fr> + * explow.c (round_push): Use HOST_WIDE_INT instead of int for the + temporary used to round CONST_INT sizes. + * tree.c (int_fits_type_p): Extract generic checks from the case of constant type bounds. Refine the checks against constant type bounds to allow for possible decisions against each of these bounds diff --git a/gcc/explow.c b/gcc/explow.c index 9ed034e..b6c290f 100644 --- a/gcc/explow.c +++ b/gcc/explow.c @@ -945,11 +945,14 @@ round_push (size) rtx size; { int align = PREFERRED_STACK_BOUNDARY / BITS_PER_UNIT; + if (align == 1) return size; + if (GET_CODE (size) == CONST_INT) { - int new = (INTVAL (size) + align - 1) / align * align; + HOST_WIDE_INT new = (INTVAL (size) + align - 1) / align * align; + if (INTVAL (size) != new) size = GEN_INT (new); } @@ -964,6 +967,7 @@ round_push (size) NULL_RTX, 1); size = expand_mult (Pmode, size, GEN_INT (align), NULL_RTX, 1); } + return size; } |