aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Kenner <kenner@vlsi1.ultra.nyu.edu>2001-03-21 19:49:54 +0000
committerRichard Kenner <kenner@gcc.gnu.org>2001-03-21 14:49:54 -0500
commita8d1960882c702df96396caa90c5dedd7d1a7cba (patch)
treeccd01391f0aa31284960b2b2a2b8ddf3bf8191c7 /gcc
parent4eadbbd5bf0ea871aba3302a73e45adce2cc5938 (diff)
downloadgcc-a8d1960882c702df96396caa90c5dedd7d1a7cba.zip
gcc-a8d1960882c702df96396caa90c5dedd7d1a7cba.tar.gz
gcc-a8d1960882c702df96396caa90c5dedd7d1a7cba.tar.bz2
recog.c (push_operand): Fix error in last change that caused undefined symbol on many targets.
* recog.c (push_operand): Fix error in last change that caused undefined symbol on many targets. From-SVN: r40712
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog3
-rw-r--r--gcc/recog.c11
2 files changed, 11 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 0429118..d0425f7 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,8 @@
Wed Mar 21 14:27:11 2001 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
+ * recog.c (push_operand): Fix error in last change that caused
+ undefined symbol on many targets.
+
* sdbout.c: #include ggc.h.
(sdbout_init): Move to end of file.
Call ggc_add_tree_root for anonymous_types.
diff --git a/gcc/recog.c b/gcc/recog.c
index 195d3f4..55f6656 100644
--- a/gcc/recog.c
+++ b/gcc/recog.c
@@ -1350,6 +1350,12 @@ push_operand (op, mode)
rtx op;
enum machine_mode mode;
{
+ unsigned int rounded_size = GET_MODE_SIZE (mode);
+
+#ifdef PUSH_ROUNDING
+ rounded_size = PUSH_ROUNDING (rounded_size);
+#endif
+
if (GET_CODE (op) != MEM)
return 0;
@@ -1358,20 +1364,19 @@ push_operand (op, mode)
op = XEXP (op, 0);
- if (PUSH_ROUNDING (GET_MODE_SIZE (mode)) == GET_MODE_SIZE (mode))
+ if (rounded_size == GET_MODE_SIZE (mode))
{
if (GET_CODE (op) != STACK_PUSH_CODE)
return 0;
}
else
{
- int rounded_size = PUSH_ROUNDING (GET_MODE_SIZE (mode));
if (GET_CODE (op) != PRE_MODIFY
|| GET_CODE (XEXP (op, 1)) != PLUS
|| XEXP (XEXP (op, 1), 0) != XEXP (op, 0)
|| GET_CODE (XEXP (XEXP (op, 1), 1)) != CONST_INT
#ifdef STACK_GROWS_DOWNWARD
- || INTVAL (XEXP (XEXP (op, 1), 1)) != -rounded_size
+ || INTVAL (XEXP (XEXP (op, 1), 1)) != - (int) rounded_size
#else
|| INTVAL (XEXP (XEXP (op, 1), 1)) != rounded_size
#endif