📄 opcode8.c
字号:
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_80b0(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = get_disp_ea(regs.a[srcreg]);
{ LONG src = get_long(srca);
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_80b8(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = (LONG)(WORD)nextiword();
LONG src = get_long(srca);
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_80b9(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = nextilong();
LONG src = get_long(srca);
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_80ba(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = m68k_getpc();
srca += (LONG)(WORD)nextiword();
{ LONG src = get_long(srca);
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_80bb(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = get_disp_ea(m68k_getpc());
{ LONG src = get_long(srca);
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_80bc(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ LONG src = nextilong();
{ LONG dst = regs.d[dstreg].D;
src |= dst;
regs.d[dstreg].D = (src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_80c0(void) /* DIVU */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ WORD src = regs.d[srcreg].W.l;
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 38;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 133;
}
}}}}
void op_80d0(void) /* DIVU */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = regs.a[srcreg];
WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 42;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 137;
}
}}}}
void op_80d8(void) /* DIVU */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = regs.a[srcreg];
WORD src = get_word(srca);
{ regs.a[srcreg] += 2;
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 42;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 137;
}
}}}}}
void op_80e0(void) /* DIVU */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ regs.a[srcreg] -= 2;
{ CPTR srca = regs.a[srcreg];
WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 44;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 139;
}
}}}}}
void op_80e8(void) /* DIVU */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = regs.a[srcreg] + (LONG)(WORD)nextiword();
WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 46;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 141;
}
}}}}
void op_80f0(void) /* DIVU */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = get_disp_ea(regs.a[srcreg]);
{ WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 48;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 143;
}
}}}}}
void op_80f8(void) /* DIVU */
{
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = (LONG)(WORD)nextiword();
WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 46;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 141;
}
}}}}
void op_80f9(void) /* DIVU */
{
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = nextilong();
WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 50;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 145;
}
}}}}
void op_80fa(void) /* DIVU */
{
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = m68k_getpc();
srca += (LONG)(WORD)nextiword();
{ WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 46;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 141;
}
}}}}}
void op_80fb(void) /* DIVU */
{
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ CPTR srca = get_disp_ea(m68k_getpc());
{ WORD src = get_word(srca);
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 48;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 143;
}
}}}}}
void op_80fc(void) /* DIVU */
{
ULONG dstreg = (opcode >> 9) & 7;
{ CPTR oldpc = m68k_getpc();
{ WORD src = nextiword();
{ LONG dst = regs.d[dstreg].D;
if(src == 0){ MC68000_ICount -= 42;
Exception(5,oldpc-2);} else {
ULONG newv = (ULONG)dst / (ULONG)(UWORD)src;
ULONG rem = (ULONG)dst % (ULONG)(UWORD)src;
if (newv > 0xffff) { VFLG = NFLG = 1; CFLG = 0; } else
{
CLEARVC;
ZFLG = ((WORD)(newv)) == 0;
NFLG = ((WORD)(newv)) < 0;
newv = (newv & 0xffff) | ((ULONG)rem << 16);
regs.d[dstreg].D = (newv);
}
MC68000_ICount -= 137;
}
}}}}
void op_8100(void) /* SBCD */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ BYTE src = regs.d[srcreg].B.l;
{ BYTE dst = regs.d[dstreg].B.l;
{ UWORD newv_lo = (dst & 0xF) - (src & 0xF) - (regs.x ? 1 : 0);
UWORD newv_hi = (dst & 0xF0) - (src & 0xF0);
UWORD newv;
if (newv_lo > 9) { newv_lo-=6; newv_hi-=0x10; }
newv = newv_hi + (newv_lo & 0xF); CFLG = regs.x = (newv_hi & 0x1F0) > 0x90;
if (CFLG) newv -= 0x60;
if (((BYTE)(newv)) != 0) ZFLG = 0;
NFLG = ((BYTE)(newv)) < 0;
{ int flgs = ((BYTE)(src)) < 0;
int flgo = ((BYTE)(dst)) < 0;
int flgn = ((BYTE)(newv)) < 0;
VFLG = (flgs != flgo) && (flgn != flgo);
regs.d[dstreg].B.l = newv;
}}}}}}
void op_8108(void) /* SBCD */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ regs.a[srcreg] -= areg_byteinc[srcreg];
{ CPTR srca = regs.a[srcreg];
BYTE src = get_byte(srca);
{ regs.a[dstreg] -= areg_byteinc[dstreg];
{ CPTR dsta = regs.a[dstreg];
BYTE dst = get_byte(dsta);
{ UWORD newv_lo = (dst & 0xF) - (src & 0xF) - (regs.x ? 1 : 0);
UWORD newv_hi = (dst & 0xF0) - (src & 0xF0);
UWORD newv;
if (newv_lo > 9) { newv_lo-=6; newv_hi-=0x10; }
newv = newv_hi + (newv_lo & 0xF); CFLG = regs.x = (newv_hi & 0x1F0) > 0x90;
if (CFLG) newv -= 0x60;
if (((BYTE)(newv)) != 0) ZFLG = 0;
NFLG = ((BYTE)(newv)) < 0;
{ int flgs = ((BYTE)(src)) < 0;
int flgo = ((BYTE)(dst)) < 0;
int flgn = ((BYTE)(newv)) < 0;
VFLG = (flgs != flgo) && (flgn != flgo);
put_byte(dsta,newv);
}}}}}}}}
void op_8110(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
ULONG dstreg = opcode & 7;
{{ BYTE src = regs.d[srcreg].B.l;
{ CPTR dsta = regs.a[dstreg];
BYTE dst = get_byte(dsta);
src |= dst;
put_byte(dsta,src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8118(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
ULONG dstreg = opcode & 7;
{{ BYTE src = regs.d[srcreg].B.l;
{ CPTR dsta = regs.a[dstreg];
BYTE dst = get_byte(dsta);
{ regs.a[dstreg] += areg_byteinc[dstreg];
src |= dst;
put_byte(dsta,src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8120(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
ULONG dstreg = opcode & 7;
{{ BYTE src = regs.d[srcreg].B.l;
{ regs.a[dstreg] -= areg_byteinc[dstreg];
{ CPTR dsta = regs.a[dstreg];
BYTE dst = get_byte(dsta);
src |= dst;
put_byte(dsta,src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8128(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
ULONG dstreg = opcode & 7;
{{ BYTE src = regs.d[srcreg].B.l;
{ CPTR dsta = regs.a[dstreg] + (LONG)(WORD)nextiword();
BYTE dst = get_byte(dsta);
src |= dst;
put_byte(dsta,src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8130(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
ULONG dstreg = opcode & 7;
{{ BYTE src = regs.d[srcreg].B.l;
{ CPTR dsta = get_disp_ea(regs.a[dstreg]);
{ BYTE dst = get_byte(dsta);
src |= dst;
put_byte(dsta,src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8138(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
{{ BYTE src = regs.d[srcreg].B.l;
{ CPTR dsta = (LONG)(WORD)nextiword();
BYTE dst = get_byte(dsta);
src |= dst;
put_byte(dsta,src);
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8139(void) /* OR */
{
ULONG srcreg = ((opcode >> 9) & 7);
{{ BYTE src = regs.d[srcreg].B.l;
{ CPTR dsta = nextilong();
BYTE dst = get_byte(dsta);
src |= dst;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -