forked from eden-emu/eden
		
	VideoCore/Engines: Refactor Engines CallMethod.
This commit is contained in:
		
							parent
							
								
									4dca2298f9
								
							
						
					
					
						commit
						90e5694230
					
				
					 13 changed files with 82 additions and 62 deletions
				
			
		|  | @ -24,20 +24,19 @@ KeplerCompute::KeplerCompute(Core::System& system, VideoCore::RasterizerInterfac | |||
| 
 | ||||
| KeplerCompute::~KeplerCompute() = default; | ||||
| 
 | ||||
| void KeplerCompute::CallMethod(const GPU::MethodCall& method_call) { | ||||
|     ASSERT_MSG(method_call.method < Regs::NUM_REGS, | ||||
| void KeplerCompute::CallMethod(u32 method, u32 method_argument, bool is_last_call)  { | ||||
|     ASSERT_MSG(method < Regs::NUM_REGS, | ||||
|                "Invalid KeplerCompute register, increase the size of the Regs structure"); | ||||
| 
 | ||||
|     regs.reg_array[method_call.method] = method_call.argument; | ||||
|     regs.reg_array[method] = method_argument; | ||||
| 
 | ||||
|     switch (method_call.method) { | ||||
|     switch (method) { | ||||
|     case KEPLER_COMPUTE_REG_INDEX(exec_upload): { | ||||
|         upload_state.ProcessExec(regs.exec_upload.linear != 0); | ||||
|         break; | ||||
|     } | ||||
|     case KEPLER_COMPUTE_REG_INDEX(data_upload): { | ||||
|         const bool is_last_call = method_call.IsLastCall(); | ||||
|         upload_state.ProcessData(method_call.argument, is_last_call); | ||||
|         upload_state.ProcessData(method_argument, is_last_call); | ||||
|         if (is_last_call) { | ||||
|             system.GPU().Maxwell3D().OnMemoryWrite(); | ||||
|         } | ||||
|  | @ -54,7 +53,7 @@ void KeplerCompute::CallMethod(const GPU::MethodCall& method_call) { | |||
| void KeplerCompute::CallMultiMethod(u32 method, const u32* base_start, u32 amount, | ||||
|                                     u32 methods_pending) { | ||||
|     for (std::size_t i = 0; i < amount; i++) { | ||||
|         CallMethod({method, base_start[i], 0, methods_pending - static_cast<u32>(i)}); | ||||
|         CallMethod(method, base_start[i], methods_pending - static_cast<u32>(i) <= 1); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow