aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/include/asm/inat.h
diff options
context:
space:
mode:
authorMasami Hiramatsu <mhiramat@redhat.com>2009-10-27 16:42:11 -0400
committerIngo Molnar <mingo@elte.hu>2009-10-29 03:47:45 -0400
commit04d46c1b13b02e1e5c24eb270a01cf3f94ee4d04 (patch)
treeb5a4b8c1229b1b1defe2d6671319ff0cfbe21ada /arch/x86/include/asm/inat.h
parent7f387d3f2421781610588faa2f49ae5f1737b137 (diff)
x86: Merge INAT_REXPFX into INAT_PFX_*
Merge INAT_REXPFX into INAT_PFX_* macro and rename it to INAT_PFX_REX. Signed-off-by: Masami Hiramatsu <mhiramat@redhat.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Jim Keniston <jkenisto@us.ibm.com> Cc: Ananth N Mavinakayanahalli <ananth@in.ibm.com> Cc: Christoph Hellwig <hch@infradead.org> Cc: Frank Ch. Eigler <fche@redhat.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Jason Baron <jbaron@redhat.com> Cc: K.Prasad <prasad@linux.vnet.ibm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> LKML-Reference: <20091027204211.30545.58090.stgit@harusame> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/include/asm/inat.h')
-rw-r--r--arch/x86/include/asm/inat.h36
1 files changed, 20 insertions, 16 deletions
diff --git a/arch/x86/include/asm/inat.h b/arch/x86/include/asm/inat.h
index 2866fddd1848..c2487d2aca25 100644
--- a/arch/x86/include/asm/inat.h
+++ b/arch/x86/include/asm/inat.h
@@ -30,10 +30,11 @@
30#define INAT_OPCODE_TABLE_SIZE 256 30#define INAT_OPCODE_TABLE_SIZE 256
31#define INAT_GROUP_TABLE_SIZE 8 31#define INAT_GROUP_TABLE_SIZE 8
32 32
33/* Legacy instruction prefixes */ 33/* Legacy last prefixes */
34#define INAT_PFX_OPNDSZ 1 /* 0x66 */ /* LPFX1 */ 34#define INAT_PFX_OPNDSZ 1 /* 0x66 */ /* LPFX1 */
35#define INAT_PFX_REPNE 2 /* 0xF2 */ /* LPFX2 */ 35#define INAT_PFX_REPNE 2 /* 0xF2 */ /* LPFX2 */
36#define INAT_PFX_REPE 3 /* 0xF3 */ /* LPFX3 */ 36#define INAT_PFX_REPE 3 /* 0xF3 */ /* LPFX3 */
37/* Other Legacy prefixes */
37#define INAT_PFX_LOCK 4 /* 0xF0 */ 38#define INAT_PFX_LOCK 4 /* 0xF0 */
38#define INAT_PFX_CS 5 /* 0x2E */ 39#define INAT_PFX_CS 5 /* 0x2E */
39#define INAT_PFX_DS 6 /* 0x3E */ 40#define INAT_PFX_DS 6 /* 0x3E */
@@ -42,8 +43,11 @@
42#define INAT_PFX_GS 9 /* 0x65 */ 43#define INAT_PFX_GS 9 /* 0x65 */
43#define INAT_PFX_SS 10 /* 0x36 */ 44#define INAT_PFX_SS 10 /* 0x36 */
44#define INAT_PFX_ADDRSZ 11 /* 0x67 */ 45#define INAT_PFX_ADDRSZ 11 /* 0x67 */
46/* x86-64 REX prefix */
47#define INAT_PFX_REX 12 /* 0x4X */
45 48
46#define INAT_LPREFIX_MAX 3 49#define INAT_LSTPFX_MAX 3
50#define INAT_LGCPFX_MAX 11
47 51
48/* Immediate size */ 52/* Immediate size */
49#define INAT_IMM_BYTE 1 53#define INAT_IMM_BYTE 1
@@ -75,12 +79,11 @@
75#define INAT_IMM_MASK (((1 << INAT_IMM_BITS) - 1) << INAT_IMM_OFFS) 79#define INAT_IMM_MASK (((1 << INAT_IMM_BITS) - 1) << INAT_IMM_OFFS)
76/* Flags */ 80/* Flags */
77#define INAT_FLAG_OFFS (INAT_IMM_OFFS + INAT_IMM_BITS) 81#define INAT_FLAG_OFFS (INAT_IMM_OFFS + INAT_IMM_BITS)
78#define INAT_REXPFX (1 << INAT_FLAG_OFFS) 82#define INAT_MODRM (1 << (INAT_FLAG_OFFS))
79#define INAT_MODRM (1 << (INAT_FLAG_OFFS + 1)) 83#define INAT_FORCE64 (1 << (INAT_FLAG_OFFS + 1))
80#define INAT_FORCE64 (1 << (INAT_FLAG_OFFS + 2)) 84#define INAT_SCNDIMM (1 << (INAT_FLAG_OFFS + 2))
81#define INAT_SCNDIMM (1 << (INAT_FLAG_OFFS + 3)) 85#define INAT_MOFFSET (1 << (INAT_FLAG_OFFS + 3))
82#define INAT_MOFFSET (1 << (INAT_FLAG_OFFS + 4)) 86#define INAT_VARIANT (1 << (INAT_FLAG_OFFS + 4))
83#define INAT_VARIANT (1 << (INAT_FLAG_OFFS + 5))
84/* Attribute making macros for attribute tables */ 87/* Attribute making macros for attribute tables */
85#define INAT_MAKE_PREFIX(pfx) (pfx << INAT_PFX_OFFS) 88#define INAT_MAKE_PREFIX(pfx) (pfx << INAT_PFX_OFFS)
86#define INAT_MAKE_ESCAPE(esc) (esc << INAT_ESC_OFFS) 89#define INAT_MAKE_ESCAPE(esc) (esc << INAT_ESC_OFFS)
@@ -97,9 +100,10 @@ extern insn_attr_t inat_get_group_attribute(insn_byte_t modrm,
97 insn_attr_t esc_attr); 100 insn_attr_t esc_attr);
98 101
99/* Attribute checking functions */ 102/* Attribute checking functions */
100static inline int inat_is_prefix(insn_attr_t attr) 103static inline int inat_is_legacy_prefix(insn_attr_t attr)
101{ 104{
102 return attr & INAT_PFX_MASK; 105 attr &= INAT_PFX_MASK;
106 return attr && attr <= INAT_LGCPFX_MAX;
103} 107}
104 108
105static inline int inat_is_address_size_prefix(insn_attr_t attr) 109static inline int inat_is_address_size_prefix(insn_attr_t attr)
@@ -112,9 +116,14 @@ static inline int inat_is_operand_size_prefix(insn_attr_t attr)
112 return (attr & INAT_PFX_MASK) == INAT_PFX_OPNDSZ; 116 return (attr & INAT_PFX_MASK) == INAT_PFX_OPNDSZ;
113} 117}
114 118
119static inline int inat_is_rex_prefix(insn_attr_t attr)
120{
121 return (attr & INAT_PFX_MASK) == INAT_PFX_REX;
122}
123
115static inline int inat_last_prefix_id(insn_attr_t attr) 124static inline int inat_last_prefix_id(insn_attr_t attr)
116{ 125{
117 if ((attr & INAT_PFX_MASK) > INAT_LPREFIX_MAX) 126 if ((attr & INAT_PFX_MASK) > INAT_LSTPFX_MAX)
118 return 0; 127 return 0;
119 else 128 else
120 return attr & INAT_PFX_MASK; 129 return attr & INAT_PFX_MASK;
@@ -155,11 +164,6 @@ static inline int inat_immediate_size(insn_attr_t attr)
155 return (attr & INAT_IMM_MASK) >> INAT_IMM_OFFS; 164 return (attr & INAT_IMM_MASK) >> INAT_IMM_OFFS;
156} 165}
157 166
158static inline int inat_is_rex_prefix(insn_attr_t attr)
159{
160 return attr & INAT_REXPFX;
161}
162
163static inline int inat_has_modrm(insn_attr_t attr) 167static inline int inat_has_modrm(insn_attr_t attr)
164{ 168{
165 return attr & INAT_MODRM; 169 return attr & INAT_MODRM;