diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2007-09-04 14:44:35 +0000 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2007-09-04 14:44:35 +0000 |
commit | 75178d9df6665275c9b4726f8281f74803a25e54 (patch) | |
tree | 7e99954074a7f52f74b20d1c21f4a4b73b780dae /gas | |
parent | 2525df0347977ad33e02c215a474a681a24f756b (diff) | |
download | gdb-75178d9df6665275c9b4726f8281f74803a25e54.zip gdb-75178d9df6665275c9b4726f8281f74803a25e54.tar.gz gdb-75178d9df6665275c9b4726f8281f74803a25e54.tar.bz2 |
2007-09-04 H.J. Lu <hongjiu.lu@intel.com>
* config/tc-i386.c (process_operands): Remove segment override
check on SVME instructions.
(i386_index_check): Remove memory operand check on SVME
instructions.
Diffstat (limited to 'gas')
-rw-r--r-- | gas/ChangeLog | 7 | ||||
-rw-r--r-- | gas/config/tc-i386.c | 31 |
2 files changed, 11 insertions, 27 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog index 6fb2893..1df3e4d 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,10 @@ +2007-09-04 H.J. Lu <hongjiu.lu@intel.com> + + * config/tc-i386.c (process_operands): Remove segment override + check on SVME instructions. + (i386_index_check): Remove memory operand check on SVME + instructions. + 2007-09-04 Alan Modra <amodra@bigpond.net.au> * config/tc-spu.c (struct spu_insn): Delete "flag". Add "reloc". diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c index 0f6396f..9a39d43 100644 --- a/gas/config/tc-i386.c +++ b/gas/config/tc-i386.c @@ -3477,9 +3477,9 @@ process_operands (void) default_seg = &ds; } - if ((i.tm.base_opcode == 0x8d /* lea */ - || (i.tm.cpu_flags & CpuSVME)) - && i.seg[0] && !quiet_warnings) + if (i.tm.base_opcode == 0x8d /* lea */ + && i.seg[0] + && !quiet_warnings) as_warn (_("segment override on `%s' is ineffectual"), i.tm.name); /* If a segment was explicitly specified, and the specified segment @@ -4962,30 +4962,7 @@ i386_index_check (const char *operand_string) tryprefix: #endif ok = 1; - if ((current_templates->start->cpu_flags & CpuSVME) - && current_templates->end[-1].operand_types[0] == AnyMem) - { - /* Memory operands of SVME insns are special in that they only allow - rAX as their memory address and ignore any segment override. */ - unsigned RegXX; - - /* SKINIT is even more restrictive: it always requires EAX. */ - if (strcmp (current_templates->start->name, "skinit") == 0) - RegXX = Reg32; - else if (flag_code == CODE_64BIT) - RegXX = i.prefix[ADDR_PREFIX] == 0 ? Reg64 : Reg32; - else - RegXX = ((flag_code == CODE_16BIT) ^ (i.prefix[ADDR_PREFIX] != 0) - ? Reg16 - : Reg32); - if (!i.base_reg - || !(i.base_reg->reg_type & Acc) - || !(i.base_reg->reg_type & RegXX) - || i.index_reg - || (i.types[0] & Disp)) - ok = 0; - } - else if (flag_code == CODE_64BIT) + if (flag_code == CODE_64BIT) { unsigned RegXX = (i.prefix[ADDR_PREFIX] == 0 ? Reg64 : Reg32); |