mirror of
https://github.com/ksherlock/mpw.git
synced 2025-01-20 09:31:46 +00:00
sync cpu code with fellow. fixes some instruction times and 64-bit division.
This commit is contained in:
parent
26bd3f53b7
commit
fb6d52a93d
@ -5231,7 +5231,7 @@ static void BTST_0110(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA02(opc_data[0]);
|
ULO dstea = cpuEA02(opc_data[0]);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(10);
|
cpuSetInstructionTime(8);
|
||||||
}
|
}
|
||||||
static void BTST_0118(ULO*opc_data)
|
static void BTST_0118(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5239,7 +5239,7 @@ static void BTST_0118(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA03(opc_data[0], 1);
|
ULO dstea = cpuEA03(opc_data[0], 1);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(10);
|
cpuSetInstructionTime(8);
|
||||||
}
|
}
|
||||||
static void BTST_0120(ULO*opc_data)
|
static void BTST_0120(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5247,7 +5247,7 @@ static void BTST_0120(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA04(opc_data[0], 1);
|
ULO dstea = cpuEA04(opc_data[0], 1);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(12);
|
cpuSetInstructionTime(10);
|
||||||
}
|
}
|
||||||
static void BTST_0128(ULO*opc_data)
|
static void BTST_0128(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5255,7 +5255,7 @@ static void BTST_0128(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA05(opc_data[0]);
|
ULO dstea = cpuEA05(opc_data[0]);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(14);
|
cpuSetInstructionTime(12);
|
||||||
}
|
}
|
||||||
static void BTST_0130(ULO*opc_data)
|
static void BTST_0130(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5263,7 +5263,7 @@ static void BTST_0130(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA06(opc_data[0]);
|
ULO dstea = cpuEA06(opc_data[0]);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(16);
|
cpuSetInstructionTime(14);
|
||||||
}
|
}
|
||||||
static void BTST_0138(ULO*opc_data)
|
static void BTST_0138(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5271,7 +5271,7 @@ static void BTST_0138(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA70();
|
ULO dstea = cpuEA70();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(14);
|
cpuSetInstructionTime(12);
|
||||||
}
|
}
|
||||||
static void BTST_0139(ULO*opc_data)
|
static void BTST_0139(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5279,7 +5279,7 @@ static void BTST_0139(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA71();
|
ULO dstea = cpuEA71();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(18);
|
cpuSetInstructionTime(16);
|
||||||
}
|
}
|
||||||
static void BTST_013A(ULO*opc_data)
|
static void BTST_013A(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5287,7 +5287,7 @@ static void BTST_013A(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA72();
|
ULO dstea = cpuEA72();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(14);
|
cpuSetInstructionTime(12);
|
||||||
}
|
}
|
||||||
static void BTST_013B(ULO*opc_data)
|
static void BTST_013B(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5295,21 +5295,21 @@ static void BTST_013B(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA73();
|
ULO dstea = cpuEA73();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(16);
|
cpuSetInstructionTime(14);
|
||||||
}
|
}
|
||||||
static void BTST_013C(ULO*opc_data)
|
static void BTST_013C(ULO*opc_data)
|
||||||
{
|
{
|
||||||
UBY src = cpuGetDRegByte(opc_data[1]);
|
UBY src = cpuGetDRegByte(opc_data[1]);
|
||||||
UBY dst = (UBY)cpuGetNextWord();
|
UBY dst = (UBY)cpuGetNextWord();
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(10);
|
cpuSetInstructionTime(8);
|
||||||
}
|
}
|
||||||
static void BTST_0100(ULO*opc_data)
|
static void BTST_0100(ULO*opc_data)
|
||||||
{
|
{
|
||||||
ULO src = cpuGetDReg(opc_data[1]);
|
ULO src = cpuGetDReg(opc_data[1]);
|
||||||
ULO dst = cpuGetDReg(opc_data[0]);
|
ULO dst = cpuGetDReg(opc_data[0]);
|
||||||
cpuBtstL(dst, src);
|
cpuBtstL(dst, src);
|
||||||
cpuSetInstructionTime(10);
|
cpuSetInstructionTime(6);
|
||||||
}
|
}
|
||||||
static void BTST_0810(ULO*opc_data)
|
static void BTST_0810(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5317,7 +5317,7 @@ static void BTST_0810(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA02(opc_data[0]);
|
ULO dstea = cpuEA02(opc_data[0]);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(8);
|
cpuSetInstructionTime(12);
|
||||||
}
|
}
|
||||||
static void BTST_0818(ULO*opc_data)
|
static void BTST_0818(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5325,7 +5325,7 @@ static void BTST_0818(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA03(opc_data[0], 1);
|
ULO dstea = cpuEA03(opc_data[0], 1);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(8);
|
cpuSetInstructionTime(12);
|
||||||
}
|
}
|
||||||
static void BTST_0820(ULO*opc_data)
|
static void BTST_0820(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5333,7 +5333,7 @@ static void BTST_0820(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA04(opc_data[0], 1);
|
ULO dstea = cpuEA04(opc_data[0], 1);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(10);
|
cpuSetInstructionTime(14);
|
||||||
}
|
}
|
||||||
static void BTST_0828(ULO*opc_data)
|
static void BTST_0828(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5341,7 +5341,7 @@ static void BTST_0828(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA05(opc_data[0]);
|
ULO dstea = cpuEA05(opc_data[0]);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(12);
|
cpuSetInstructionTime(16);
|
||||||
}
|
}
|
||||||
static void BTST_0830(ULO*opc_data)
|
static void BTST_0830(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5349,7 +5349,7 @@ static void BTST_0830(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA06(opc_data[0]);
|
ULO dstea = cpuEA06(opc_data[0]);
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(14);
|
cpuSetInstructionTime(18);
|
||||||
}
|
}
|
||||||
static void BTST_0838(ULO*opc_data)
|
static void BTST_0838(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5357,7 +5357,7 @@ static void BTST_0838(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA70();
|
ULO dstea = cpuEA70();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(12);
|
cpuSetInstructionTime(16);
|
||||||
}
|
}
|
||||||
static void BTST_0839(ULO*opc_data)
|
static void BTST_0839(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5365,7 +5365,7 @@ static void BTST_0839(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA71();
|
ULO dstea = cpuEA71();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(16);
|
cpuSetInstructionTime(20);
|
||||||
}
|
}
|
||||||
static void BTST_083A(ULO*opc_data)
|
static void BTST_083A(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5373,7 +5373,7 @@ static void BTST_083A(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA72();
|
ULO dstea = cpuEA72();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(12);
|
cpuSetInstructionTime(16);
|
||||||
}
|
}
|
||||||
static void BTST_083B(ULO*opc_data)
|
static void BTST_083B(ULO*opc_data)
|
||||||
{
|
{
|
||||||
@ -5381,14 +5381,14 @@ static void BTST_083B(ULO*opc_data)
|
|||||||
ULO dstea = cpuEA73();
|
ULO dstea = cpuEA73();
|
||||||
UBY dst = memoryReadByte(dstea);
|
UBY dst = memoryReadByte(dstea);
|
||||||
cpuBtstB(dst, src);
|
cpuBtstB(dst, src);
|
||||||
cpuSetInstructionTime(14);
|
cpuSetInstructionTime(18);
|
||||||
}
|
}
|
||||||
static void BTST_0800(ULO*opc_data)
|
static void BTST_0800(ULO*opc_data)
|
||||||
{
|
{
|
||||||
ULO src = (ULO)cpuGetNextWord();
|
ULO src = (ULO)cpuGetNextWord();
|
||||||
ULO dst = cpuGetDReg(opc_data[0]);
|
ULO dst = cpuGetDReg(opc_data[0]);
|
||||||
cpuBtstL(dst, src);
|
cpuBtstL(dst, src);
|
||||||
cpuSetInstructionTime(8);
|
cpuSetInstructionTime(10);
|
||||||
}
|
}
|
||||||
static void LEA_41D0(ULO*opc_data)
|
static void LEA_41D0(ULO*opc_data)
|
||||||
{
|
{
|
||||||
|
@ -68,7 +68,7 @@ static __inline void cpuTscBefore(LLO* a)
|
|||||||
*a = local_a;
|
*a = local_a;
|
||||||
}
|
}
|
||||||
|
|
||||||
static __inline void cpuTscAfter(LLO* a, LLO* b, ULO* c)
|
static __inline void cpuTscAfter(LLO* a, LLO* b, LON* c)
|
||||||
{
|
{
|
||||||
LLO local_a = *a;
|
LLO local_a = *a;
|
||||||
LLO local_b = *b;
|
LLO local_b = *b;
|
||||||
@ -1065,9 +1065,9 @@ static void cpuMulL(ULO src1, UWO extension)
|
|||||||
{
|
{
|
||||||
BOOLE o;
|
BOOLE o;
|
||||||
if (result >= 0)
|
if (result >= 0)
|
||||||
o = (result & 0xffffffff00000000) != 0;
|
o = (result & 0xffffffff00000000) != 0;
|
||||||
else
|
else
|
||||||
o = (result & 0xffffffff00000000) != 0xffffffff00000000;
|
o = (result & 0xffffffff00000000) != 0xffffffff00000000;
|
||||||
cpuSetDReg(dl, (ULO)result);
|
cpuSetDReg(dl, (ULO)result);
|
||||||
cpuSetFlagsNZVC(result == 0, result < 0, o, FALSE);
|
cpuSetFlagsNZVC(result == 0, result < 0, o, FALSE);
|
||||||
}
|
}
|
||||||
@ -1103,7 +1103,7 @@ void cpuCreateMuluTimeTable(void)
|
|||||||
j = 0;
|
j = 0;
|
||||||
for (k = 0; k < 8; k++)
|
for (k = 0; k < 8; k++)
|
||||||
if (((i>>k) & 1) == 1)
|
if (((i>>k) & 1) == 1)
|
||||||
j++;
|
j++;
|
||||||
cpuMuluTime[i] = (UBY) j*2;
|
cpuMuluTime[i] = (UBY) j*2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1117,7 +1117,7 @@ void cpuCreateMulsTimeTable(void)
|
|||||||
j = 0;
|
j = 0;
|
||||||
for (k = 0; k < 9; k++)
|
for (k = 0; k < 9; k++)
|
||||||
if ((((i>>k) & 3) == 1) || (((i>>k) & 3) == 2))
|
if ((((i>>k) & 3) == 1) || (((i>>k) & 3) == 2))
|
||||||
j++;
|
j++;
|
||||||
cpuMulsTime[i] = (UBY) j*2;
|
cpuMulsTime[i] = (UBY) j*2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1229,21 +1229,21 @@ static void cpuDivL(ULO divisor, ULO ext, ULO instruction_time)
|
|||||||
|
|
||||||
if (sign)
|
if (sign)
|
||||||
{
|
{
|
||||||
if (size64) x_signed = ((LLO) (LON) cpuGetDReg(dq_reg)) | (((LLO) cpuGetDReg(dr_reg))<<32);
|
if (size64) x_signed = (LLO) ((ULL) cpuGetDReg(dq_reg)) | (((LLO) cpuGetDReg(dr_reg))<<32);
|
||||||
else x_signed = (LLO) (LON) cpuGetDReg(dq_reg);
|
else x_signed = (LLO) (LON) cpuGetDReg(dq_reg);
|
||||||
y_signed = (LLO) (LON) divisor;
|
y_signed = (LLO) (LON) divisor;
|
||||||
|
|
||||||
if (y_signed < 0)
|
if (y_signed < 0)
|
||||||
{
|
{
|
||||||
y = (ULL) -y_signed;
|
y = (ULL) -y_signed;
|
||||||
resultsigned = !resultsigned;
|
resultsigned = !resultsigned;
|
||||||
}
|
}
|
||||||
else y = y_signed;
|
else y = y_signed;
|
||||||
if (x_signed < 0)
|
if (x_signed < 0)
|
||||||
{
|
{
|
||||||
x = (ULL) -x_signed;
|
x = (ULL) -x_signed;
|
||||||
resultsigned = !resultsigned;
|
resultsigned = !resultsigned;
|
||||||
restsigned = TRUE;
|
restsigned = TRUE;
|
||||||
}
|
}
|
||||||
else x = (ULL) x_signed;
|
else x = (ULL) x_signed;
|
||||||
}
|
}
|
||||||
@ -1261,30 +1261,30 @@ static void cpuDivL(ULO divisor, ULO ext, ULO instruction_time)
|
|||||||
{
|
{
|
||||||
if ((resultsigned && result > 0x80000000) || (!resultsigned && result > 0x7fffffff))
|
if ((resultsigned && result > 0x80000000) || (!resultsigned && result > 0x7fffffff))
|
||||||
{
|
{
|
||||||
/* Overflow */
|
/* Overflow */
|
||||||
cpuSetFlagsVC(TRUE, FALSE);
|
cpuSetFlagsVC(TRUE, FALSE);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LLO result_signed = (resultsigned) ? (-(LLO)result) : ((LLO)result);
|
LLO result_signed = (resultsigned) ? (-(LLO)result) : ((LLO)result);
|
||||||
LLO rest_signed = (restsigned) ? (-(LLO)rest) : ((LLO)rest);
|
LLO rest_signed = (restsigned) ? (-(LLO)rest) : ((LLO)rest);
|
||||||
cpuSetDReg(dr_reg, (ULO) rest_signed);
|
cpuSetDReg(dr_reg, (ULO) rest_signed);
|
||||||
cpuSetDReg(dq_reg, (ULO) result_signed);
|
cpuSetDReg(dq_reg, (ULO) result_signed);
|
||||||
cpuSetFlagsNZ00NewL((ULO) result_signed);
|
cpuSetFlagsNZ00NewL((ULO) result_signed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (result > 0xffffffff)
|
if (result > 0xffffffff)
|
||||||
{
|
{
|
||||||
/* Overflow */
|
/* Overflow */
|
||||||
cpuSetFlagsVC(TRUE, FALSE);
|
cpuSetFlagsVC(TRUE, FALSE);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cpuSetDReg(dr_reg, (ULO) rest);
|
cpuSetDReg(dr_reg, (ULO) rest);
|
||||||
cpuSetDReg(dq_reg, (ULO) result);
|
cpuSetDReg(dq_reg, (ULO) result);
|
||||||
cpuSetFlagsNZ00NewL((ULO) result);
|
cpuSetFlagsNZ00NewL((ULO) result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cpuSetInstructionTime(instruction_time);
|
cpuSetInstructionTime(instruction_time);
|
||||||
@ -1960,10 +1960,10 @@ static void cpuRte()
|
|||||||
|
|
||||||
if (cpuGetModelMajor() > 0)
|
if (cpuGetModelMajor() > 0)
|
||||||
{
|
{
|
||||||
ULO frame_type = (memoryReadWord(cpuGetAReg(7)) >> 12) & 0xf;
|
ULO frame_type = (memoryReadWord(cpuGetAReg(7)) >> 12) & 0xf;
|
||||||
cpuSetAReg(7, cpuGetAReg(7) + 2);
|
cpuSetAReg(7, cpuGetAReg(7) + 2);
|
||||||
cpuSetAReg(7, cpuGetAReg(7) + cpuRteStackInc[frame_type]);
|
cpuSetAReg(7, cpuGetAReg(7) + cpuRteStackInc[frame_type]);
|
||||||
redo = (frame_type == 1 && cpuGetModelMajor() >= 2 && cpuGetModelMajor() < 6);
|
redo = (frame_type == 1 && cpuGetModelMajor() >= 2 && cpuGetModelMajor() < 6);
|
||||||
}
|
}
|
||||||
else redo = FALSE;
|
else redo = FALSE;
|
||||||
|
|
||||||
@ -2116,12 +2116,12 @@ static void cpuMovemwPre(UWO regs, ULO reg)
|
|||||||
dstea -= 2;
|
dstea -= 2;
|
||||||
if (cpuGetModelMajor() >= 2 && j == reg)
|
if (cpuGetModelMajor() >= 2 && j == reg)
|
||||||
{
|
{
|
||||||
ea_reg_seen = TRUE;
|
ea_reg_seen = TRUE;
|
||||||
ea_reg_ea = dstea;
|
ea_reg_ea = dstea;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
memoryWriteWord(cpuGetRegWord(i, j), dstea);
|
memoryWriteWord(cpuGetRegWord(i, j), dstea);
|
||||||
}
|
}
|
||||||
cycles += 4;
|
cycles += 4;
|
||||||
}
|
}
|
||||||
@ -2168,12 +2168,12 @@ static void cpuMovemlPre(UWO regs, ULO reg)
|
|||||||
dstea -= 4;
|
dstea -= 4;
|
||||||
if (cpuGetModelMajor() >= 2 && j == reg)
|
if (cpuGetModelMajor() >= 2 && j == reg)
|
||||||
{
|
{
|
||||||
ea_reg_seen = TRUE;
|
ea_reg_seen = TRUE;
|
||||||
ea_reg_ea = dstea;
|
ea_reg_ea = dstea;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
memoryWriteLong(cpuGetReg(i, j), dstea);
|
memoryWriteLong(cpuGetReg(i, j), dstea);
|
||||||
}
|
}
|
||||||
cycles += 8;
|
cycles += 8;
|
||||||
}
|
}
|
||||||
@ -2217,10 +2217,10 @@ static void cpuMovemwPost(UWO regs, ULO reg)
|
|||||||
{
|
{
|
||||||
if (regs & index)
|
if (regs & index)
|
||||||
{
|
{
|
||||||
// Each word, for both data and address registers, is sign-extended before stored.
|
// Each word, for both data and address registers, is sign-extended before stored.
|
||||||
cpuSetReg(i, j, (ULO)(LON)(WOR) memoryReadWord(dstea));
|
cpuSetReg(i, j, (ULO)(LON)(WOR) memoryReadWord(dstea));
|
||||||
dstea += 2;
|
dstea += 2;
|
||||||
cycles += 4;
|
cycles += 4;
|
||||||
}
|
}
|
||||||
index = index << 1;
|
index = index << 1;
|
||||||
}
|
}
|
||||||
@ -2246,9 +2246,9 @@ static void cpuMovemlPost(UWO regs, ULO reg)
|
|||||||
{
|
{
|
||||||
if (regs & index)
|
if (regs & index)
|
||||||
{
|
{
|
||||||
cpuSetReg(i, j, memoryReadLong(dstea));
|
cpuSetReg(i, j, memoryReadLong(dstea));
|
||||||
dstea += 4;
|
dstea += 4;
|
||||||
cycles += 8;
|
cycles += 8;
|
||||||
}
|
}
|
||||||
index = index << 1;
|
index = index << 1;
|
||||||
}
|
}
|
||||||
@ -2274,10 +2274,10 @@ static void cpuMovemwEa2R(UWO regs, ULO ea, ULO eacycles)
|
|||||||
{
|
{
|
||||||
if (regs & index)
|
if (regs & index)
|
||||||
{
|
{
|
||||||
// Each word, for both data and address registers, is sign-extended before stored.
|
// Each word, for both data and address registers, is sign-extended before stored.
|
||||||
cpuSetReg(i, j, (ULO)(LON)(WOR) memoryReadWord(dstea));
|
cpuSetReg(i, j, (ULO)(LON)(WOR) memoryReadWord(dstea));
|
||||||
dstea += 2;
|
dstea += 2;
|
||||||
cycles += 4;
|
cycles += 4;
|
||||||
}
|
}
|
||||||
index = index << 1;
|
index = index << 1;
|
||||||
}
|
}
|
||||||
@ -2302,9 +2302,9 @@ static void cpuMovemlEa2R(UWO regs, ULO ea, ULO eacycles)
|
|||||||
{
|
{
|
||||||
if (regs & index)
|
if (regs & index)
|
||||||
{
|
{
|
||||||
cpuSetReg(i, j, memoryReadLong(dstea));
|
cpuSetReg(i, j, memoryReadLong(dstea));
|
||||||
dstea += 4;
|
dstea += 4;
|
||||||
cycles += 8;
|
cycles += 8;
|
||||||
}
|
}
|
||||||
index = index << 1;
|
index = index << 1;
|
||||||
}
|
}
|
||||||
@ -2329,9 +2329,9 @@ static void cpuMovemwR2Ea(UWO regs, ULO ea, ULO eacycles)
|
|||||||
{
|
{
|
||||||
if (regs & index)
|
if (regs & index)
|
||||||
{
|
{
|
||||||
memoryWriteWord(cpuGetRegWord(i, j), dstea);
|
memoryWriteWord(cpuGetRegWord(i, j), dstea);
|
||||||
dstea += 2;
|
dstea += 2;
|
||||||
cycles += 4;
|
cycles += 4;
|
||||||
}
|
}
|
||||||
index = index << 1;
|
index = index << 1;
|
||||||
}
|
}
|
||||||
@ -2356,9 +2356,9 @@ static void cpuMovemlR2Ea(UWO regs, ULO ea, ULO eacycles)
|
|||||||
{
|
{
|
||||||
if (regs & index)
|
if (regs & index)
|
||||||
{
|
{
|
||||||
memoryWriteLong(cpuGetReg(i, j), dstea);
|
memoryWriteLong(cpuGetReg(i, j), dstea);
|
||||||
dstea += 4;
|
dstea += 4;
|
||||||
cycles += 8;
|
cycles += 8;
|
||||||
}
|
}
|
||||||
index = index << 1;
|
index = index << 1;
|
||||||
}
|
}
|
||||||
@ -3103,41 +3103,41 @@ static void cpuMoveCFrom()
|
|||||||
{
|
{
|
||||||
switch (ctrl_regno)
|
switch (ctrl_regno)
|
||||||
{
|
{
|
||||||
case 0x000: cpuSetReg(da, regno, cpuGetSfc()); break;
|
case 0x000: cpuSetReg(da, regno, cpuGetSfc()); break;
|
||||||
case 0x001: cpuSetReg(da, regno, cpuGetDfc()); break;
|
case 0x001: cpuSetReg(da, regno, cpuGetDfc()); break;
|
||||||
case 0x800: cpuSetReg(da, regno, cpuGetUspDirect()); break; // In supervisor mode, usp is up to date.
|
case 0x800: cpuSetReg(da, regno, cpuGetUspDirect()); break; // In supervisor mode, usp is up to date.
|
||||||
case 0x801: cpuSetReg(da, regno, cpuGetVbr()); break;
|
case 0x801: cpuSetReg(da, regno, cpuGetVbr()); break;
|
||||||
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (cpuGetModelMajor() == 2)
|
else if (cpuGetModelMajor() == 2)
|
||||||
{
|
{
|
||||||
switch (ctrl_regno)
|
switch (ctrl_regno)
|
||||||
{
|
{
|
||||||
case 0x000: cpuSetReg(da, regno, cpuGetSfc()); break;
|
case 0x000: cpuSetReg(da, regno, cpuGetSfc()); break;
|
||||||
case 0x001: cpuSetReg(da, regno, cpuGetDfc()); break;
|
case 0x001: cpuSetReg(da, regno, cpuGetDfc()); break;
|
||||||
case 0x002: cpuSetReg(da, regno, cpuGetCacr() & 3); break;
|
case 0x002: cpuSetReg(da, regno, cpuGetCacr() & 3); break;
|
||||||
case 0x800: cpuSetReg(da, regno, cpuGetUspDirect()); break; // In supervisor mode, usp is up to date.
|
case 0x800: cpuSetReg(da, regno, cpuGetUspDirect()); break; // In supervisor mode, usp is up to date.
|
||||||
case 0x801: cpuSetReg(da, regno, cpuGetVbr()); break;
|
case 0x801: cpuSetReg(da, regno, cpuGetVbr()); break;
|
||||||
case 0x802: cpuSetReg(da, regno, cpuGetCaar() & 0xfc); break;
|
case 0x802: cpuSetReg(da, regno, cpuGetCaar() & 0xfc); break;
|
||||||
case 0x803: cpuSetReg(da, regno, cpuGetMspAutoMap()); break;
|
case 0x803: cpuSetReg(da, regno, cpuGetMspAutoMap()); break;
|
||||||
case 0x804: cpuSetReg(da, regno, cpuGetIspAutoMap()); break;
|
case 0x804: cpuSetReg(da, regno, cpuGetIspAutoMap()); break;
|
||||||
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (cpuGetModelMajor() == 3)
|
else if (cpuGetModelMajor() == 3)
|
||||||
{
|
{
|
||||||
switch (ctrl_regno)
|
switch (ctrl_regno)
|
||||||
{
|
{
|
||||||
case 0x000: cpuSetReg(da, regno, cpuGetSfc()); break;
|
case 0x000: cpuSetReg(da, regno, cpuGetSfc()); break;
|
||||||
case 0x001: cpuSetReg(da, regno, cpuGetDfc()); break;
|
case 0x001: cpuSetReg(da, regno, cpuGetDfc()); break;
|
||||||
case 0x002: cpuSetReg(da, regno, cpuGetCacr()); break;
|
case 0x002: cpuSetReg(da, regno, cpuGetCacr()); break;
|
||||||
case 0x800: cpuSetReg(da, regno, cpuGetUspDirect()); break; // In supervisor mode, usp is up to date.
|
case 0x800: cpuSetReg(da, regno, cpuGetUspDirect()); break; // In supervisor mode, usp is up to date.
|
||||||
case 0x801: cpuSetReg(da, regno, cpuGetVbr()); break;
|
case 0x801: cpuSetReg(da, regno, cpuGetVbr()); break;
|
||||||
case 0x802: cpuSetReg(da, regno, cpuGetCaar() & 0xfc); break;
|
case 0x802: cpuSetReg(da, regno, cpuGetCaar() & 0xfc); break;
|
||||||
case 0x803: cpuSetReg(da, regno, cpuGetMspAutoMap()); break;
|
case 0x803: cpuSetReg(da, regno, cpuGetMspAutoMap()); break;
|
||||||
case 0x804: cpuSetReg(da, regno, cpuGetIspAutoMap()); break;
|
case 0x804: cpuSetReg(da, regno, cpuGetIspAutoMap()); break;
|
||||||
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3164,41 +3164,41 @@ static void cpuMoveCTo()
|
|||||||
{
|
{
|
||||||
switch (ctrl_regno)
|
switch (ctrl_regno)
|
||||||
{
|
{
|
||||||
case 0x000: cpuSetSfc(cpuGetReg(da, regno) & 7); break;
|
case 0x000: cpuSetSfc(cpuGetReg(da, regno) & 7); break;
|
||||||
case 0x001: cpuSetDfc(cpuGetReg(da, regno) & 7); break;
|
case 0x001: cpuSetDfc(cpuGetReg(da, regno) & 7); break;
|
||||||
case 0x800: cpuSetUspDirect(cpuGetReg(da, regno)); break;
|
case 0x800: cpuSetUspDirect(cpuGetReg(da, regno)); break;
|
||||||
case 0x801: cpuSetVbr(cpuGetReg(da, regno)); break;
|
case 0x801: cpuSetVbr(cpuGetReg(da, regno)); break;
|
||||||
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (cpuGetModelMajor() == 2)
|
else if (cpuGetModelMajor() == 2)
|
||||||
{
|
{
|
||||||
switch (ctrl_regno)
|
switch (ctrl_regno)
|
||||||
{
|
{
|
||||||
case 0x000: cpuSetSfc(cpuGetReg(da, regno) & 7); break;
|
case 0x000: cpuSetSfc(cpuGetReg(da, regno) & 7); break;
|
||||||
case 0x001: cpuSetDfc(cpuGetReg(da, regno) & 7); break;
|
case 0x001: cpuSetDfc(cpuGetReg(da, regno) & 7); break;
|
||||||
case 0x002: cpuSetCacr(cpuGetReg(da, regno) & 0x3); break;
|
case 0x002: cpuSetCacr(cpuGetReg(da, regno) & 0x3); break;
|
||||||
case 0x800: cpuSetUspDirect(cpuGetReg(da, regno)); break;
|
case 0x800: cpuSetUspDirect(cpuGetReg(da, regno)); break;
|
||||||
case 0x801: cpuSetVbr(cpuGetReg(da, regno)); break;
|
case 0x801: cpuSetVbr(cpuGetReg(da, regno)); break;
|
||||||
case 0x802: cpuSetCaar(cpuGetReg(da, regno) & 0x00fc); break;
|
case 0x802: cpuSetCaar(cpuGetReg(da, regno) & 0x00fc); break;
|
||||||
case 0x803: cpuSetMspAutoMap(cpuGetReg(da, regno)); break;
|
case 0x803: cpuSetMspAutoMap(cpuGetReg(da, regno)); break;
|
||||||
case 0x804: cpuSetIspAutoMap(cpuGetReg(da, regno)); break;
|
case 0x804: cpuSetIspAutoMap(cpuGetReg(da, regno)); break;
|
||||||
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (cpuGetModelMajor() == 3)
|
else if (cpuGetModelMajor() == 3)
|
||||||
{
|
{
|
||||||
switch (ctrl_regno)
|
switch (ctrl_regno)
|
||||||
{
|
{
|
||||||
case 0x000: cpuSetSfc(cpuGetReg(da, regno) & 7); break;
|
case 0x000: cpuSetSfc(cpuGetReg(da, regno) & 7); break;
|
||||||
case 0x001: cpuSetDfc(cpuGetReg(da, regno) & 7); break;
|
case 0x001: cpuSetDfc(cpuGetReg(da, regno) & 7); break;
|
||||||
case 0x002: cpuSetCacr(cpuGetReg(da, regno) & 0x3313); break;
|
case 0x002: cpuSetCacr(cpuGetReg(da, regno) & 0x3313); break;
|
||||||
case 0x800: cpuSetUspDirect(cpuGetReg(da, regno)); break;
|
case 0x800: cpuSetUspDirect(cpuGetReg(da, regno)); break;
|
||||||
case 0x801: cpuSetVbr(cpuGetReg(da, regno)); break;
|
case 0x801: cpuSetVbr(cpuGetReg(da, regno)); break;
|
||||||
case 0x802: cpuSetCaar(cpuGetReg(da, regno) & 0x00fc); break;
|
case 0x802: cpuSetCaar(cpuGetReg(da, regno) & 0x00fc); break;
|
||||||
case 0x803: cpuSetMspAutoMap(cpuGetReg(da, regno)); break;
|
case 0x803: cpuSetMspAutoMap(cpuGetReg(da, regno)); break;
|
||||||
case 0x804: cpuSetIspAutoMap(cpuGetReg(da, regno)); break;
|
case 0x804: cpuSetIspAutoMap(cpuGetReg(da, regno)); break;
|
||||||
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
default: cpuThrowIllegalInstructionException(FALSE); return; // Illegal instruction
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3228,11 +3228,11 @@ static void cpuMoveSB(ULO ea, UWO extension)
|
|||||||
UBY data = memoryReadByte(ea);
|
UBY data = memoryReadByte(ea);
|
||||||
if (da == 0)
|
if (da == 0)
|
||||||
{
|
{
|
||||||
cpuSetDRegByte(regno, data);
|
cpuSetDRegByte(regno, data);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cpuSetAReg(regno, (ULO)(LON)(BYT) data);
|
cpuSetAReg(regno, (ULO)(LON)(BYT) data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3262,11 +3262,11 @@ static void cpuMoveSW(ULO ea, UWO extension)
|
|||||||
UWO data = memoryReadWord(ea);
|
UWO data = memoryReadWord(ea);
|
||||||
if (da == 0)
|
if (da == 0)
|
||||||
{
|
{
|
||||||
cpuSetDRegWord(regno, data);
|
cpuSetDRegWord(regno, data);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cpuSetAReg(regno, (ULO)(LON)(WOR) data);
|
cpuSetAReg(regno, (ULO)(LON)(WOR) data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3634,18 +3634,18 @@ static void cpuPflush040(ULO opmode, ULO regno)
|
|||||||
{
|
{
|
||||||
if (cpuGetFlagSupervisor())
|
if (cpuGetFlagSupervisor())
|
||||||
{
|
{
|
||||||
if (cpuGetModelMajor() != 2) // This is NOP on 68EC040
|
if (cpuGetModelMajor() != 2) // This is NOP on 68EC040
|
||||||
{
|
{
|
||||||
switch (opmode)
|
switch (opmode)
|
||||||
{
|
{
|
||||||
case 0: //PFLUSHN (An)
|
case 0: //PFLUSHN (An)
|
||||||
break;
|
break;
|
||||||
case 1: //PFLUSH (An)
|
case 1: //PFLUSH (An)
|
||||||
break;
|
break;
|
||||||
case 2: //PFLUSHAN
|
case 2: //PFLUSHAN
|
||||||
break;
|
break;
|
||||||
case 3: //PFLUSHA
|
case 3: //PFLUSHA
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3669,15 +3669,15 @@ static void cpuPtest040(ULO rw, ULO regno)
|
|||||||
{
|
{
|
||||||
if (cpuGetFlagSupervisor())
|
if (cpuGetFlagSupervisor())
|
||||||
{
|
{
|
||||||
if (cpuGetModelMajor() != 2) // This is NOP on 68EC040
|
if (cpuGetModelMajor() != 2) // This is NOP on 68EC040
|
||||||
{
|
{
|
||||||
if (rw == 0)
|
if (rw == 0)
|
||||||
{
|
{
|
||||||
// ptestr
|
// ptestr
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// ptestw
|
// ptestw
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3744,8 +3744,8 @@ ULO cpuExecuteInstruction(void)
|
|||||||
|
|
||||||
cpuSetInstructionTime(0);
|
cpuSetInstructionTime(0);
|
||||||
|
|
||||||
cpu_opcode_data_current[opcode].instruction_func(
|
cpu_opcode_data_current[opcode].instruction_func(
|
||||||
cpu_opcode_data_current[opcode].data);
|
cpu_opcode_data_current[opcode].data);
|
||||||
if (oldSr & 0xc000)
|
if (oldSr & 0xc000)
|
||||||
{
|
{
|
||||||
// This instruction was traced
|
// This instruction was traced
|
||||||
|
Loading…
x
Reference in New Issue
Block a user