forked from eden-emu/eden
		
	Frontend/GPU: Refactor context management
Changes the GraphicsContext to be managed by the GPU core. This eliminates the need for the frontends to fool around with tricky MakeCurrent/DoneCurrent calls that are dependent on the settings (such as async gpu option). This also refactors out the need to use QWidget::fromWindowContainer as that caused issues with focus and input handling. Now we use a regular QWidget and just access the native windowHandle() directly. Another change is removing the debug tool setting in FrameMailbox. Instead of trying to block the frontend until a new frame is ready, the core will now take over presentation and draw directly to the window if the renderer detects that its hooked by NSight or RenderDoc Lastly, since it was in the way, I removed ScopeAcquireWindowContext and replaced it with a simple subclass in GraphicsContext that achieves the same result
This commit is contained in:
		
							parent
							
								
									6ca8637d4c
								
							
						
					
					
						commit
						282adfc70b
					
				
					 29 changed files with 362 additions and 419 deletions
				
			
		|  | @ -25,8 +25,11 @@ inline u8* FromCacheAddr(CacheAddr cache_addr) { | |||
| } | ||||
| 
 | ||||
| namespace Core { | ||||
| class System; | ||||
| namespace Frontend { | ||||
| class EmuWindow; | ||||
| } | ||||
| class System; | ||||
| } // namespace Core
 | ||||
| 
 | ||||
| namespace VideoCore { | ||||
| class RendererBase; | ||||
|  | @ -129,7 +132,8 @@ class MemoryManager; | |||
| 
 | ||||
| class GPU { | ||||
| public: | ||||
|     explicit GPU(Core::System& system, VideoCore::RendererBase& renderer, bool is_async); | ||||
|     explicit GPU(Core::System& system, std::unique_ptr<VideoCore::RendererBase>&& renderer, | ||||
|                  bool is_async); | ||||
| 
 | ||||
|     virtual ~GPU(); | ||||
| 
 | ||||
|  | @ -174,6 +178,14 @@ public: | |||
|     /// Returns a reference to the GPU DMA pusher.
 | ||||
|     Tegra::DmaPusher& DmaPusher(); | ||||
| 
 | ||||
|     VideoCore::RendererBase& Renderer() { | ||||
|         return *renderer; | ||||
|     } | ||||
| 
 | ||||
|     const VideoCore::RendererBase& Renderer() const { | ||||
|         return *renderer; | ||||
|     } | ||||
| 
 | ||||
|     // Waits for the GPU to finish working
 | ||||
|     virtual void WaitIdle() const = 0; | ||||
| 
 | ||||
|  | @ -287,7 +299,7 @@ private: | |||
| protected: | ||||
|     std::unique_ptr<Tegra::DmaPusher> dma_pusher; | ||||
|     Core::System& system; | ||||
|     VideoCore::RendererBase& renderer; | ||||
|     std::unique_ptr<VideoCore::RendererBase> renderer; | ||||
| 
 | ||||
| private: | ||||
|     std::unique_ptr<Tegra::MemoryManager> memory_manager; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 James Rowe
						James Rowe