mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-24 12:23:31 +08:00
x86: re-order insn template fields
This saves quite a number of shift instructions: The "operands" field can now be retrieved by just masking (no shift), and extracting the "extension_opcode" field now only requires a (signed) right shift, with no prereq left one. (Of course there may be architectures where, in a cross build, there might be no difference at all, e.g. when there are suitable bitfield extraction insns.)
This commit is contained in:
@ -1444,8 +1444,8 @@ output_i386_opcode (FILE *table, const char *name, char *str,
|
|||||||
fail (_("%s:%d: %s: residual opcode (0x%0*llx) too large\n"),
|
fail (_("%s:%d: %s: residual opcode (0x%0*llx) too large\n"),
|
||||||
filename, lineno, name, 2 * length, opcode);
|
filename, lineno, name, 2 * length, opcode);
|
||||||
|
|
||||||
fprintf (table, " { \"%s\", 0x%0*llx%s, %s, %lu,\n",
|
fprintf (table, " { \"%s\", 0x%0*llx%s, %lu, %s,\n",
|
||||||
name, 2 * (int)length, opcode, end, extension_opcode, i);
|
name, 2 * (int)length, opcode, end, i, extension_opcode);
|
||||||
|
|
||||||
process_i386_opcode_modifier (table, opcode_modifier, space, prefix,
|
process_i386_opcode_modifier (table, opcode_modifier, space, prefix,
|
||||||
operand_types, lineno);
|
operand_types, lineno);
|
||||||
|
@ -915,6 +915,11 @@ typedef struct insn_template
|
|||||||
/* instruction name sans width suffix ("mov" for movl insns) */
|
/* instruction name sans width suffix ("mov" for movl insns) */
|
||||||
char *name;
|
char *name;
|
||||||
|
|
||||||
|
/* Bitfield arrangement is such that individual fields can be easily
|
||||||
|
extracted (in native builds at least) - either by at most a masking
|
||||||
|
operation (base_opcode, operands), or by just a (signed) right shift
|
||||||
|
(extension_opcode). Please try to maintain this property. */
|
||||||
|
|
||||||
/* base_opcode is the fundamental opcode byte without optional
|
/* base_opcode is the fundamental opcode byte without optional
|
||||||
prefix(es). */
|
prefix(es). */
|
||||||
unsigned int base_opcode:16;
|
unsigned int base_opcode:16;
|
||||||
@ -929,6 +934,12 @@ typedef struct insn_template
|
|||||||
from all other values above. */
|
from all other values above. */
|
||||||
#define Opcode_VexW 0xf /* Operand order controlled by VEX.W. */
|
#define Opcode_VexW 0xf /* Operand order controlled by VEX.W. */
|
||||||
|
|
||||||
|
/* how many operands */
|
||||||
|
unsigned int operands:3;
|
||||||
|
|
||||||
|
/* spare bits */
|
||||||
|
unsigned int :4;
|
||||||
|
|
||||||
/* (Fake) base opcode value for pseudo prefixes. */
|
/* (Fake) base opcode value for pseudo prefixes. */
|
||||||
#define PSEUDO_PREFIX 0
|
#define PSEUDO_PREFIX 0
|
||||||
|
|
||||||
@ -952,9 +963,6 @@ typedef struct insn_template
|
|||||||
#define Prefix_REX 8 /* {rex} */
|
#define Prefix_REX 8 /* {rex} */
|
||||||
#define Prefix_NoOptimize 9 /* {nooptimize} */
|
#define Prefix_NoOptimize 9 /* {nooptimize} */
|
||||||
|
|
||||||
/* how many operands */
|
|
||||||
unsigned int operands:3;
|
|
||||||
|
|
||||||
/* the bits in opcode_modifier are used to generate the final opcode from
|
/* the bits in opcode_modifier are used to generate the final opcode from
|
||||||
the base_opcode. These bits also are used to detect alternate forms of
|
the base_opcode. These bits also are used to detect alternate forms of
|
||||||
the same instruction */
|
the same instruction */
|
||||||
|
7430
opcodes/i386-tbl.h
7430
opcodes/i386-tbl.h
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user