keeping $0 overwrite prevention to just the CPU interpreter loop
Tried my best to make sure I didn't miss any op-codes. (Ctrl+F searching for "!= 0" and "== 0" throught the file shows me that I didn't.) If I did miss any op-codes, it's no bug, just remaining extra unnecessary checking for zero.
This commit is contained in:
parent
1772f1467c
commit
cb9f9e2b56
|
@ -98,19 +98,14 @@ void RSP_Opcode_BGTZ ( void ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSP_Opcode_ADDI ( void ) {
|
void RSP_Opcode_ADDI ( void ) {
|
||||||
if (RSPOpC.rt != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W + (int16_t)RSPOpC.immediate;
|
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W + (int16_t)RSPOpC.immediate;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Opcode_ADDIU ( void ) {
|
void RSP_Opcode_ADDIU ( void ) {
|
||||||
if (RSPOpC.rt != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rt].UW = RSP_GPR[RSPOpC.rs].UW + (uint32_t)((int16_t)RSPOpC.immediate);
|
RSP_GPR[RSPOpC.rt].UW = RSP_GPR[RSPOpC.rs].UW + (uint32_t)((int16_t)RSPOpC.immediate);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Opcode_SLTI (void) {
|
void RSP_Opcode_SLTI (void) {
|
||||||
if (RSPOpC.rt == 0) { return; }
|
|
||||||
if (RSP_GPR[RSPOpC.rs].W < (int16_t)RSPOpC.immediate) {
|
if (RSP_GPR[RSPOpC.rs].W < (int16_t)RSPOpC.immediate) {
|
||||||
RSP_GPR[RSPOpC.rt].W = 1;
|
RSP_GPR[RSPOpC.rt].W = 1;
|
||||||
} else {
|
} else {
|
||||||
|
@ -119,7 +114,6 @@ void RSP_Opcode_SLTI (void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSP_Opcode_SLTIU (void) {
|
void RSP_Opcode_SLTIU (void) {
|
||||||
if (RSPOpC.rt == 0) { return; }
|
|
||||||
if (RSP_GPR[RSPOpC.rs].UW < (uint32_t)(int16_t)RSPOpC.immediate) {
|
if (RSP_GPR[RSPOpC.rs].UW < (uint32_t)(int16_t)RSPOpC.immediate) {
|
||||||
RSP_GPR[RSPOpC.rt].W = 1;
|
RSP_GPR[RSPOpC.rt].W = 1;
|
||||||
} else {
|
} else {
|
||||||
|
@ -128,28 +122,20 @@ void RSP_Opcode_SLTIU (void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSP_Opcode_ANDI ( void ) {
|
void RSP_Opcode_ANDI ( void ) {
|
||||||
if (RSPOpC.rt != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W & RSPOpC.immediate;
|
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W & RSPOpC.immediate;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Opcode_ORI ( void ) {
|
void RSP_Opcode_ORI ( void ) {
|
||||||
if (RSPOpC.rt != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W | RSPOpC.immediate;
|
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W | RSPOpC.immediate;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Opcode_XORI ( void ) {
|
void RSP_Opcode_XORI ( void ) {
|
||||||
if (RSPOpC.rt != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W ^ RSPOpC.immediate;
|
RSP_GPR[RSPOpC.rt].W = RSP_GPR[RSPOpC.rs].W ^ RSPOpC.immediate;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Opcode_LUI (void) {
|
void RSP_Opcode_LUI (void) {
|
||||||
if (RSPOpC.rt != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rt].W = RSPOpC.immediate << 16;
|
RSP_GPR[RSPOpC.rt].W = RSPOpC.immediate << 16;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Opcode_COP0 (void) {
|
void RSP_Opcode_COP0 (void) {
|
||||||
RSP_Cop0[ RSPOpC.rs ]();
|
RSP_Cop0[ RSPOpC.rs ]();
|
||||||
|
@ -213,40 +199,28 @@ void RSP_Opcode_SC2 (void) {
|
||||||
|
|
||||||
/********************** R4300i OpCodes: Special **********************/
|
/********************** R4300i OpCodes: Special **********************/
|
||||||
void RSP_Special_SLL ( void ) {
|
void RSP_Special_SLL ( void ) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W << RSPOpC.sa;
|
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W << RSPOpC.sa;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SRL ( void ) {
|
void RSP_Special_SRL ( void ) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rt].UW >> RSPOpC.sa;
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rt].UW >> RSPOpC.sa;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SRA ( void ) {
|
void RSP_Special_SRA ( void ) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W >> RSPOpC.sa;
|
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W >> RSPOpC.sa;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SLLV (void) {
|
void RSP_Special_SLLV (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W << (RSP_GPR[RSPOpC.rs].W & 0x1F);
|
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W << (RSP_GPR[RSPOpC.rs].W & 0x1F);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SRLV (void) {
|
void RSP_Special_SRLV (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rt].UW >> (RSP_GPR[RSPOpC.rs].W & 0x1F);
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rt].UW >> (RSP_GPR[RSPOpC.rs].W & 0x1F);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SRAV (void) {
|
void RSP_Special_SRAV (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W >> (RSP_GPR[RSPOpC.rs].W & 0x1F);
|
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rt].W >> (RSP_GPR[RSPOpC.rs].W & 0x1F);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_JR (void) {
|
void RSP_Special_JR (void) {
|
||||||
RSP_NextInstruction = DELAY_SLOT;
|
RSP_NextInstruction = DELAY_SLOT;
|
||||||
|
@ -269,55 +243,38 @@ void RSP_Special_BREAK ( void ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSP_Special_ADD (void) {
|
void RSP_Special_ADD (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rs].W + RSP_GPR[RSPOpC.rt].W;
|
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rs].W + RSP_GPR[RSPOpC.rt].W;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_ADDU (void) {
|
void RSP_Special_ADDU (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW + RSP_GPR[RSPOpC.rt].UW;
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW + RSP_GPR[RSPOpC.rt].UW;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SUB (void) {
|
void RSP_Special_SUB (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rs].W - RSP_GPR[RSPOpC.rt].W;
|
RSP_GPR[RSPOpC.rd].W = RSP_GPR[RSPOpC.rs].W - RSP_GPR[RSPOpC.rt].W;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SUBU (void) {
|
void RSP_Special_SUBU (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW - RSP_GPR[RSPOpC.rt].UW;
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW - RSP_GPR[RSPOpC.rt].UW;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_AND (void) {
|
void RSP_Special_AND (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW & RSP_GPR[RSPOpC.rt].UW;
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW & RSP_GPR[RSPOpC.rt].UW;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_OR (void) {
|
void RSP_Special_OR (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW | RSP_GPR[RSPOpC.rt].UW;
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW | RSP_GPR[RSPOpC.rt].UW;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_XOR (void) {
|
void RSP_Special_XOR (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW ^ RSP_GPR[RSPOpC.rt].UW;
|
RSP_GPR[RSPOpC.rd].UW = RSP_GPR[RSPOpC.rs].UW ^ RSP_GPR[RSPOpC.rt].UW;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_NOR (void) {
|
void RSP_Special_NOR (void) {
|
||||||
if (RSPOpC.rd != 0) {
|
|
||||||
RSP_GPR[RSPOpC.rd].UW = ~(RSP_GPR[RSPOpC.rs].UW | RSP_GPR[RSPOpC.rt].UW);
|
RSP_GPR[RSPOpC.rd].UW = ~(RSP_GPR[RSPOpC.rs].UW | RSP_GPR[RSPOpC.rt].UW);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void RSP_Special_SLT (void) {
|
void RSP_Special_SLT (void) {
|
||||||
if (RSPOpC.rd == 0) { return; }
|
|
||||||
if (RSP_GPR[RSPOpC.rs].W < RSP_GPR[RSPOpC.rt].W) {
|
if (RSP_GPR[RSPOpC.rs].W < RSP_GPR[RSPOpC.rt].W) {
|
||||||
RSP_GPR[RSPOpC.rd].UW = 1;
|
RSP_GPR[RSPOpC.rd].UW = 1;
|
||||||
} else {
|
} else {
|
||||||
|
@ -326,7 +283,6 @@ void RSP_Special_SLT (void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSP_Special_SLTU (void) {
|
void RSP_Special_SLTU (void) {
|
||||||
if (RSPOpC.rd == 0) { return; }
|
|
||||||
if (RSP_GPR[RSPOpC.rs].UW < RSP_GPR[RSPOpC.rt].UW) {
|
if (RSP_GPR[RSPOpC.rs].UW < RSP_GPR[RSPOpC.rt].UW) {
|
||||||
RSP_GPR[RSPOpC.rd].UW = 1;
|
RSP_GPR[RSPOpC.rd].UW = 1;
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue