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

📄 cpuemu_01.c

📁 又一个游戏模拟器,著名ARC模拟器源码,包括多个平台
💻 C
📖 第 1 页 / 共 5 页
字号:
{	INT32 src = get_ilong(2);{	unsigned int dsta = m68k_areg(regs, dstreg);{	INT32 dst = cpu_readmem24_dword(dsta);	m68k_areg(regs, dstreg) += 4;	src &= dst;	CLEAR_CZNV;	SET_ZFLG (((INT32)(src)) == 0);	SET_NFLG (((INT32)(src)) < 0);	cpu_writemem24_dword(dsta,src);}}}}m68k_incpc(6);return 14;}unsigned long op_2a0_0(UINT32 opcode) /* AND */{	UINT32 dstreg = opcode & 7;{{	INT32 src = get_ilong(2);{	unsigned int dsta = m68k_areg(regs, dstreg) - 4;{	INT32 dst = cpu_readmem24_dword(dsta);	m68k_areg (regs, dstreg) = dsta;	src &= dst;	CLEAR_CZNV;	SET_ZFLG (((INT32)(src)) == 0);	SET_NFLG (((INT32)(src)) < 0);	cpu_writemem24_dword(dsta,src);}}}}m68k_incpc(6);return 15;}unsigned long op_2a8_0(UINT32 opcode) /* AND */{	UINT32 dstreg = opcode & 7;{{	INT32 src = get_ilong(2);{	unsigned int dsta = m68k_areg(regs, dstreg) + (INT32)(INT16)get_iword(6);{	INT32 dst = cpu_readmem24_dword(dsta);	src &= dst;	CLEAR_CZNV;	SET_ZFLG (((INT32)(src)) == 0);	SET_NFLG (((INT32)(src)) < 0);	cpu_writemem24_dword(dsta,src);}}}}m68k_incpc(8);return 16;}unsigned long op_2b0_0(UINT32 opcode) /* AND */{	UINT32 dstreg = opcode & 7;{{	INT32 src = get_ilong(2);{m68k_incpc(6);{	unsigned int dsta = get_disp_ea_020(m68k_areg(regs, dstreg), next_iword());{	INT32 dst = cpu_readmem24_dword(dsta);	src &= dst;	CLEAR_CZNV;	SET_ZFLG (((INT32)(src)) == 0);	SET_NFLG (((INT32)(src)) < 0);	cpu_writemem24_dword(dsta,src);}}}}}return 17;}unsigned long op_2b8_0(UINT32 opcode) /* AND */{	(void)(opcode);{{	INT32 src = get_ilong(2);{	unsigned int dsta = (INT32)(INT16)get_iword(6);{	INT32 dst = cpu_readmem24_dword(dsta);	src &= dst;	CLEAR_CZNV;	SET_ZFLG (((INT32)(src)) == 0);	SET_NFLG (((INT32)(src)) < 0);	cpu_writemem24_dword(dsta,src);}}}}m68k_incpc(8);return 16;}unsigned long op_2b9_0(UINT32 opcode) /* AND */{	(void)(opcode);{{	INT32 src = get_ilong(2);{	unsigned int dsta = get_ilong(6);{	INT32 dst = cpu_readmem24_dword(dsta);	src &= dst;	CLEAR_CZNV;	SET_ZFLG (((INT32)(src)) == 0);	SET_NFLG (((INT32)(src)) < 0);	cpu_writemem24_dword(dsta,src);}}}}m68k_incpc(10);return 18;}unsigned long op_2d0_0(UINT32 opcode) /* CHK2 */{	UINT32 dstreg = opcode & 7;{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{	unsigned int dsta = m68k_areg(regs, dstreg);	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel105; }}}}}m68k_incpc(4);endlabel105: ;return 4;}unsigned long op_2e8_0(UINT32 opcode) /* CHK2 */{	UINT32 dstreg = opcode & 7;{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{	unsigned int dsta = m68k_areg(regs, dstreg) + (INT32)(INT16)get_iword(4);	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel106; }}}}}m68k_incpc(6);endlabel106: ;return 6;}unsigned long op_2f0_0(UINT32 opcode) /* CHK2 */{	UINT32 dstreg = opcode & 7;{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{m68k_incpc(4);{	unsigned int dsta = get_disp_ea_020(m68k_areg(regs, dstreg), next_iword());	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel107; }}}}}}endlabel107: ;return 7;}unsigned long op_2f8_0(UINT32 opcode) /* CHK2 */{	(void)(opcode);{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{	unsigned int dsta = (INT32)(INT16)get_iword(4);	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel108; }}}}}m68k_incpc(6);endlabel108: ;return 6;}unsigned long op_2f9_0(UINT32 opcode) /* CHK2 */{	(void)(opcode);{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{	unsigned int dsta = get_ilong(4);	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel109; }}}}}m68k_incpc(8);endlabel109: ;return 8;}unsigned long op_2fa_0(UINT32 opcode) /* CHK2 */{	(void)(opcode);{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{	unsigned int dsta = m68k_getpc () + 4;	dsta += (INT32)(INT16)get_iword(4);	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel110; }}}}}m68k_incpc(6);endlabel110: ;return 6;}unsigned long op_2fb_0(UINT32 opcode) /* CHK2 */{	(void)(opcode);{	unsigned int oldpc = m68k_getpc();{	INT16 extra = get_iword(2);{m68k_incpc(4);{	unsigned int tmppc = m68k_getpc();	unsigned int dsta = get_disp_ea_020(tmppc, next_iword());	{INT32 upper,lower,reg = regs.regs[(extra >> 12) & 15];	lower=(INT32)(INT16)cpu_readmem24_word(dsta); upper = (INT32)(INT16)cpu_readmem24_word(dsta+2);	if ((extra & 0x8000) == 0) reg = (INT32)(INT16)reg;	SET_ZFLG (upper == reg || lower == reg);	SET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);	if ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto endlabel111; }}}}}}endlabel111: ;return 7;}unsigned long op_400_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT8 src = get_ibyte(2);{	INT8 dst = m68k_dreg(regs, dstreg);{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	m68k_dreg(regs, dstreg) = (m68k_dreg(regs, dstreg) & ~0xff) | ((newv) & 0xff);}}}}}}m68k_incpc(4);return 4;}unsigned long op_410_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT8 src = get_ibyte(2);{	unsigned int dsta = m68k_areg(regs, dstreg);{	INT8 dst = cpu_readmem24(dsta);{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}m68k_incpc(4);return 8;}unsigned long op_418_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT8 src = get_ibyte(2);{	unsigned int dsta = m68k_areg(regs, dstreg);{	INT8 dst = cpu_readmem24(dsta);	m68k_areg(regs, dstreg) += areg_byteinc[dstreg];{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}m68k_incpc(4);return 8;}unsigned long op_420_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT8 src = get_ibyte(2);{	unsigned int dsta = m68k_areg(regs, dstreg) - areg_byteinc[dstreg];{	INT8 dst = cpu_readmem24(dsta);	m68k_areg (regs, dstreg) = dsta;{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}m68k_incpc(4);return 9;}unsigned long op_428_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT8 src = get_ibyte(2);{	unsigned int dsta = m68k_areg(regs, dstreg) + (INT32)(INT16)get_iword(4);{	INT8 dst = cpu_readmem24(dsta);{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}m68k_incpc(6);return 10;}unsigned long op_430_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT8 src = get_ibyte(2);{m68k_incpc(4);{	unsigned int dsta = get_disp_ea_020(m68k_areg(regs, dstreg), next_iword());{	INT8 dst = cpu_readmem24(dsta);{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}}return 11;}unsigned long op_438_0(UINT32 opcode) /* SUB */{	(void)(opcode);{{	INT8 src = get_ibyte(2);{	unsigned int dsta = (INT32)(INT16)get_iword(4);{	INT8 dst = cpu_readmem24(dsta);{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}m68k_incpc(6);return 10;}unsigned long op_439_0(UINT32 opcode) /* SUB */{	(void)(opcode);{{	INT8 src = get_ibyte(2);{	unsigned int dsta = get_ilong(4);{	INT8 dst = cpu_readmem24(dsta);{{UINT32 newv = ((INT8)(dst)) - ((INT8)(src));{	int flgs = ((INT8)(src)) < 0;	int flgo = ((INT8)(dst)) < 0;	int flgn = ((INT8)(newv)) < 0;	SET_ZFLG (((INT8)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT8)(src)) > ((UINT8)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24(dsta,newv);}}}}}}}m68k_incpc(8);return 12;}unsigned long op_440_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT16 src = get_iword(2);{	INT16 dst = m68k_dreg(regs, dstreg);{{UINT32 newv = ((INT16)(dst)) - ((INT16)(src));{	int flgs = ((INT16)(src)) < 0;	int flgo = ((INT16)(dst)) < 0;	int flgn = ((INT16)(newv)) < 0;	SET_ZFLG (((INT16)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT16)(src)) > ((UINT16)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	m68k_dreg(regs, dstreg) = (m68k_dreg(regs, dstreg) & ~0xffff) | ((newv) & 0xffff);}}}}}}m68k_incpc(4);return 4;}unsigned long op_450_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT16 src = get_iword(2);{	unsigned int dsta = m68k_areg(regs, dstreg);{	INT16 dst = cpu_readmem24_word(dsta);{{UINT32 newv = ((INT16)(dst)) - ((INT16)(src));{	int flgs = ((INT16)(src)) < 0;	int flgo = ((INT16)(dst)) < 0;	int flgn = ((INT16)(newv)) < 0;	SET_ZFLG (((INT16)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT16)(src)) > ((UINT16)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24_word(dsta,newv);}}}}}}}m68k_incpc(4);return 8;}unsigned long op_458_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT16 src = get_iword(2);{	unsigned int dsta = m68k_areg(regs, dstreg);{	INT16 dst = cpu_readmem24_word(dsta);	m68k_areg(regs, dstreg) += 2;{{UINT32 newv = ((INT16)(dst)) - ((INT16)(src));{	int flgs = ((INT16)(src)) < 0;	int flgo = ((INT16)(dst)) < 0;	int flgn = ((INT16)(newv)) < 0;	SET_ZFLG (((INT16)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT16)(src)) > ((UINT16)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24_word(dsta,newv);}}}}}}}m68k_incpc(4);return 8;}unsigned long op_460_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT16 src = get_iword(2);{	unsigned int dsta = m68k_areg(regs, dstreg) - 2;{	INT16 dst = cpu_readmem24_word(dsta);	m68k_areg (regs, dstreg) = dsta;{{UINT32 newv = ((INT16)(dst)) - ((INT16)(src));{	int flgs = ((INT16)(src)) < 0;	int flgo = ((INT16)(dst)) < 0;	int flgn = ((INT16)(newv)) < 0;	SET_ZFLG (((INT16)(newv)) == 0);	SET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));	SET_CFLG (((UINT16)(src)) > ((UINT16)(dst)));	COPY_CARRY;	SET_NFLG (flgn != 0);	cpu_writemem24_word(dsta,newv);}}}}}}}m68k_incpc(4);return 9;}unsigned long op_468_0(UINT32 opcode) /* SUB */{	UINT32 dstreg = opcode & 7;{{	INT16 src = get_iword(2);{	unsigned int dsta = m68k_areg(regs, dstreg) + (INT32)(INT16)get_iword(4);

⌨️ 快捷键说明

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