OSDN Git Service

* recog.c (general_operand, immediate_operand,
authoraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 12 Apr 2001 05:25:55 +0000 (05:25 +0000)
committeraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 12 Apr 2001 05:25:55 +0000 (05:25 +0000)
nonmemory_operand): Require CONST_INTs to be sign-extended
values for their modes.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@41286 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/recog.c

index 83ec619..20cf366 100644 (file)
@@ -1,5 +1,11 @@
 2001-04-12  Alexandre Oliva  <aoliva@redhat.com>
 
+       * recog.c (general_operand, immediate_operand,
+       nonmemory_operand): Require CONST_INTs to be sign-extended
+       values for their modes.
+
+2001-04-12  Alexandre Oliva  <aoliva@redhat.com>
+
        * expmed.c (store_bit_field): Truncate CONST_INTs.
        (expand_mult_highpart, expand_divmod): Likewise.
        * expr.c (convert_modes, store_field): Likewise.
index bbecd5b..1c9fdf9 100644 (file)
@@ -1114,6 +1114,10 @@ general_operand (op, mode)
       && GET_MODE_CLASS (mode) != MODE_PARTIAL_INT)
     return 0;
 
+  if (GET_CODE (op) == CONST_INT
+      && trunc_int_for_mode (INTVAL (op), mode) != INTVAL (op))
+    return 0;
+
   if (CONSTANT_P (op))
     return ((GET_MODE (op) == VOIDmode || GET_MODE (op) == mode
             || mode == VOIDmode)
@@ -1290,6 +1294,10 @@ immediate_operand (op, mode)
       && GET_MODE_CLASS (mode) != MODE_PARTIAL_INT)
     return 0;
 
+  if (GET_CODE (op) == CONST_INT
+      && trunc_int_for_mode (INTVAL (op), mode) != INTVAL (op))
+    return 0;
+
   /* Accept CONSTANT_P_RTX, since it will be gone by CSE1 and
      result in 0/1.  It seems a safe assumption that this is
      in range for everyone.  */
@@ -1361,6 +1369,10 @@ nonmemory_operand (op, mode)
          && GET_MODE_CLASS (mode) != MODE_PARTIAL_INT)
        return 0;
 
+      if (GET_CODE (op) == CONST_INT
+         && trunc_int_for_mode (INTVAL (op), mode) != INTVAL (op))
+       return 0;
+
       return ((GET_MODE (op) == VOIDmode || GET_MODE (op) == mode
              || mode == VOIDmode)
 #ifdef LEGITIMATE_PIC_OPERAND_P