⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ops2.c

📁 针对linux休眠suspend显卡状态保存恢复的一个办法
💻 C
📖 第 1 页 / 共 5 页
字号:
    case 2:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm10_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_SS = fetch_data_word(srcoffset + 2);        break;    case 3:                     /* register to register */        /* UNDEFINED! */        TRACE_AND_STEP();    }    DECODE_CLEAR_SEGOVR();    END_OF_INSTR();}/****************************************************************************REMARKS:Handles opcode 0x0f,0xb3****************************************************************************/static void x86emuOp2_btr_R(u8 X86EMU_UNUSED(op2)){	int mod, rl, rh;	uint srcoffset;	int bit,disp;	START_OF_INSTR();	DECODE_PRINTF("BTR\t");	FETCH_DECODE_MODRM(mod, rh, rl);	switch (mod) {	case 0:		if (M.x86.mode & SYSMODE_PREFIX_DATA) {			u32 srcval,mask;			u32 *shiftreg;			srcoffset = decode_rm00_address(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_LONG_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0x1F;			disp = (s16)*shiftreg >> 5;			srcval = fetch_data_long(srcoffset+disp);			mask = (0x1 << bit);			CONDITIONAL_SET_FLAG(srcval & mask,F_CF);			store_data_long(srcoffset+disp, srcval & ~mask);		} else {			u16 srcval,mask;			u16 *shiftreg;			srcoffset = decode_rm00_address(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_WORD_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0xF;			disp = (s16)*shiftreg >> 4;			srcval = fetch_data_word(srcoffset+disp);			mask = (u16)(0x1 << bit);			CONDITIONAL_SET_FLAG(srcval & mask,F_CF);			store_data_word(srcoffset+disp, (u16)(srcval & ~mask));		}		break;	case 1:		if (M.x86.mode & SYSMODE_PREFIX_DATA) {			u32 srcval,mask;			u32 *shiftreg;			srcoffset = decode_rm01_address(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_LONG_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0x1F;			disp = (s16)*shiftreg >> 5;			srcval = fetch_data_long(srcoffset+disp);			mask = (0x1 << bit);			CONDITIONAL_SET_FLAG(srcval & mask,F_CF);			store_data_long(srcoffset+disp, srcval & ~mask);		} else {			u16 srcval,mask;			u16 *shiftreg;			srcoffset = decode_rm01_address(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_WORD_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0xF;			disp = (s16)*shiftreg >> 4;			srcval = fetch_data_word(srcoffset+disp);			mask = (u16)(0x1 << bit);			CONDITIONAL_SET_FLAG(srcval & mask,F_CF);			store_data_word(srcoffset+disp, (u16)(srcval & ~mask));		}		break;	case 2:		if (M.x86.mode & SYSMODE_PREFIX_DATA) {			u32 srcval,mask;			u32 *shiftreg;			srcoffset = decode_rm10_address(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_LONG_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0x1F;			disp = (s16)*shiftreg >> 5;			srcval = fetch_data_long(srcoffset+disp);			mask = (0x1 << bit);			CONDITIONAL_SET_FLAG(srcval & mask,F_CF);			store_data_long(srcoffset+disp, srcval & ~mask);		} else {			u16 srcval,mask;			u16 *shiftreg;			srcoffset = decode_rm10_address(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_WORD_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0xF;			disp = (s16)*shiftreg >> 4;			srcval = fetch_data_word(srcoffset+disp);			mask = (u16)(0x1 << bit);			CONDITIONAL_SET_FLAG(srcval & mask,F_CF);			store_data_word(srcoffset+disp, (u16)(srcval & ~mask));		}		break;	case 3:                     /* register to register */		if (M.x86.mode & SYSMODE_PREFIX_DATA) {			u32 *srcreg,*shiftreg;			u32 mask;			srcreg = DECODE_RM_LONG_REGISTER(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_LONG_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0x1F;			mask = (0x1 << bit);			CONDITIONAL_SET_FLAG(*srcreg & mask,F_CF);			*srcreg &= ~mask;		} else {			u16 *srcreg,*shiftreg;			u16 mask;			srcreg = DECODE_RM_WORD_REGISTER(rl);			DECODE_PRINTF(",");			shiftreg = DECODE_RM_WORD_REGISTER(rh);			TRACE_AND_STEP();			bit = *shiftreg & 0xF;			mask = (u16)(0x1 << bit);			CONDITIONAL_SET_FLAG(*srcreg & mask,F_CF);			*srcreg &= ~mask;		}		break;	}	DECODE_CLEAR_SEGOVR();	END_OF_INSTR();}/****************************************************************************REMARKS:Handles opcode 0x0f,0xb4****************************************************************************/static void x86emuOp2_lfs_R_IMM(u8 X86EMU_UNUSED(op2)){	int mod, rh, rl;    u16 *dstreg;    uint srcoffset;    START_OF_INSTR();    DECODE_PRINTF("LFS\t");    FETCH_DECODE_MODRM(mod, rh, rl);    switch (mod) {    case 0:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm00_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_FS = fetch_data_word(srcoffset + 2);        break;    case 1:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm01_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_FS = fetch_data_word(srcoffset + 2);        break;    case 2:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm10_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_FS = fetch_data_word(srcoffset + 2);        break;    case 3:                     /* register to register */        /* UNDEFINED! */        TRACE_AND_STEP();    }    DECODE_CLEAR_SEGOVR();    END_OF_INSTR();}/****************************************************************************REMARKS:Handles opcode 0x0f,0xb5****************************************************************************/static void x86emuOp2_lgs_R_IMM(u8 X86EMU_UNUSED(op2)){	int mod, rh, rl;    u16 *dstreg;    uint srcoffset;    START_OF_INSTR();    DECODE_PRINTF("LGS\t");    FETCH_DECODE_MODRM(mod, rh, rl);    switch (mod) {    case 0:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm00_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_GS = fetch_data_word(srcoffset + 2);        break;    case 1:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm01_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_GS = fetch_data_word(srcoffset + 2);        break;    case 2:        dstreg = DECODE_RM_WORD_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm10_address(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *dstreg = fetch_data_word(srcoffset);        M.x86.R_GS = fetch_data_word(srcoffset + 2);        break;    case 3:                     /* register to register */        /* UNDEFINED! */        TRACE_AND_STEP();    }    DECODE_CLEAR_SEGOVR();    END_OF_INSTR();}/****************************************************************************REMARKS:Handles opcode 0x0f,0xb6****************************************************************************/static void x86emuOp2_movzx_byte_R_RM(u8 X86EMU_UNUSED(op2)){    int mod, rl, rh;    uint srcoffset;    START_OF_INSTR();    DECODE_PRINTF("MOVZX\t");    FETCH_DECODE_MODRM(mod, rh, rl);    switch (mod) {    case 0:        if (M.x86.mode & SYSMODE_PREFIX_DATA) {            u32 *destreg;            u32 srcval;            destreg = DECODE_RM_LONG_REGISTER(rh);            DECODE_PRINTF(",");            srcoffset = decode_rm00_address(rl);            srcval = fetch_data_byte(srcoffset);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = srcval;        } else {            u16 *destreg;            u16 srcval;            destreg = DECODE_RM_WORD_REGISTER(rh);            DECODE_PRINTF(",");            srcoffset = decode_rm00_address(rl);            srcval = fetch_data_byte(srcoffset);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = srcval;        }        break;    case 1:        if (M.x86.mode & SYSMODE_PREFIX_DATA) {            u32 *destreg;            u32 srcval;            destreg = DECODE_RM_LONG_REGISTER(rh);            DECODE_PRINTF(",");            srcoffset = decode_rm01_address(rl);            srcval = fetch_data_byte(srcoffset);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = srcval;        } else {            u16 *destreg;            u16 srcval;            destreg = DECODE_RM_WORD_REGISTER(rh);            DECODE_PRINTF(",");            srcoffset = decode_rm01_address(rl);            srcval = fetch_data_byte(srcoffset);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = srcval;        }        break;    case 2:        if (M.x86.mode & SYSMODE_PREFIX_DATA) {            u32 *destreg;            u32 srcval;            destreg = DECODE_RM_LONG_REGISTER(rh);            DECODE_PRINTF(",");            srcoffset = decode_rm10_address(rl);            srcval = fetch_data_byte(srcoffset);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = srcval;        } else {            u16 *destreg;            u16 srcval;            destreg = DECODE_RM_WORD_REGISTER(rh);            DECODE_PRINTF(",");            srcoffset = decode_rm10_address(rl);            srcval = fetch_data_byte(srcoffset);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = srcval;        }        break;    case 3:                     /* register to register */        if (M.x86.mode & SYSMODE_PREFIX_DATA) {            u32 *destreg;            u8  *srcreg;            destreg = DECODE_RM_LONG_REGISTER(rh);            DECODE_PRINTF(",");            srcreg = DECODE_RM_BYTE_REGISTER(rl);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = *srcreg;        } else {            u16 *destreg;            u8  *srcreg;            destreg = DECODE_RM_WORD_REGISTER(rh);            DECODE_PRINTF(",");            srcreg = DECODE_RM_BYTE_REGISTER(rl);            DECODE_PRINTF("\n");            TRACE_AND_STEP();            *destreg = *srcreg;        }        break;    }    DECODE_CLEAR_SEGOVR();    END_OF_INSTR();}/****************************************************************************REMARKS:Handles opcode 0x0f,0xb7****************************************************************************/static void x86emuOp2_movzx_word_R_RM(u8 X86EMU_UNUSED(op2)){    int mod, rl, rh;    uint srcoffset;    u32 *destreg;    u32 srcval;    u16 *srcreg;    START_OF_INSTR();    DECODE_PRINTF("MOVZX\t");    FETCH_DECODE_MODRM(mod, rh, rl);    switch (mod) {    case 0:        destreg = DECODE_RM_LONG_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm00_address(rl);        srcval = fetch_data_word(srcoffset);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *destreg = srcval;        break;    case 1:        destreg = DECODE_RM_LONG_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm01_address(rl);        srcval = fetch_data_word(srcoffset);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *destreg = srcval;        break;    case 2:        destreg = DECODE_RM_LONG_REGISTER(rh);        DECODE_PRINTF(",");        srcoffset = decode_rm10_address(rl);        srcval = fetch_data_word(srcoffset);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *destreg = srcval;        break;    case 3:                     /* register to register */        destreg = DECODE_RM_LONG_REGISTER(rh);        DECODE_PRINTF(",");        srcreg = DECODE_RM_WORD_REGISTER(rl);        DECODE_PRINTF("\n");        TRACE_AND_STEP();        *destreg = *srcreg;        break;    }    DECODE_CLEAR_SEGOVR();    END_OF_INSTR();}/****************************************************************************REMARKS:Handles opcode 0x0f,0xba****************************************************************************/static void x86emuOp2_btX_I(u8 X86EMU_UNUSED(op2)){    int mod, rl, rh;    uint srcoffset;    int bit;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -