forked from eden-emu/eden
		
	GPU: Move the Maxwell3D macro uploading code to the inside of the Maxwell3D processor.
It doesn't belong in the PFIFO handler.
This commit is contained in:
		
							parent
							
								
									f42b93399f
								
							
						
					
					
						commit
						219b5d34e7
					
				
					 4 changed files with 23 additions and 40 deletions
				
			
		|  | @ -22,10 +22,6 @@ constexpr u32 MacroRegistersStart = 0xE00; | |||
| Maxwell3D::Maxwell3D(MemoryManager& memory_manager) | ||||
|     : memory_manager(memory_manager), macro_interpreter(*this) {} | ||||
| 
 | ||||
| void Maxwell3D::SubmitMacroCode(u32 entry, std::vector<u32> code) { | ||||
|     uploaded_macros[entry * 2 + MacroRegistersStart] = std::move(code); | ||||
| } | ||||
| 
 | ||||
| void Maxwell3D::CallMacroMethod(u32 method, std::vector<u32> parameters) { | ||||
|     auto macro_code = uploaded_macros.find(method); | ||||
|     // The requested macro must have been uploaded already.
 | ||||
|  | @ -75,6 +71,10 @@ void Maxwell3D::WriteReg(u32 method, u32 value, u32 remaining_params) { | |||
|     regs.reg_array[method] = value; | ||||
| 
 | ||||
|     switch (method) { | ||||
|     case MAXWELL3D_REG_INDEX(macros.data): { | ||||
|         ProcessMacroUpload(value); | ||||
|         break; | ||||
|     } | ||||
|     case MAXWELL3D_REG_INDEX(code_address.code_address_high): | ||||
|     case MAXWELL3D_REG_INDEX(code_address.code_address_low): { | ||||
|         // Note: For some reason games (like Puyo Puyo Tetris) seem to write 0 to the CODE_ADDRESS
 | ||||
|  | @ -141,6 +141,12 @@ void Maxwell3D::WriteReg(u32 method, u32 value, u32 remaining_params) { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| void Maxwell3D::ProcessMacroUpload(u32 data) { | ||||
|     // Store the uploaded macro code to interpret them when they're called.
 | ||||
|     auto& macro = uploaded_macros[regs.macros.entry * 2 + MacroRegistersStart]; | ||||
|     macro.push_back(data); | ||||
| } | ||||
| 
 | ||||
| void Maxwell3D::ProcessQueryGet() { | ||||
|     GPUVAddr sequence_address = regs.query.QueryAddress(); | ||||
|     // Since the sequence address is given as a GPU VAddr, we have to convert it to an application
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Subv
						Subv