Instruction Properties and prefixes | |
static XED_INLINE void | xed_addr (xed_encoder_instruction_t *x, xed_uint_t width) |
This is to specify effective address size different than the default. | |
XED_DLL_EXPORT xed_bool_t | xed_convert_to_encoder_request (xed_encoder_request_t *out, xed_encoder_instruction_t *in) |
convert a xed_encoder_instruction_t to a xed_encoder_request_t for encoding | |
static XED_INLINE void | xed_lock (xed_encoder_instruction_t *x) |
static XED_INLINE void | xed_rep (xed_encoder_instruction_t *x) |
static XED_INLINE void | xed_repne (xed_encoder_instruction_t *x) |
Memory Displacement | |
static XED_INLINE xed_enc_displacement_t | xed_disp (xed_uint64_t displacement, xed_uint32_t displacement_width) |
a memory displacement (not for branches) | |
Register and Immmediate Operands | |
static XED_INLINE xed_encoder_operand_t | xed_imm0 (xed_uint64_t v, xed_uint_t width) |
a first immediate operand (known as IMM0) | |
static XED_INLINE xed_encoder_operand_t | xed_imm1 (xed_uint8_t v) |
an second immediate operand (known as IMM1) | |
static XED_INLINE xed_encoder_operand_t | xed_other (xed_operand_enum_t operand_name, xed_int32_t value) |
an operand storage field name and value | |
static XED_INLINE xed_encoder_operand_t | xed_reg (xed_reg_enum_t reg) |
a register operand | |
static XED_INLINE xed_encoder_operand_t | xed_simm0 (xed_int32_t v, xed_uint_t width) |
an 32b signed immediate operand | |
Creating instructions from operands | |
static XED_INLINE void | xed_inst (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width, xed_uint_t number_of_operands, const xed_encoder_operand_t *operand_array) |
instruction with an array of operands. | |
static XED_INLINE void | xed_inst0 (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width) |
instruction with no operands | |
static XED_INLINE void | xed_inst1 (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width, xed_encoder_operand_t op0) |
instruction with one operand | |
static XED_INLINE void | xed_inst2 (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width, xed_encoder_operand_t op0, xed_encoder_operand_t op1) |
instruction with two operands | |
static XED_INLINE void | xed_inst3 (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width, xed_encoder_operand_t op0, xed_encoder_operand_t op1, xed_encoder_operand_t op2) |
instruction with three operands | |
static XED_INLINE void | xed_inst4 (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width, xed_encoder_operand_t op0, xed_encoder_operand_t op1, xed_encoder_operand_t op2, xed_encoder_operand_t op3) |
instruction with four operands | |
static XED_INLINE void | xed_inst5 (xed_encoder_instruction_t *inst, xed_state_t mode, xed_iclass_enum_t iclass, xed_uint_t effective_operand_width, xed_encoder_operand_t op0, xed_encoder_operand_t op1, xed_encoder_operand_t op2, xed_encoder_operand_t op3, xed_encoder_operand_t op4) |
instruction with five operands | |
Memory and Segment-releated Operands | |
static XED_INLINE xed_encoder_operand_t | xed_mem_b (xed_reg_enum_t base, xed_uint_t width) |
memory operand - base only | |
static XED_INLINE xed_encoder_operand_t | xed_mem_bd (xed_reg_enum_t base, xed_enc_displacement_t disp, xed_uint_t width) |
memory operand - base and displacement only | |
static XED_INLINE xed_encoder_operand_t | xed_mem_bisd (xed_reg_enum_t base, xed_reg_enum_t index, xed_uint_t scale, xed_enc_displacement_t disp, xed_uint_t width) |
memory operand - base, index, scale, displacement | |
static XED_INLINE xed_encoder_operand_t | xed_mem_gb (xed_reg_enum_t seg, xed_reg_enum_t base, xed_uint_t width) |
memory operand - segment and base only | |
static XED_INLINE xed_encoder_operand_t | xed_mem_gbd (xed_reg_enum_t seg, xed_reg_enum_t base, xed_enc_displacement_t disp, xed_uint_t width) |
memory operand - segment, base and displacement only | |
static XED_INLINE xed_encoder_operand_t | xed_mem_gbisd (xed_reg_enum_t seg, xed_reg_enum_t base, xed_reg_enum_t index, xed_uint_t scale, xed_enc_displacement_t disp, xed_uint_t width) |
memory operand - segment, base, index, scale, and displacement | |
static XED_INLINE xed_encoder_operand_t | xed_mem_gd (xed_reg_enum_t seg, xed_enc_displacement_t disp, xed_uint_t width) |
memory operand - segment and displacement only | |
static XED_INLINE xed_encoder_operand_t | xed_seg0 (xed_reg_enum_t seg0) |
seg reg override for implicit suppressed memory ops | |
static XED_INLINE xed_encoder_operand_t | xed_seg1 (xed_reg_enum_t seg1) |
seg reg override for implicit suppressed memory ops | |
Pointer Displacement | |
static XED_INLINE xed_encoder_operand_t | xed_ptr (xed_int32_t brdisp, xed_uint_t width) |
a relative displacement for a PTR operand -- the subsequent imm0 holds the 16b selector | |
Branch Displacement | |
static XED_INLINE xed_encoder_operand_t | xed_relbr (xed_int32_t brdisp, xed_uint_t width) |
a relative branch displacement operand |
A full example is present in examples/xed-ex5-enc.c
In the following example we create one instructions template that can be passed to the encoder.
xed_encoder_instruction_t x; xed_encoder_request_t enc_req; xed_state_t dstate; dstate.mmode=XED_MACHINE_MODE_LEGACY_32; dstate.stack_addr_width=XED_ADDRESS_WIDTH_32b; xed_inst2(&x, dstate, XED_ICLASS_ADD, 0, xreg(XED_REG_EAX), xmem_bd(XED_REG_EDX, xdisp(0x11223344, 32), 32)); xed_encoder_request_zero_set_mode(&enc_req, &dstate); convert_ok = xed_convert_to_encoder_request(&enc_req, &x); if (!convert_ok) { fprintf(stderr,"conversion to encode request failed\n"); continue; } xed_error = xed_encode(&enc_req, itext, ilen, &olen);
The high-level encoder interface allows passing the effective operand width for the xed_inst*() function as 0 (zero) when the effective operand width is the default.
The default width in 16b mode is 16b. The default width in 32b or 64b modes is 32b. So if you do a 16b operation in 32b/64b mode, you must set the effective operand width. If you do a 64b operation in 64b mode, you must set it (the default is 32). Or if you do a more rare 32b operation in 16b mode you must also set it.
When all the operands are "suppressed" operands, then the effective operand width must be supplied for nondefault operation widths.
static XED_INLINE void xed_addr | ( | xed_encoder_instruction_t * | x, | |
xed_uint_t | width | |||
) | [static] |
This is to specify effective address size different than the default.
For things with base or index regs, XED picks it up from the registers. But for things that have implicit memops, or no base or index reg, we must allow the user to set the address width directly.
Definition at line 380 of file xed-encoder-hl.h.
XED_DLL_EXPORT xed_bool_t xed_convert_to_encoder_request | ( | xed_encoder_request_t * | out, | |
xed_encoder_instruction_t * | in | |||
) |
convert a xed_encoder_instruction_t to a xed_encoder_request_t for encoding
static XED_INLINE xed_enc_displacement_t xed_disp | ( | xed_uint64_t | displacement, | |
xed_uint32_t | displacement_width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_imm0 | ( | xed_uint64_t | v, | |
xed_uint_t | width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_imm1 | ( | xed_uint8_t | v | ) | [static] |
static XED_INLINE void xed_inst | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width, | |||
xed_uint_t | number_of_operands, | |||
const xed_encoder_operand_t * | operand_array | |||
) | [static] |
instruction with an array of operands.
The maximum number is XED_ENCODER_OPERANDS_MAX. The array's contents are copied.
Definition at line 553 of file xed-encoder-hl.h.
static XED_INLINE void xed_inst0 | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width | |||
) | [static] |
static XED_INLINE void xed_inst1 | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width, | |||
xed_encoder_operand_t | op0 | |||
) | [static] |
static XED_INLINE void xed_inst2 | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width, | |||
xed_encoder_operand_t | op0, | |||
xed_encoder_operand_t | op1 | |||
) | [static] |
static XED_INLINE void xed_inst3 | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width, | |||
xed_encoder_operand_t | op0, | |||
xed_encoder_operand_t | op1, | |||
xed_encoder_operand_t | op2 | |||
) | [static] |
static XED_INLINE void xed_inst4 | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width, | |||
xed_encoder_operand_t | op0, | |||
xed_encoder_operand_t | op1, | |||
xed_encoder_operand_t | op2, | |||
xed_encoder_operand_t | op3 | |||
) | [static] |
static XED_INLINE void xed_inst5 | ( | xed_encoder_instruction_t * | inst, | |
xed_state_t | mode, | |||
xed_iclass_enum_t | iclass, | |||
xed_uint_t | effective_operand_width, | |||
xed_encoder_operand_t | op0, | |||
xed_encoder_operand_t | op1, | |||
xed_encoder_operand_t | op2, | |||
xed_encoder_operand_t | op3, | |||
xed_encoder_operand_t | op4 | |||
) | [static] |
static XED_INLINE void xed_lock | ( | xed_encoder_instruction_t * | x | ) | [static] |
Definition at line 397 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_mem_b | ( | xed_reg_enum_t | base, | |
xed_uint_t | width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_mem_bd | ( | xed_reg_enum_t | base, | |
xed_enc_displacement_t | disp, | |||
xed_uint_t | width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_mem_bisd | ( | xed_reg_enum_t | base, | |
xed_reg_enum_t | index, | |||
xed_uint_t | scale, | |||
xed_enc_displacement_t | disp, | |||
xed_uint_t | width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_mem_gb | ( | xed_reg_enum_t | seg, | |
xed_reg_enum_t | base, | |||
xed_uint_t | width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_mem_gbd | ( | xed_reg_enum_t | seg, | |
xed_reg_enum_t | base, | |||
xed_enc_displacement_t | disp, | |||
xed_uint_t | width | |||
) | [static] |
memory operand - segment, base and displacement only
Definition at line 291 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_mem_gbisd | ( | xed_reg_enum_t | seg, | |
xed_reg_enum_t | base, | |||
xed_reg_enum_t | index, | |||
xed_uint_t | scale, | |||
xed_enc_displacement_t | disp, | |||
xed_uint_t | width | |||
) | [static] |
memory operand - segment, base, index, scale, and displacement
Definition at line 324 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_mem_gd | ( | xed_reg_enum_t | seg, | |
xed_enc_displacement_t | disp, | |||
xed_uint_t | width | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_other | ( | xed_operand_enum_t | operand_name, | |
xed_int32_t | value | |||
) | [static] |
static XED_INLINE xed_encoder_operand_t xed_ptr | ( | xed_int32_t | brdisp, | |
xed_uint_t | width | |||
) | [static] |
a relative displacement for a PTR operand -- the subsequent imm0 holds the 16b selector
Definition at line 125 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_reg | ( | xed_reg_enum_t | reg | ) | [static] |
static XED_INLINE xed_encoder_operand_t xed_relbr | ( | xed_int32_t | brdisp, | |
xed_uint_t | width | |||
) | [static] |
static XED_INLINE void xed_rep | ( | xed_encoder_instruction_t * | x | ) | [static] |
Definition at line 387 of file xed-encoder-hl.h.
static XED_INLINE void xed_repne | ( | xed_encoder_instruction_t * | x | ) | [static] |
Definition at line 392 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_seg0 | ( | xed_reg_enum_t | seg0 | ) | [static] |
seg reg override for implicit suppressed memory ops
Definition at line 205 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_seg1 | ( | xed_reg_enum_t | seg1 | ) | [static] |
seg reg override for implicit suppressed memory ops
Definition at line 214 of file xed-encoder-hl.h.
static XED_INLINE xed_encoder_operand_t xed_simm0 | ( | xed_int32_t | v, | |
xed_uint_t | width | |||
) | [static] |