forked from eden-emu/eden
		
	gpu: Refactor command and swap buffers interface for asynch.
This commit is contained in:
		
							parent
							
								
									1e27162275
								
							
						
					
					
						commit
						edf09ff450
					
				
					 5 changed files with 26 additions and 17 deletions
				
			
		|  | @ -65,6 +65,16 @@ const DmaPusher& GPU::DmaPusher() const { | |||
|     return *dma_pusher; | ||||
| } | ||||
| 
 | ||||
| void GPU::PushGPUEntries(Tegra::CommandList&& entries) { | ||||
|     dma_pusher->Push(std::move(entries)); | ||||
|     dma_pusher->DispatchCalls(); | ||||
| } | ||||
| 
 | ||||
| void GPU::SwapBuffers( | ||||
|     std::optional<std::reference_wrapper<const Tegra::FramebufferConfig>> framebuffer) { | ||||
|     renderer.SwapBuffers(std::move(framebuffer)); | ||||
| } | ||||
| 
 | ||||
| u32 RenderTargetBytesPerPixel(RenderTargetFormat format) { | ||||
|     ASSERT(format != RenderTargetFormat::NONE); | ||||
| 
 | ||||
|  |  | |||
|  | @ -200,6 +200,13 @@ public: | |||
|             std::array<u32, NUM_REGS> reg_array; | ||||
|         }; | ||||
|     } regs{}; | ||||
|      | ||||
|     /// Push GPU command entries to be processed
 | ||||
|     void PushGPUEntries(Tegra::CommandList&& entries); | ||||
| 
 | ||||
|     /// Swap buffers (render frame)
 | ||||
|     void SwapBuffers( | ||||
|         std::optional<std::reference_wrapper<const Tegra::FramebufferConfig>> framebuffer); | ||||
| 
 | ||||
| private: | ||||
|     void ProcessBindMethod(const MethodCall& method_call); | ||||
|  | @ -207,11 +214,13 @@ private: | |||
|     void ProcessSemaphoreRelease(); | ||||
|     void ProcessSemaphoreAcquire(); | ||||
| 
 | ||||
|     // Calls a GPU puller method.
 | ||||
|     /// Calls a GPU puller method.
 | ||||
|     void CallPullerMethod(const MethodCall& method_call); | ||||
|     // Calls a GPU engine method.
 | ||||
|      | ||||
|     /// Calls a GPU engine method.
 | ||||
|     void CallEngineMethod(const MethodCall& method_call); | ||||
|     // Determines where the method should be executed.
 | ||||
|      | ||||
|     /// Determines where the method should be executed.
 | ||||
|     bool ExecuteMethodOnEngine(const MethodCall& method_call); | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei