mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 11:56:42 +08:00 
			
		
		
		
	Merge pull request #964 from lioncash/svc
dyncom: Pass SVC immediates directly.
This commit is contained in:
		
						commit
						043b2f882a
					
				| @ -6248,7 +6248,8 @@ unsigned InterpreterMainLoop(ARMul_State* cpu) { | ||||
|     SWI_INST: | ||||
|     { | ||||
|         if (inst_base->cond == 0xE || CondPassed(cpu, inst_base->cond)) { | ||||
|             SVC::CallSVC(Memory::Read32(cpu->Reg[15])); | ||||
|             swi_inst* const inst_cream = (swi_inst*)inst_base->component; | ||||
|             SVC::CallSVC(inst_cream->num & 0xFFFF); | ||||
|         } | ||||
| 
 | ||||
|         cpu->Reg[15] += GET_INST_SIZE(cpu); | ||||
|  | ||||
| @ -833,8 +833,7 @@ static const FunctionDef SVC_Table[] = { | ||||
| 
 | ||||
| Common::Profiling::TimingCategory profiler_svc("SVC Calls"); | ||||
| 
 | ||||
| static const FunctionDef* GetSVCInfo(u32 opcode) { | ||||
|     u32 func_num = opcode & 0xFFFFFF; // 8 bits
 | ||||
| static const FunctionDef* GetSVCInfo(u32 func_num) { | ||||
|     if (func_num >= ARRAY_SIZE(SVC_Table)) { | ||||
|         LOG_ERROR(Kernel_SVC, "unknown svc=0x%02X", func_num); | ||||
|         return nullptr; | ||||
| @ -842,10 +841,10 @@ static const FunctionDef* GetSVCInfo(u32 opcode) { | ||||
|     return &SVC_Table[func_num]; | ||||
| } | ||||
| 
 | ||||
| void CallSVC(u32 opcode) { | ||||
| void CallSVC(u32 immediate) { | ||||
|     Common::Profiling::ScopeTimer timer_svc(profiler_svc); | ||||
| 
 | ||||
|     const FunctionDef *info = GetSVCInfo(opcode); | ||||
|     const FunctionDef* info = GetSVCInfo(immediate); | ||||
|     if (info) { | ||||
|         if (info->func) { | ||||
|             info->func(); | ||||
|  | ||||
| @ -41,6 +41,6 @@ enum ArbitrationType { | ||||
| 
 | ||||
| namespace SVC { | ||||
| 
 | ||||
| void CallSVC(u32 opcode); | ||||
| void CallSVC(u32 immediate); | ||||
| 
 | ||||
| } // namespace
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user