From 70f1628747fd4ec69fce0e26067e1a42f7b2504a Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Tue, 3 Feb 2009 18:27:45 +0100 Subject: [PATCH] re PR target/35318 (ICE with inline asm in reload) PR target/35318 * function.c (match_asm_constraints_1): Skip over initial optional % in the constraint. * gcc.c-torture/compile/pr35318.c: New test. From-SVN: r143901 --- gcc/ChangeLog | 4 ++++ gcc/function.c | 3 +++ gcc/testsuite/ChangeLog | 3 +++ gcc/testsuite/gcc.c-torture/compile/pr35318.c | 8 ++++++++ 4 files changed, 18 insertions(+) create mode 100644 gcc/testsuite/gcc.c-torture/compile/pr35318.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a92228c9b11..d9eb79f1a62 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2009-02-03 Jakub Jelinek + PR target/35318 + * function.c (match_asm_constraints_1): Skip over + initial optional % in the constraint. + PR inline-asm/39059 * c-parser.c (c_parser_postfix_expression): If fixed point is not supported, don't accept FIXED_CSTs. diff --git a/gcc/function.c b/gcc/function.c index 0cf4d5d0000..7489dc915dd 100644 --- a/gcc/function.c +++ b/gcc/function.c @@ -5477,6 +5477,9 @@ match_asm_constraints_1 (rtx insn, rtx *p_sets, int noutputs) char *end; int match, j; + if (*constraint == '%') + constraint++; + match = strtoul (constraint, &end, 10); if (end == constraint) continue; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 4062c8688a5..1df4e70f703 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2009-02-03 Jakub Jelinek + PR target/35318 + * gcc.c-torture/compile/pr35318.c: New test. + PR inline-asm/39059 * gcc.dg/nofixed-point-2.c: New test. * g++.dg/ext/fixed1.C: Adjust expected diagnostics. diff --git a/gcc/testsuite/gcc.c-torture/compile/pr35318.c b/gcc/testsuite/gcc.c-torture/compile/pr35318.c new file mode 100644 index 00000000000..85bb3626986 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/pr35318.c @@ -0,0 +1,8 @@ +/* PR target/35318 */ + +void +foo () +{ + double x = 4, y; + __asm__ volatile ("" : "=r,r" (x), "=r,r" (y) : "%0,0" (x), "m,r" (8)); +}