From 5717a6cecc1d689e2fa48ee823c7e379c655b358 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Sat, 20 Dec 2008 18:20:16 +0000 Subject: [PATCH] 2008-12-20 H.J. Lu * config/tc-i386.c (parse_insn): Optimize ".s" handling. --- gas/ChangeLog | 4 ++++ gas/config/tc-i386.c | 21 +++++++++------------ 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/gas/ChangeLog b/gas/ChangeLog index 4d9c5a066..8e6d86c87 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,5 +1,9 @@ 2008-12-20 H.J. Lu + * config/tc-i386.c (parse_insn): Optimize ".s" handling. + +2008-12-20 H.J. Lu + * config/tc-i386.c (_i386_insn): Add swap_operand. (parse_insn): Handle ".s". (match_template): Handle swap_operand. diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c index d74c1c664..5505d5cd5 100644 --- a/gas/config/tc-i386.c +++ b/gas/config/tc-i386.c @@ -2994,19 +2994,16 @@ parse_insn (char *line, char *mnemonic) break; } - if (!current_templates && dot_p) + if (!current_templates) { - if (mnem_p - 2 == dot_p) - { - /* Check if we should swap operand in encoding. */ - if (dot_p[1] == 's') - i.swap_operand = 1; - else - goto check_suffix; - mnem_p = dot_p; - *dot_p = '\0'; - current_templates = hash_find (op_hash, mnemonic); - } + /* Check if we should swap operand in encoding. */ + if (mnem_p - 2 == dot_p && dot_p[1] == 's') + i.swap_operand = 1; + else + goto check_suffix; + mnem_p = dot_p; + *dot_p = '\0'; + current_templates = hash_find (op_hash, mnemonic); } if (!current_templates) -- 2.11.4.GIT