aboutsummaryrefslogtreecommitdiff
path: root/gcc/recog.c
diff options
context:
space:
mode:
authorJ"orn Rennecke <joern.rennecke@superh.com>2002-07-23 20:51:00 +0000
committerJoern Rennecke <amylaar@gcc.gnu.org>2002-07-23 21:51:00 +0100
commitbf7cd75401b5d5830e1718f5dd5d7e4c05b4b615 (patch)
treea5d5505e1aa6fa31c9ad1126476f0b586999ccb8 /gcc/recog.c
parent13fd931e49da6fbdcc4a9dbb080ab87f4b89d2ca (diff)
downloadgcc-bf7cd75401b5d5830e1718f5dd5d7e4c05b4b615.zip
gcc-bf7cd75401b5d5830e1718f5dd5d7e4c05b4b615.tar.gz
gcc-bf7cd75401b5d5830e1718f5dd5d7e4c05b4b615.tar.bz2
recog.c (asm_operand_ok): Allow float CONST_VECTORs for 'F'.
* recog.c (asm_operand_ok): Allow float CONST_VECTORs for 'F'. (constrain_operands): Likewise. * regclass.c (record_reg_classes): Likewise. * reload.c (find_reloads): Likewise. * doc/md.texi: Likewise. From-SVN: r55689
Diffstat (limited to 'gcc/recog.c')
-rw-r--r--gcc/recog.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/gcc/recog.c b/gcc/recog.c
index 3769249..c56069a 100644
--- a/gcc/recog.c
+++ b/gcc/recog.c
@@ -1745,7 +1745,9 @@ asm_operand_ok (op, constraint)
case 'E':
case 'F':
- if (GET_CODE (op) == CONST_DOUBLE)
+ if (GET_CODE (op) == CONST_DOUBLE
+ || (GET_CODE (op) == CONST_VECTOR
+ && GET_MODE_CLASS (GET_MODE (op)) == MODE_VECTOR_FLOAT))
return 1;
break;
@@ -2513,7 +2515,9 @@ constrain_operands (strict)
case 'E':
case 'F':
- if (GET_CODE (op) == CONST_DOUBLE)
+ if (GET_CODE (op) == CONST_DOUBLE
+ || (GET_CODE (op) == CONST_VECTOR
+ && GET_MODE_CLASS (GET_MODE (op)) == MODE_VECTOR_FLOAT))
win = 1;
break;