diff options
Diffstat (limited to 'cpu-i386.h')
-rw-r--r-- | cpu-i386.h | 148 |
1 files changed, 148 insertions, 0 deletions
diff --git a/cpu-i386.h b/cpu-i386.h new file mode 100644 index 0000000000..a857efb7df --- /dev/null +++ b/cpu-i386.h @@ -0,0 +1,148 @@ +#ifndef CPU_I386_H +#define CPU_I386_H + +#define R_EAX 0 +#define R_ECX 1 +#define R_EDX 2 +#define R_EBX 3 +#define R_ESP 4 +#define R_EBP 5 +#define R_ESI 6 +#define R_EDI 7 + +#define R_AL 0 +#define R_CL 1 +#define R_DL 2 +#define R_BL 3 +#define R_AH 4 +#define R_CH 5 +#define R_DH 6 +#define R_BH 7 + +#define R_ES 0 +#define R_CS 1 +#define R_SS 2 +#define R_DS 3 +#define R_FS 4 +#define R_GS 5 + +#define CC_C 0x0001 +#define CC_P 0x0004 +#define CC_A 0x0010 +#define CC_Z 0x0040 +#define CC_S 0x0080 +#define CC_O 0x0800 + +#define TRAP_FLAG 0x0100 +#define INTERRUPT_FLAG 0x0200 +#define DIRECTION_FLAG 0x0400 +#define IOPL_FLAG_MASK 0x3000 +#define NESTED_FLAG 0x4000 +#define BYTE_FL 0x8000 /* Intel reserved! */ +#define RF_FLAG 0x10000 +#define VM_FLAG 0x20000 +/* AC 0x40000 */ + +enum { + CC_OP_DYNAMIC, /* must use dynamic code to get cc_op */ + CC_OP_EFLAGS, /* all cc are explicitely computed, CC_SRC = flags */ + CC_OP_MUL, /* modify all flags, C, O = (CC_SRC != 0) */ + + CC_OP_ADDB, /* modify all flags, CC_DST = res, CC_SRC = src1 */ + CC_OP_ADDW, + CC_OP_ADDL, + + CC_OP_SUBB, /* modify all flags, CC_DST = res, CC_SRC = src1 */ + CC_OP_SUBW, + CC_OP_SUBL, + + CC_OP_LOGICB, /* modify all flags, CC_DST = res */ + CC_OP_LOGICW, + CC_OP_LOGICL, + + CC_OP_INCB, /* modify all flags except, CC_DST = res */ + CC_OP_INCW, + CC_OP_INCL, + + CC_OP_DECB, /* modify all flags except, CC_DST = res */ + CC_OP_DECW, + CC_OP_DECL, + + CC_OP_SHLB, /* modify all flags, CC_DST = res, CC_SRC.lsb = C */ + CC_OP_SHLW, + CC_OP_SHLL, + + CC_OP_NB, +}; + +typedef struct CPU86State { + /* standard registers */ + uint32_t regs[8]; + uint32_t pc; /* cs_case + eip value */ + + /* eflags handling */ + uint32_t eflags; + uint32_t cc_src; + uint32_t cc_dst; + uint32_t cc_op; + int32_t df; /* D flag : 1 if D = 0, -1 if D = 1 */ + + /* segments */ + uint8_t *segs_base[6]; + uint32_t segs[6]; + + /* emulator internal variables */ + uint32_t t0; /* temporary t0 storage */ + uint32_t t1; /* temporary t1 storage */ + uint32_t a0; /* temporary a0 storage (address) */ +} CPU86State; + +static inline int ldub(void *ptr) +{ + return *(uint8_t *)ptr; +} + +static inline int ldsb(void *ptr) +{ + return *(int8_t *)ptr; +} + +static inline int lduw(void *ptr) +{ + return *(uint16_t *)ptr; +} + +static inline int ldsw(void *ptr) +{ + return *(int16_t *)ptr; +} + +static inline int ldl(void *ptr) +{ + return *(uint32_t *)ptr; +} + + +static inline void stb(void *ptr, int v) +{ + *(uint8_t *)ptr = v; +} + +static inline void stw(void *ptr, int v) +{ + *(uint16_t *)ptr = v; +} + +static inline void stl(void *ptr, int v) +{ + *(uint32_t *)ptr = v; +} + +void port_outb(int addr, int val); +void port_outw(int addr, int val); +void port_outl(int addr, int val); +int port_inb(int addr); +int port_inw(int addr); +int port_inl(int addr); + +#endif /* CPU_I386_H */ |