Changes to device_t struct to accomodate the upcoming PCI IRQ arbitration rewrite; Added device.c/h API to obtain name from the device_t struct; Significant changes to win/win_settings.c to clean up the code a bit and fix bugs; Ported all the CPU and AudioPCI commits from PCem; Added an API call to allow ACPI soft power off to gracefully stop the emulator; Removed the Siemens PCD-2L from the Dev branch because it now works; Removed the Socket 5 HP Vectra from the Dev branch because it now works; Fixed the Compaq Presario and the Micronics Spitfire; Give the IBM PC330 its own list of 486 CPU so it can have DX2's with CPUID 0x470; SMM fixes; Rewrote the SYSENTER, SYSEXIT, SYSCALL, and SYSRET instructions; Changed IDE reset period to match the specification, fixes #929; The keyboard input and output ports are now forced in front of the queue when read, fixes a number of bugs, including the AMI Apollo hanging on soft reset; Added the Intel AN430TX but Dev branched because it does not work; The network code no longer drops packets if the emulated network card has failed to receive them (eg. when the buffer is full); Changes to PCI card adding and renamed some PCI slot types, also added proper AGP bridge slot types; USB UHCI emulation is no longer a stub (still doesn't fully work, but at least Windows XP chk with Debug no longer ASSERT's on it); Fixed NVR on the the SMC FDC37C932QF and APM variants; A number of fixes to Intel 4x0 chipsets, including fixing every register of the 440LX and 440EX; Some ACPI changes.
196 lines
9.9 KiB
C
196 lines
9.9 KiB
C
void host_x86_ADD32_REG_ABS(codeblock_t *block, int dst_reg, void *p);
|
|
|
|
void host_x86_ADD8_REG_IMM(codeblock_t *block, int dst_reg, uint8_t imm_data);
|
|
void host_x86_ADD16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_ADD32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|
|
|
|
void host_x86_ADD8_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_ADD16_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_ADD32_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_AND8_REG_IMM(codeblock_t *block, int dst_reg, uint8_t imm_data);
|
|
void host_x86_AND16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_AND32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|
|
|
|
void host_x86_AND8_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_AND16_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_AND32_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_CALL(codeblock_t *block, void *p);
|
|
|
|
void host_x86_CMP16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_CMP32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|
|
|
|
void host_x86_CMP8_REG_REG(codeblock_t *block, int src_reg_a, int src_reg_b);
|
|
void host_x86_CMP16_REG_REG(codeblock_t *block, int src_reg_a, int src_reg_b);
|
|
void host_x86_CMP32_REG_REG(codeblock_t *block, int src_reg_a, int src_reg_b);
|
|
|
|
void host_x86_INC32_ABS(codeblock_t *block, void *p);
|
|
|
|
void host_x86_JMP(codeblock_t *block, void *p);
|
|
uint32_t *host_x86_JMP_short(codeblock_t *block);
|
|
uint32_t *host_x86_JMP_long(codeblock_t *block);
|
|
|
|
void host_x86_JNZ(codeblock_t *block, void *p);
|
|
void host_x86_JZ(codeblock_t *block, void *p);
|
|
|
|
uint8_t *host_x86_JNZ_short(codeblock_t *block);
|
|
uint8_t *host_x86_JS_short(codeblock_t *block);
|
|
uint8_t *host_x86_JZ_short(codeblock_t *block);
|
|
|
|
uint32_t *host_x86_JNB_long(codeblock_t *block);
|
|
uint32_t *host_x86_JNBE_long(codeblock_t *block);
|
|
uint32_t *host_x86_JNL_long(codeblock_t *block);
|
|
uint32_t *host_x86_JNLE_long(codeblock_t *block);
|
|
uint32_t *host_x86_JNO_long(codeblock_t *block);
|
|
uint32_t *host_x86_JNS_long(codeblock_t *block);
|
|
uint32_t *host_x86_JNZ_long(codeblock_t *block);
|
|
uint32_t *host_x86_JB_long(codeblock_t *block);
|
|
uint32_t *host_x86_JBE_long(codeblock_t *block);
|
|
uint32_t *host_x86_JL_long(codeblock_t *block);
|
|
uint32_t *host_x86_JLE_long(codeblock_t *block);
|
|
uint32_t *host_x86_JO_long(codeblock_t *block);
|
|
uint32_t *host_x86_JS_long(codeblock_t *block);
|
|
uint32_t *host_x86_JZ_long(codeblock_t *block);
|
|
|
|
void host_x86_LAHF(codeblock_t *block);
|
|
|
|
void host_x86_LEA_REG_IMM(codeblock_t *block, int dst_reg, int src_reg_a, uint32_t offset);
|
|
void host_x86_LEA_REG_REG(codeblock_t *block, int dst_reg, int src_reg_a, int src_reg_b);
|
|
void host_x86_LEA_REG_REG_SHIFT(codeblock_t *block, int dst_reg, int src_reg_a, int src_reg_b, int shift);
|
|
|
|
void host_x86_MOV8_ABS_IMM(codeblock_t *block, void *p, uint32_t imm_data);
|
|
void host_x86_MOV16_ABS_IMM(codeblock_t *block, void *p, uint16_t imm_data);
|
|
void host_x86_MOV32_ABS_IMM(codeblock_t *block, void *p, uint32_t imm_data);
|
|
|
|
void host_x86_MOV8_ABS_REG(codeblock_t *block, void *p, int src_reg);
|
|
void host_x86_MOV16_ABS_REG(codeblock_t *block, void *p, int src_reg);
|
|
void host_x86_MOV32_ABS_REG(codeblock_t *block, void *p, int src_reg);
|
|
|
|
void host_x86_MOV8_ABS_REG_REG_SHIFT_REG(codeblock_t *block, uint32_t addr, int base_reg, int idx_reg, int shift, int src_reg);
|
|
|
|
void host_x86_MOV8_BASE_INDEX_REG(codeblock_t *block, int base_reg, int idx_reg, int src_reg);
|
|
void host_x86_MOV16_BASE_INDEX_REG(codeblock_t *block, int base_reg, int idx_reg, int src_reg);
|
|
void host_x86_MOV32_BASE_INDEX_REG(codeblock_t *block, int base_reg, int idx_reg, int src_reg);
|
|
|
|
void host_x86_MOV16_BASE_OFFSET_REG(codeblock_t *block, int base_reg, int offset, int dst_reg);
|
|
void host_x86_MOV32_BASE_OFFSET_REG(codeblock_t *block, int base_reg, int offset, int dst_reg);
|
|
|
|
void host_x86_MOV32_BASE_OFFSET_IMM(codeblock_t *block, int base_reg, int offset, uint32_t imm_data);
|
|
|
|
void host_x86_MOV8_REG_ABS(codeblock_t *block, int dst_reg, void *p);
|
|
void host_x86_MOV16_REG_ABS(codeblock_t *block, int dst_reg, void *p);
|
|
void host_x86_MOV32_REG_ABS(codeblock_t *block, int dst_reg, void *p);
|
|
|
|
void host_x86_MOV32_REG_ABS_INDEX_SHIFT(codeblock_t *block, int dst_reg, void *p, int idx_reg, int shift);
|
|
|
|
void host_x86_MOV8_REG_ABS_REG_REG_SHIFT(codeblock_t *block, int dst_addr, uint32_t addr, int base_reg, int idx_reg, int shift);
|
|
|
|
void host_x86_MOV32_REG_BASE_INDEX(codeblock_t *block, int dst_reg, int base_reg, int idx_reg);
|
|
|
|
void host_x86_MOV16_REG_BASE_OFFSET(codeblock_t *block, int dst_reg, int base_reg, int offset);
|
|
void host_x86_MOV32_REG_BASE_OFFSET(codeblock_t *block, int dst_reg, int base_reg, int offset);
|
|
|
|
void host_x86_MOV8_REG_IMM(codeblock_t *block, int dst_reg, uint8_t imm_data);
|
|
void host_x86_MOV16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_MOV32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|
|
|
|
void host_x86_MOV8_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_MOV16_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_MOV32_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
#define host_x86_MOV16_STACK_REG(block, offset, src_reg) host_x86_MOV16_BASE_OFFSET_REG(block, REG_ESP, offset, src_reg)
|
|
|
|
void host_x86_MOV32_STACK_IMM(codeblock_t *block, int32_t offset, uint32_t imm_data);
|
|
|
|
void host_x86_MOVSX_REG_16_8(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_MOVSX_REG_32_8(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_MOVSX_REG_32_16(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_MOVZX_REG_16_8(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_MOVZX_REG_32_8(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_MOVZX_REG_32_16(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_MOVZX_REG_ABS_16_8(codeblock_t *block, int dst_reg, void *p);
|
|
void host_x86_MOVZX_REG_ABS_32_8(codeblock_t *block, int dst_reg, void *p);
|
|
void host_x86_MOVZX_REG_ABS_32_16(codeblock_t *block, int dst_reg, void *p);
|
|
|
|
void host_x86_MOVZX_BASE_INDEX_32_8(codeblock_t *block, int dst_reg, int base_reg, int idx_reg);
|
|
void host_x86_MOVZX_BASE_INDEX_32_16(codeblock_t *block, int dst_reg, int base_reg, int idx_reg);
|
|
|
|
void host_x86_OR8_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_OR16_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_OR32_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_OR8_REG_IMM(codeblock_t *block, int dst_reg, uint8_t imm_data);
|
|
void host_x86_OR16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_OR32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|
|
|
|
void host_x86_POP(codeblock_t *block, int src_reg);
|
|
|
|
void host_x86_PUSH(codeblock_t *block, int src_reg);
|
|
|
|
void host_x86_RET(codeblock_t *block);
|
|
|
|
void host_x86_ROL8_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_ROL16_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_ROL32_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
|
|
void host_x86_ROL8_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_ROL16_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_ROL32_CL(codeblock_t *block, int dst_reg);
|
|
|
|
void host_x86_ROR8_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_ROR16_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_ROR32_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
|
|
void host_x86_ROR8_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_ROR16_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_ROR32_CL(codeblock_t *block, int dst_reg);
|
|
|
|
void host_x86_SAR8_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_SAR16_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_SAR32_CL(codeblock_t *block, int dst_reg);
|
|
|
|
void host_x86_SAR8_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_SAR16_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_SAR32_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
|
|
void host_x86_SHL8_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_SHL16_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_SHL32_CL(codeblock_t *block, int dst_reg);
|
|
|
|
void host_x86_SHL8_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_SHL16_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_SHL32_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
|
|
void host_x86_SHR8_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_SHR16_CL(codeblock_t *block, int dst_reg);
|
|
void host_x86_SHR32_CL(codeblock_t *block, int dst_reg);
|
|
|
|
void host_x86_SHR8_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_SHR16_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
void host_x86_SHR32_IMM(codeblock_t *block, int dst_reg, int shift);
|
|
|
|
void host_x86_SUB8_REG_IMM(codeblock_t *block, int dst_reg, uint8_t imm_data);
|
|
void host_x86_SUB16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_SUB32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|
|
|
|
void host_x86_SUB8_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_SUB16_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_SUB32_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_TEST8_REG(codeblock_t *block, int src_host_reg, int dst_host_reg);
|
|
void host_x86_TEST16_REG(codeblock_t *block, int src_host_reg, int dst_host_reg);
|
|
void host_x86_TEST32_REG(codeblock_t *block, int src_host_reg, int dst_host_reg);
|
|
|
|
void host_x86_TEST32_REG_IMM(codeblock_t *block, int src_host_reg, uint32_t imm_data);
|
|
|
|
void host_x86_XOR8_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_XOR16_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
void host_x86_XOR32_REG_REG(codeblock_t *block, int dst_reg, int src_reg);
|
|
|
|
void host_x86_XOR8_REG_IMM(codeblock_t *block, int dst_reg, uint8_t imm_data);
|
|
void host_x86_XOR16_REG_IMM(codeblock_t *block, int dst_reg, uint16_t imm_data);
|
|
void host_x86_XOR32_REG_IMM(codeblock_t *block, int dst_reg, uint32_t imm_data);
|