dyncom: Get rid of unnecessary outer-scope variables in InterpreterMainLoop
This commit is contained in:
		
							parent
							
								
									3ace75a49f
								
							
						
					
					
						commit
						2843d1b98b
					
				
					 1 changed files with 108 additions and 97 deletions
				
			
		|  | @ -3968,15 +3968,11 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|         }; |         }; | ||||||
| #endif | #endif | ||||||
|     arm_inst* inst_base; |     arm_inst* inst_base; | ||||||
|     unsigned int lop, rop, dst; |  | ||||||
|     unsigned int addr; |     unsigned int addr; | ||||||
|     unsigned int phys_addr; |     unsigned int phys_addr; | ||||||
|     unsigned int last_pc = 0; |  | ||||||
|     unsigned int num_instrs = 0; |     unsigned int num_instrs = 0; | ||||||
| 
 | 
 | ||||||
|     static unsigned int last_physical_base = 0, last_logical_base = 0; |  | ||||||
|     int ptr; |     int ptr; | ||||||
|     bool single_step = (cpu->NumInstrsToExecute == 1); |  | ||||||
| 
 | 
 | ||||||
|     LOAD_NZCVT; |     LOAD_NZCVT; | ||||||
|     DISPATCH: |     DISPATCH: | ||||||
|  | @ -4071,9 +4067,9 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     { |     { | ||||||
|         and_inst *inst_cream = (and_inst *)inst_base->component; |         and_inst *inst_cream = (and_inst *)inst_base->component; | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { | ||||||
|             lop = RN; |             u32 lop = RN; | ||||||
|             rop = SHIFTER_OPERAND; |             u32 rop = SHIFTER_OPERAND; | ||||||
|             RD = dst = lop & rop; |             RD = lop & rop; | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -4081,8 +4077,8 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_WITH_SC; |                 UPDATE_CFLAG_WITH_SC; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|  | @ -4114,12 +4110,12 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     { |     { | ||||||
|         bic_inst *inst_cream = (bic_inst *)inst_base->component; |         bic_inst *inst_cream = (bic_inst *)inst_base->component; | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { | ||||||
|             lop = RN; |             u32 lop = RN; | ||||||
|             if (inst_cream->Rn == 15) { |             if (inst_cream->Rn == 15) { | ||||||
|                 lop += 2 * GET_INST_SIZE(cpu); |                 lop += 2 * GET_INST_SIZE(cpu); | ||||||
|             } |             } | ||||||
|             rop = SHIFTER_OPERAND; |             u32 rop = SHIFTER_OPERAND; | ||||||
|             RD = dst = lop & (~rop); |             RD = lop & (~rop); | ||||||
|             if ((inst_cream->S) && (inst_cream->Rd == 15)) { |             if ((inst_cream->S) && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -4127,8 +4123,8 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_WITH_SC; |                 UPDATE_CFLAG_WITH_SC; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|  | @ -4234,15 +4230,17 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     } |     } | ||||||
|     CMN_INST: |     CMN_INST: | ||||||
|     { |     { | ||||||
|         cmn_inst *inst_cream = (cmn_inst *)inst_base->component; |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |             cmn_inst* const inst_cream = (cmn_inst*)inst_base->component; | ||||||
|             lop = RN; | 
 | ||||||
|             rop = SHIFTER_OPERAND; |             bool carry; | ||||||
|             dst = lop + rop; |             bool overflow; | ||||||
|             UPDATE_NFLAG(dst); |             u32 result = AddWithCarry(RN, SHIFTER_OPERAND, 0, &carry, &overflow); | ||||||
|             UPDATE_ZFLAG(dst); | 
 | ||||||
|             UPDATE_CFLAG(dst, lop, rop); |             UPDATE_NFLAG(result); | ||||||
|             UPDATE_VFLAG((int)dst, (int)lop, (int)rop); |             UPDATE_ZFLAG(result); | ||||||
|  |             cpu->CFlag = carry; | ||||||
|  |             cpu->VFlag = overflow; | ||||||
|         } |         } | ||||||
|         cpu->Reg[15] += GET_INST_SIZE(cpu); |         cpu->Reg[15] += GET_INST_SIZE(cpu); | ||||||
|         INC_PC(sizeof(cmn_inst)); |         INC_PC(sizeof(cmn_inst)); | ||||||
|  | @ -4251,19 +4249,21 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     } |     } | ||||||
|     CMP_INST: |     CMP_INST: | ||||||
|     { |     { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|             cmp_inst *inst_cream = (cmp_inst *)inst_base->component; |             cmp_inst* const inst_cream = (cmp_inst*)inst_base->component; | ||||||
|             lop = RN; |  | ||||||
|             if (inst_cream->Rn == 15) { |  | ||||||
|                 lop += 2 * GET_INST_SIZE(cpu); |  | ||||||
|             } |  | ||||||
|             rop = SHIFTER_OPERAND; |  | ||||||
|             dst = lop - rop; |  | ||||||
| 
 | 
 | ||||||
|             UPDATE_NFLAG(dst); |             u32 rn_val = RN; | ||||||
|             UPDATE_ZFLAG(dst); |             if (inst_cream->Rn == 15) | ||||||
|             UPDATE_CFLAG_NOT_BORROW_FROM(lop, rop); |                 rn_val += 2 * GET_INST_SIZE(cpu); | ||||||
|             UPDATE_VFLAG_OVERFLOW_FROM(dst, lop, rop); | 
 | ||||||
|  |             bool carry; | ||||||
|  |             bool overflow; | ||||||
|  |             u32 result = AddWithCarry(rn_val, ~SHIFTER_OPERAND, 1, &carry, &overflow); | ||||||
|  | 
 | ||||||
|  |             UPDATE_NFLAG(result); | ||||||
|  |             UPDATE_ZFLAG(result); | ||||||
|  |             cpu->CFlag = carry; | ||||||
|  |             cpu->VFlag = overflow; | ||||||
|         } |         } | ||||||
|         cpu->Reg[15] += GET_INST_SIZE(cpu); |         cpu->Reg[15] += GET_INST_SIZE(cpu); | ||||||
|         INC_PC(sizeof(cmp_inst)); |         INC_PC(sizeof(cmp_inst)); | ||||||
|  | @ -4321,12 +4321,12 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     { |     { | ||||||
|         eor_inst *inst_cream = (eor_inst *)inst_base->component; |         eor_inst *inst_cream = (eor_inst *)inst_base->component; | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { | ||||||
|             lop = RN; |             u32 lop = RN; | ||||||
|             if (inst_cream->Rn == 15) { |             if (inst_cream->Rn == 15) { | ||||||
|                 lop += 2 * GET_INST_SIZE(cpu); |                 lop += 2 * GET_INST_SIZE(cpu); | ||||||
|             } |             } | ||||||
|             rop = SHIFTER_OPERAND; |             u32 rop = SHIFTER_OPERAND; | ||||||
|             RD = dst = lop ^ rop; |             RD = lop ^ rop; | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -4334,8 +4334,8 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_WITH_SC; |                 UPDATE_CFLAG_WITH_SC; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|  | @ -4852,10 +4852,10 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                 LOG_ERROR(Core_ARM11, "invalid operands for MLA"); |                 LOG_ERROR(Core_ARM11, "invalid operands for MLA"); | ||||||
|                 CITRA_IGNORE_EXIT(-1); |                 CITRA_IGNORE_EXIT(-1); | ||||||
|             } |             } | ||||||
|             RD = dst = static_cast<uint32_t>((rm * rs + rn) & 0xffffffff); |             RD = static_cast<uint32_t>((rm * rs + rn) & 0xffffffff); | ||||||
|             if (inst_cream->S) { |             if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|                 INC_PC(sizeof(mla_inst)); |                 INC_PC(sizeof(mla_inst)); | ||||||
|  | @ -4871,7 +4871,7 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     { |     { | ||||||
|         mov_inst *inst_cream = (mov_inst *)inst_base->component; |         mov_inst *inst_cream = (mov_inst *)inst_base->component; | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { | ||||||
|             RD = dst = SHIFTER_OPERAND; |             RD = SHIFTER_OPERAND; | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -4879,8 +4879,8 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_WITH_SC; |                 UPDATE_CFLAG_WITH_SC; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|  | @ -5016,10 +5016,10 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { | ||||||
|             uint64_t rm = RM; |             uint64_t rm = RM; | ||||||
|             uint64_t rs = RS; |             uint64_t rs = RS; | ||||||
|             RD = dst = static_cast<uint32_t>((rm * rs) & 0xffffffff); |             RD = static_cast<uint32_t>((rm * rs) & 0xffffffff); | ||||||
|             if (inst_cream->S) { |             if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|                 INC_PC(sizeof(mul_inst)); |                 INC_PC(sizeof(mul_inst)); | ||||||
|  | @ -5033,9 +5033,11 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     } |     } | ||||||
|     MVN_INST: |     MVN_INST: | ||||||
|     { |     { | ||||||
|         mvn_inst *inst_cream = (mvn_inst *)inst_base->component; |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |             mvn_inst* const inst_cream = (mvn_inst*)inst_base->component; | ||||||
|             RD = dst = ~SHIFTER_OPERAND; | 
 | ||||||
|  |             RD = ~SHIFTER_OPERAND; | ||||||
|  | 
 | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -5043,8 +5045,8 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_WITH_SC; |                 UPDATE_CFLAG_WITH_SC; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|  | @ -5059,11 +5061,13 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     } |     } | ||||||
|     ORR_INST: |     ORR_INST: | ||||||
|     { |     { | ||||||
|         orr_inst *inst_cream = (orr_inst *)inst_base->component; |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |             orr_inst* const inst_cream = (orr_inst*)inst_base->component; | ||||||
|             lop = RN; | 
 | ||||||
|             rop = SHIFTER_OPERAND; |             u32 lop = RN; | ||||||
|             RD = dst = lop | rop; |             u32 rop = SHIFTER_OPERAND; | ||||||
|  |             RD = lop | rop; | ||||||
|  | 
 | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -5071,8 +5075,8 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_WITH_SC; |                 UPDATE_CFLAG_WITH_SC; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|  | @ -5292,14 +5296,17 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     RFE_INST: |     RFE_INST: | ||||||
|     RSB_INST: |     RSB_INST: | ||||||
|     { |     { | ||||||
|         rsb_inst *inst_cream = (rsb_inst *)inst_base->component; |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |             rsb_inst* const inst_cream = (rsb_inst*)inst_base->component; | ||||||
|             rop = RN; | 
 | ||||||
|             lop = SHIFTER_OPERAND; |             u32 rn_val = RN; | ||||||
|             if (inst_cream->Rn == 15) { |             if (inst_cream->Rn == 15) | ||||||
|                 rop += 2 * GET_INST_SIZE(cpu);; |                 rn_val += 2 * GET_INST_SIZE(cpu); | ||||||
|             } | 
 | ||||||
|             RD = dst = lop - rop; |             bool carry; | ||||||
|  |             bool overflow; | ||||||
|  |             RD = AddWithCarry(~rn_val, SHIFTER_OPERAND, 1, &carry, &overflow); | ||||||
|  | 
 | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -5307,10 +5314,10 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_NOT_BORROW_FROM(lop, rop); |                 cpu->CFlag = carry; | ||||||
|                 UPDATE_VFLAG_OVERFLOW_FROM(dst, lop, rop); |                 cpu->VFlag = overflow; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|                 INC_PC(sizeof(rsb_inst)); |                 INC_PC(sizeof(rsb_inst)); | ||||||
|  | @ -5324,11 +5331,13 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     } |     } | ||||||
|     RSC_INST: |     RSC_INST: | ||||||
|     { |     { | ||||||
|         rsc_inst *inst_cream = (rsc_inst *)inst_base->component; |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |             rsc_inst* const inst_cream = (rsc_inst*)inst_base->component; | ||||||
|             lop = RN; | 
 | ||||||
|             rop = SHIFTER_OPERAND; |             bool carry; | ||||||
|             RD = dst = rop - lop - !cpu->CFlag; |             bool overflow; | ||||||
|  |             RD = AddWithCarry(~RN, SHIFTER_OPERAND, cpu->CFlag, &carry, &overflow); | ||||||
|  | 
 | ||||||
|             if (inst_cream->S && (inst_cream->Rd == 15)) { |             if (inst_cream->S && (inst_cream->Rd == 15)) { | ||||||
|                 if (CurrentModeHasSPSR) { |                 if (CurrentModeHasSPSR) { | ||||||
|                     cpu->Cpsr = cpu->Spsr_copy; |                     cpu->Cpsr = cpu->Spsr_copy; | ||||||
|  | @ -5336,10 +5345,10 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|                     LOAD_NZCVT; |                     LOAD_NZCVT; | ||||||
|                 } |                 } | ||||||
|             } else if (inst_cream->S) { |             } else if (inst_cream->S) { | ||||||
|                 UPDATE_NFLAG(dst); |                 UPDATE_NFLAG(RD); | ||||||
|                 UPDATE_ZFLAG(dst); |                 UPDATE_ZFLAG(RD); | ||||||
|                 UPDATE_CFLAG_NOT_BORROW_FROM_FLAG(rop, lop, !cpu->CFlag); |                 cpu->CFlag = carry; | ||||||
|                 UPDATE_VFLAG_OVERFLOW_FROM((int)dst, (int)rop, (int)lop); |                 cpu->VFlag = overflow; | ||||||
|             } |             } | ||||||
|             if (inst_cream->Rd == 15) { |             if (inst_cream->Rd == 15) { | ||||||
|                 INC_PC(sizeof(rsc_inst)); |                 INC_PC(sizeof(rsc_inst)); | ||||||
|  | @ -6406,18 +6415,19 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
| 
 | 
 | ||||||
|     TEQ_INST: |     TEQ_INST: | ||||||
|     { |     { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|             teq_inst *inst_cream = (teq_inst *)inst_base->component; |             teq_inst* const inst_cream = (teq_inst*)inst_base->component; | ||||||
|             lop = RN; | 
 | ||||||
|  |             u32 lop = RN; | ||||||
|  |             u32 rop = SHIFTER_OPERAND; | ||||||
| 
 | 
 | ||||||
|             if (inst_cream->Rn == 15) |             if (inst_cream->Rn == 15) | ||||||
|                 lop += GET_INST_SIZE(cpu) * 2; |                 lop += GET_INST_SIZE(cpu) * 2; | ||||||
| 
 | 
 | ||||||
|             rop = SHIFTER_OPERAND; |             u32 result = lop ^ rop; | ||||||
|             dst = lop ^ rop; |  | ||||||
| 
 | 
 | ||||||
|             UPDATE_NFLAG(dst); |             UPDATE_NFLAG(result); | ||||||
|             UPDATE_ZFLAG(dst); |             UPDATE_ZFLAG(result); | ||||||
|             UPDATE_CFLAG_WITH_SC; |             UPDATE_CFLAG_WITH_SC; | ||||||
|         } |         } | ||||||
|         cpu->Reg[15] += GET_INST_SIZE(cpu); |         cpu->Reg[15] += GET_INST_SIZE(cpu); | ||||||
|  | @ -6427,18 +6437,19 @@ unsigned InterpreterMainLoop(ARMul_State* state) { | ||||||
|     } |     } | ||||||
|     TST_INST: |     TST_INST: | ||||||
|     { |     { | ||||||
|         if ((inst_base->cond == 0xe) || CondPassed(cpu, inst_base->cond)) { |         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||||
|             tst_inst *inst_cream = (tst_inst *)inst_base->component; |             tst_inst* const inst_cream = (tst_inst*)inst_base->component; | ||||||
|             lop = RN; | 
 | ||||||
|  |             u32 lop = RN; | ||||||
|  |             u32 rop = SHIFTER_OPERAND; | ||||||
| 
 | 
 | ||||||
|             if (inst_cream->Rn == 15) |             if (inst_cream->Rn == 15) | ||||||
|                 lop += GET_INST_SIZE(cpu) * 2; |                 lop += GET_INST_SIZE(cpu) * 2; | ||||||
| 
 | 
 | ||||||
|             rop = SHIFTER_OPERAND; |             u32 result = lop & rop; | ||||||
|             dst = lop & rop; |  | ||||||
| 
 | 
 | ||||||
|             UPDATE_NFLAG(dst); |             UPDATE_NFLAG(result); | ||||||
|             UPDATE_ZFLAG(dst); |             UPDATE_ZFLAG(result); | ||||||
|             UPDATE_CFLAG_WITH_SC; |             UPDATE_CFLAG_WITH_SC; | ||||||
|         } |         } | ||||||
|         cpu->Reg[15] += GET_INST_SIZE(cpu); |         cpu->Reg[15] += GET_INST_SIZE(cpu); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash