From f41bbced4588cb88ed116a617f705bcfaf9ba486 Mon Sep 17 00:00:00 2001 From: Jan Beulich Date: Mon, 9 May 2005 06:38:45 +0000 Subject: [PATCH] gas/ 2005-05-09 Jan Beulich * config/tc-i386.c (parse_insn): Consider all matching instructions when checking for string instruction after string-only prefix. --- gas/ChangeLog | 5 +++++ gas/config/tc-i386.c | 22 +++++++++++++++++----- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/gas/ChangeLog b/gas/ChangeLog index d79fc664b55..f14c9f8f7bc 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +2005-05-09 Jan Beulich + + * config/tc-i386.c (parse_insn): Consider all matching instructions + when checking for string instruction after string-only prefix. + 2005-05-07 H.J. Lu PR 940 diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c index 15db848037a..7b265464023 100644 --- a/gas/config/tc-i386.c +++ b/gas/config/tc-i386.c @@ -1765,12 +1765,24 @@ parse_insn (line, mnemonic) } /* Check for rep/repne without a string instruction. */ - if (expecting_string_instruction - && !(current_templates->start->opcode_modifier & IsString)) + if (expecting_string_instruction) { - as_bad (_("expecting string instruction after `%s'"), - expecting_string_instruction); - return NULL; + static templates override; + + for (t = current_templates->start; t < current_templates->end; ++t) + if (t->opcode_modifier & IsString) + break; + if (t >= current_templates->end) + { + as_bad (_("expecting string instruction after `%s'"), + expecting_string_instruction); + return NULL; + } + for (override.start = t; t < current_templates->end; ++t) + if (!(t->opcode_modifier & IsString)) + break; + override.end = t; + current_templates = &override; } return l; -- 2.30.2