forked from eden-emu/eden
		
	Merge pull request #4009 from ogniK5377/macro-jit-prod
video_core: Implement Macro JIT
This commit is contained in:
		
						commit
						34d4abc4f9
					
				
					 15 changed files with 1043 additions and 188 deletions
				
			
		|  | @ -25,9 +25,8 @@ constexpr u32 MacroRegistersStart = 0xE00; | |||
| Maxwell3D::Maxwell3D(Core::System& system, VideoCore::RasterizerInterface& rasterizer, | ||||
|                      MemoryManager& memory_manager) | ||||
|     : system{system}, rasterizer{rasterizer}, memory_manager{memory_manager}, | ||||
|       macro_interpreter{*this}, upload_state{memory_manager, regs.upload} { | ||||
|       macro_engine{GetMacroEngine(*this)}, upload_state{memory_manager, regs.upload} { | ||||
|     dirty.flags.flip(); | ||||
| 
 | ||||
|     InitializeRegisterDefaults(); | ||||
| } | ||||
| 
 | ||||
|  | @ -120,7 +119,7 @@ void Maxwell3D::InitializeRegisterDefaults() { | |||
|     mme_inline[MAXWELL3D_REG_INDEX(index_array.count)] = true; | ||||
| } | ||||
| 
 | ||||
| void Maxwell3D::CallMacroMethod(u32 method, std::size_t num_parameters, const u32* parameters) { | ||||
| void Maxwell3D::CallMacroMethod(u32 method, const std::vector<u32>& parameters) { | ||||
|     // Reset the current macro.
 | ||||
|     executing_macro = 0; | ||||
| 
 | ||||
|  | @ -129,7 +128,7 @@ void Maxwell3D::CallMacroMethod(u32 method, std::size_t num_parameters, const u3 | |||
|         ((method - MacroRegistersStart) >> 1) % static_cast<u32>(macro_positions.size()); | ||||
| 
 | ||||
|     // Execute the current macro.
 | ||||
|     macro_interpreter.Execute(macro_positions[entry], num_parameters, parameters); | ||||
|     macro_engine->Execute(macro_positions[entry], parameters); | ||||
|     if (mme_draw.current_mode != MMEDrawMode::Undefined) { | ||||
|         FlushMMEInlineDraw(); | ||||
|     } | ||||
|  | @ -165,7 +164,7 @@ void Maxwell3D::CallMethod(u32 method, u32 method_argument, bool is_last_call) { | |||
| 
 | ||||
|         // Call the macro when there are no more parameters in the command buffer
 | ||||
|         if (is_last_call) { | ||||
|             CallMacroMethod(executing_macro, macro_params.size(), macro_params.data()); | ||||
|             CallMacroMethod(executing_macro, macro_params); | ||||
|             macro_params.clear(); | ||||
|         } | ||||
|         return; | ||||
|  | @ -201,7 +200,7 @@ void Maxwell3D::CallMethod(u32 method, u32 method_argument, bool is_last_call) { | |||
|         break; | ||||
|     } | ||||
|     case MAXWELL3D_REG_INDEX(macros.data): { | ||||
|         ProcessMacroUpload(arg); | ||||
|         macro_engine->AddCode(regs.macros.upload_address, arg); | ||||
|         break; | ||||
|     } | ||||
|     case MAXWELL3D_REG_INDEX(macros.bind): { | ||||
|  | @ -310,7 +309,7 @@ void Maxwell3D::CallMultiMethod(u32 method, const u32* base_start, u32 amount, | |||
| 
 | ||||
|         // Call the macro when there are no more parameters in the command buffer
 | ||||
|         if (amount == methods_pending) { | ||||
|             CallMacroMethod(executing_macro, macro_params.size(), macro_params.data()); | ||||
|             CallMacroMethod(executing_macro, macro_params); | ||||
|             macro_params.clear(); | ||||
|         } | ||||
|         return; | ||||
|  | @ -424,9 +423,7 @@ void Maxwell3D::FlushMMEInlineDraw() { | |||
| } | ||||
| 
 | ||||
| void Maxwell3D::ProcessMacroUpload(u32 data) { | ||||
|     ASSERT_MSG(regs.macros.upload_address < macro_memory.size(), | ||||
|                "upload_address exceeded macro_memory size!"); | ||||
|     macro_memory[regs.macros.upload_address++] = data; | ||||
|     macro_engine->AddCode(regs.macros.upload_address++, data); | ||||
| } | ||||
| 
 | ||||
| void Maxwell3D::ProcessMacroBind(u32 data) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei