📄 cpuemu_01.c
字号:
{ 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 + -