#define TCG_HELPER_PROTO void helper_lock(void); void helper_unlock(void); void helper_write_eflags(target_ulong t0, uint32_t update_mask); target_ulong helper_read_eflags(void); void helper_divb_AL(target_ulong t0); void helper_idivb_AL(target_ulong t0); void helper_divw_AX(target_ulong t0); void helper_idivw_AX(target_ulong t0); void helper_divl_EAX(target_ulong t0); void helper_idivl_EAX(target_ulong t0); #ifdef TARGET_X86_64 void helper_mulq_EAX_T0(target_ulong t0); void helper_imulq_EAX_T0(target_ulong t0); target_ulong helper_imulq_T0_T1(target_ulong t0, target_ulong t1); void helper_divq_EAX(target_ulong t0); void helper_idivq_EAX(target_ulong t0); #endif void helper_aam(int base); void helper_aad(int base); void helper_aaa(void); void helper_aas(void); void helper_daa(void); void helper_das(void); target_ulong helper_lsl(target_ulong selector1); target_ulong helper_lar(target_ulong selector1); void helper_verr(target_ulong selector1); void helper_verw(target_ulong selector1); void helper_lldt(int selector); void helper_ltr(int selector); void helper_load_seg(int seg_reg, int selector); void helper_ljmp_protected(int new_cs, target_ulong new_eip, int next_eip_addend); void helper_lcall_real(int new_cs, target_ulong new_eip1, int shift, int next_eip); void helper_lcall_protected(int new_cs, target_ulong new_eip, int shift, int next_eip_addend); void helper_iret_real(int shift); void helper_iret_protected(int shift, int next_eip); void helper_lret_protected(int shift, int addend); void helper_movl_crN_T0(int reg, target_ulong t0); void helper_lmsw(target_ulong t0); void helper_clts(void); #if !defined(CONFIG_USER_ONLY) target_ulong helper_movtl_T0_cr8(void); #endif void helper_movl_drN_T0(int reg, target_ulong t0); void helper_invlpg(target_ulong addr); void helper_enter_level(int level, int data32, target_ulong t1); #ifdef TARGET_X86_64 void helper_enter64_level(int level, int data64, target_ulong t1); #endif void helper_sysenter(void); void helper_sysexit(void); #ifdef TARGET_X86_64 void helper_syscall(int next_eip_addend); void helper_sysret(int dflag); #endif void helper_hlt(void); void helper_monitor(target_ulong ptr); void helper_mwait(void); void helper_debug(void); void helper_raise_interrupt(int intno, int next_eip_addend); void helper_raise_exception(int exception_index); void helper_cli(void); void helper_sti(void); void helper_set_inhibit_irq(void); void helper_reset_inhibit_irq(void); void helper_boundw(target_ulong a0, int v); void helper_boundl(target_ulong a0, int v); void helper_rsm(void); void helper_into(int next_eip_addend); void helper_cmpxchg8b(target_ulong a0); #ifdef TARGET_X86_64 void helper_cmpxchg16b(target_ulong a0); #endif void helper_single_step(void); void helper_cpuid(void); void helper_rdtsc(void); void helper_rdpmc(void); void helper_rdmsr(void); void helper_wrmsr(void); void helper_check_iob(uint32_t t0); void helper_check_iow(uint32_t t0); void helper_check_iol(uint32_t t0); void helper_outb(uint32_t port, uint32_t data); target_ulong helper_inb(uint32_t port); void helper_outw(uint32_t port, uint32_t data); target_ulong helper_inw(uint32_t port); void helper_outl(uint32_t port, uint32_t data); target_ulong helper_inl(uint32_t port); void helper_svm_check_intercept_param(uint32_t type, uint64_t param); void helper_vmexit(uint32_t exit_code, uint64_t exit_info_1); void helper_svm_check_io(uint32_t port, uint32_t param, uint32_t next_eip_addend); void helper_vmrun(void); void helper_vmmcall(void); void helper_vmload(void); void helper_vmsave(void); void helper_stgi(void); void helper_clgi(void); void helper_skinit(void); void helper_invlpga(void); /* x86 FPU */ void helper_flds_FT0(uint32_t val); void helper_fldl_FT0(uint64_t val); void helper_fildl_FT0(int32_t val); void helper_flds_ST0(uint32_t val); void helper_fldl_ST0(uint64_t val); void helper_fildl_ST0(int32_t val); void helper_fildll_ST0(int64_t val); uint32_t helper_fsts_ST0(void); uint64_t helper_fstl_ST0(void); int32_t helper_fist_ST0(void); int32_t helper_fistl_ST0(void); int64_t helper_fistll_ST0(void); int32_t helper_fistt_ST0(void); int32_t helper_fisttl_ST0(void); int64_t helper_fisttll_ST0(void); void helper_fldt_ST0(target_ulong ptr); void helper_fstt_ST0(target_ulong ptr); void helper_fpush(void); void helper_fpop(void); void helper_fdecstp(void); void helper_fincstp(void); void helper_ffree_STN(int st_index); void helper_fmov_ST0_FT0(void); void helper_fmov_FT0_STN(int st_index); void helper_fmov_ST0_STN(int st_index); void helper_fmov_STN_ST0(int st_index); void helper_fxchg_ST0_STN(int st_index); void helper_fcom_ST0_FT0(void); void helper_fucom_ST0_FT0(void); void helper_fcomi_ST0_FT0(void); void helper_fucomi_ST0_FT0(void); void helper_fadd_ST0_FT0(void); void helper_fmul_ST0_FT0(void); void helper_fsub_ST0_FT0(void); void helper_fsubr_ST0_FT0(void); void helper_fdiv_ST0_FT0(void); void helper_fdivr_ST0_FT0(void); void helper_fadd_STN_ST0(int st_index); void helper_fmul_STN_ST0(int st_index); void helper_fsub_STN_ST0(int st_index); void helper_fsubr_STN_ST0(int st_index); void helper_fdiv_STN_ST0(int st_index); void helper_fdivr_STN_ST0(int st_index); void helper_fchs_ST0(void); void helper_fabs_ST0(void); void helper_fxam_ST0(void); void helper_fld1_ST0(void); void helper_fldl2t_ST0(void); void helper_fldl2e_ST0(void); void helper_fldpi_ST0(void); void helper_fldlg2_ST0(void); void helper_fldln2_ST0(void); void helper_fldz_ST0(void); void helper_fldz_FT0(void); uint32_t helper_fnstsw(void); uint32_t helper_fnstcw(void); void helper_fldcw(uint32_t val); void helper_fclex(void); void helper_fwait(void); void helper_fninit(void); void helper_fbld_ST0(target_ulong ptr); void helper_fbst_ST0(target_ulong ptr); void helper_f2xm1(void); void helper_fyl2x(void); void helper_fptan(void); void helper_fpatan(void); void helper_fxtract(void); void helper_fprem1(void); void helper_fprem(void); void helper_fyl2xp1(void); void helper_fsqrt(void); void helper_fsincos(void); void helper_frndint(void); void helper_fscale(void); void helper_fsin(void); void helper_fcos(void); void helper_fxam_ST0(void); void helper_fstenv(target_ulong ptr, int data32); void helper_fldenv(target_ulong ptr, int data32); void helper_fsave(target_ulong ptr, int data32); void helper_frstor(target_ulong ptr, int data32); void helper_fxsave(target_ulong ptr, int data64); void helper_fxrstor(target_ulong ptr, int data64); target_ulong helper_bsf(target_ulong t0); target_ulong helper_bsr(target_ulong t0); /* MMX/SSE */ void TCG_HELPER_PROTO helper_enter_mmx(void); void TCG_HELPER_PROTO helper_emms(void); void TCG_HELPER_PROTO helper_movq(uint64_t *d, uint64_t *s); #define SHIFT 0 #include "ops_sse_header.h" #define SHIFT 1 #include "ops_sse_header.h" target_ulong helper_rclb(target_ulong t0, target_ulong t1); target_ulong helper_rclw(target_ulong t0, target_ulong t1); target_ulong helper_rcll(target_ulong t0, target_ulong t1); target_ulong helper_rcrb(target_ulong t0, target_ulong t1); target_ulong helper_rcrw(target_ulong t0, target_ulong t1); target_ulong helper_rcrl(target_ulong t0, target_ulong t1); #ifdef TARGET_X86_64 target_ulong helper_rclq(target_ulong t0, target_ulong t1); target_ulong helper_rcrq(target_ulong t0, target_ulong t1); #endif