📄 opcode8.c
字号:
#include "cpudefs.h"
/* BFV 061298 - DIVU/DIVS opcodes are modified to decrement the icount */
void op_8000(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
BYTE src = regs.d[srcreg].B.l;
BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}
void op_8010(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg];
BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8018(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg];
BYTE src = get_byte(srca);
{ regs.a[srcreg] += areg_byteinc[srcreg];
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8020(void) /* OR */
{
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);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8028(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg] + (LONG)(WORD)nextiword();
BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8030(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = get_disp_ea(regs.a[srcreg]);
{ BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8038(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = (LONG)(WORD)nextiword();
BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8039(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = nextilong();
BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_803a(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = m68k_getpc();
srca += (LONG)(WORD)nextiword();
{ BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_803b(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = get_disp_ea(m68k_getpc());
{ BYTE src = get_byte(srca);
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_803c(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ BYTE src = nextiword();
{ BYTE dst = regs.d[dstreg].B.l;
src |= dst;
regs.d[dstreg].B.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8040(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ WORD src = regs.d[srcreg].W.l;
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8050(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg];
WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8058(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg];
WORD src = get_word(srca);
{ regs.a[srcreg] += 2;
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8060(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ regs.a[srcreg] -= 2;
{ CPTR srca = regs.a[srcreg];
WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8068(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg] + (LONG)(WORD)nextiword();
WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8070(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = get_disp_ea(regs.a[srcreg]);
{ WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_8078(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = (LONG)(WORD)nextiword();
WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8079(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = nextilong();
WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_807a(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = m68k_getpc();
srca += (LONG)(WORD)nextiword();
{ WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_807b(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = get_disp_ea(m68k_getpc());
{ WORD src = get_word(srca);
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}}
void op_807c(void) /* OR */
{
ULONG dstreg = (opcode >> 9) & 7;
{{ WORD src = nextiword();
{ WORD dst = regs.d[dstreg].W.l;
src |= dst;
regs.d[dstreg].W.l = src;
CLEARFLGS;
if ( src <= 0 )
{
if ( src == 0 )
{
ZFLG = ZTRUE;
}
else
{
NFLG = NTRUE;
}
}
}}}}
void op_8080(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ LONG src = regs.d[srcreg].D;
{ 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_8090(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = 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_8098(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg];
LONG src = get_long(srca);
{ regs.a[srcreg] += 4;
{ 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_80a0(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ regs.a[srcreg] -= 4;
{ CPTR srca = 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_80a8(void) /* OR */
{
ULONG srcreg = (opcode & 7);
ULONG dstreg = (opcode >> 9) & 7;
{{ CPTR srca = regs.a[srcreg] + (LONG)(WORD)nextiword();
LONG src = get_long(srca);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -