capstone/arch/X86/X86Mapping.h

47 lines
1.2 KiB
C
Raw Normal View History

2014-04-29 11:16:21 +08:00
/* Capstone Disassembly Engine */
/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014 */
2013-11-27 12:11:31 +08:00
#ifndef CS_X86_MAP_H
#define CS_X86_MAP_H
2013-11-27 12:11:31 +08:00
#include "../../include/capstone.h"
#include "../../cs_priv.h"
2013-11-27 12:11:31 +08:00
// map sib_base to x86_reg
x86_reg x86_map_sib_base(int r);
// map sib_index to x86_reg
x86_reg x86_map_sib_index(int r);
// map seg_override to x86_reg
x86_reg x86_map_segment(int r);
// return name of regiser in friendly string
2013-12-12 05:14:42 +08:00
const char *X86_reg_name(csh handle, unsigned int reg);
2013-11-27 12:11:31 +08:00
// given internal insn id, return public instruction info
void X86_get_insn_id(cs_struct *h, cs_insn *insn, unsigned int id);
2013-11-27 12:11:31 +08:00
// return insn name, given insn id
2013-12-12 05:14:42 +08:00
const char *X86_insn_name(csh handle, unsigned int id);
2013-11-27 12:11:31 +08:00
// post printer for X86.
void X86_post_printer(csh handle, cs_insn *pub_insn, char *insn_asm, MCInst *mci);
// return register of given instruction id
// return 0 if not found
// this is to handle instructions embedding accumulate registers into AsmStrs[]
x86_reg X86_insn_reg(unsigned int id);
extern uint64_t arch_masks[9];
// handle LOCK/REP/REPNE prefixes
// return True if we patch mnemonic, like in MULPD case
bool X86_lockrep(MCInst *MI, SStream *O);
// map registers to sizes
extern uint8_t regsize_map_32[];
extern uint8_t regsize_map_64[];
2013-11-27 12:11:31 +08:00
#endif