forked from eden-emu/eden
		
	gl_rasterizer: Re-enable framebuffer cache for clear buffers
This commit is contained in:
		
							parent
							
								
									ec9f949bc8
								
							
						
					
					
						commit
						da1bef3a85
					
				
					 3 changed files with 15 additions and 32 deletions
				
			
		|  | @ -19,8 +19,8 @@ | ||||||
| namespace OpenGL { | namespace OpenGL { | ||||||
| 
 | 
 | ||||||
| struct alignas(sizeof(u64)) FramebufferCacheKey { | struct alignas(sizeof(u64)) FramebufferCacheKey { | ||||||
|     bool stencil_enable = false; |     bool stencil_enable; | ||||||
|     u16 colors_count = 0; |     u16 colors_count; | ||||||
| 
 | 
 | ||||||
|     std::array<GLenum, Tegra::Engines::Maxwell3D::Regs::NumRenderTargets> color_attachments{}; |     std::array<GLenum, Tegra::Engines::Maxwell3D::Regs::NumRenderTargets> color_attachments{}; | ||||||
|     std::array<View, Tegra::Engines::Maxwell3D::Regs::NumRenderTargets> colors; |     std::array<View, Tegra::Engines::Maxwell3D::Regs::NumRenderTargets> colors; | ||||||
|  |  | ||||||
|  | @ -93,7 +93,6 @@ RasterizerOpenGL::RasterizerOpenGL(Core::System& system, Core::Frontend::EmuWind | ||||||
|     shader_program_manager = std::make_unique<GLShader::ProgramManager>(); |     shader_program_manager = std::make_unique<GLShader::ProgramManager>(); | ||||||
|     state.draw.shader_program = 0; |     state.draw.shader_program = 0; | ||||||
|     state.Apply(); |     state.Apply(); | ||||||
|     clear_framebuffer.Create(); |  | ||||||
| 
 | 
 | ||||||
|     LOG_DEBUG(Render_OpenGL, "Sync fixed function OpenGL state here"); |     LOG_DEBUG(Render_OpenGL, "Sync fixed function OpenGL state here"); | ||||||
|     CheckExtensions(); |     CheckExtensions(); | ||||||
|  | @ -405,46 +404,32 @@ void RasterizerOpenGL::ConfigureFramebuffers() { | ||||||
| 
 | 
 | ||||||
| void RasterizerOpenGL::ConfigureClearFramebuffer(OpenGLState& current_state, bool using_color_fb, | void RasterizerOpenGL::ConfigureClearFramebuffer(OpenGLState& current_state, bool using_color_fb, | ||||||
|                                                  bool using_depth_fb, bool using_stencil_fb) { |                                                  bool using_depth_fb, bool using_stencil_fb) { | ||||||
|  |     using VideoCore::Surface::SurfaceType; | ||||||
|  | 
 | ||||||
|     auto& gpu = system.GPU().Maxwell3D(); |     auto& gpu = system.GPU().Maxwell3D(); | ||||||
|     const auto& regs = gpu.regs; |     const auto& regs = gpu.regs; | ||||||
| 
 | 
 | ||||||
|     texture_cache.GuardRenderTargets(true); |     texture_cache.GuardRenderTargets(true); | ||||||
|     View color_surface{}; |     View color_surface; | ||||||
|     if (using_color_fb) { |     if (using_color_fb) { | ||||||
|         color_surface = texture_cache.GetColorBufferSurface(regs.clear_buffers.RT, false); |         color_surface = texture_cache.GetColorBufferSurface(regs.clear_buffers.RT, false); | ||||||
|     } |     } | ||||||
|     View depth_surface{}; |     View depth_surface; | ||||||
|     if (using_depth_fb || using_stencil_fb) { |     if (using_depth_fb || using_stencil_fb) { | ||||||
|         depth_surface = texture_cache.GetDepthBufferSurface(false); |         depth_surface = texture_cache.GetDepthBufferSurface(false); | ||||||
|     } |     } | ||||||
|     texture_cache.GuardRenderTargets(false); |     texture_cache.GuardRenderTargets(false); | ||||||
| 
 | 
 | ||||||
|     current_state.draw.draw_framebuffer = clear_framebuffer.handle; |     FramebufferCacheKey key; | ||||||
|  |     key.colors_count = color_surface ? 1 : 0; | ||||||
|  |     key.colors[0] = color_surface; | ||||||
|  |     key.color_attachments[0] = GL_COLOR_ATTACHMENT0; | ||||||
|  |     key.zeta = depth_surface; | ||||||
|  |     key.stencil_enable = depth_surface && depth_surface->GetSurfaceParams().type == | ||||||
|  |                                               VideoCore::Surface::SurfaceType::DepthStencil; | ||||||
|  | 
 | ||||||
|  |     current_state.draw.draw_framebuffer = framebuffer_cache.GetFramebuffer(key); | ||||||
|     current_state.ApplyFramebufferState(); |     current_state.ApplyFramebufferState(); | ||||||
| 
 |  | ||||||
|     if (color_surface) { |  | ||||||
|         color_surface->Attach(GL_COLOR_ATTACHMENT0, GL_DRAW_FRAMEBUFFER); |  | ||||||
|     } else { |  | ||||||
|         glFramebufferTexture2D(GL_DRAW_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, 0, 0); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     if (depth_surface) { |  | ||||||
|         const auto& params = depth_surface->GetSurfaceParams(); |  | ||||||
|         switch (params.type) { |  | ||||||
|         case VideoCore::Surface::SurfaceType::Depth: |  | ||||||
|             depth_surface->Attach(GL_DEPTH_ATTACHMENT, GL_DRAW_FRAMEBUFFER); |  | ||||||
|             glFramebufferTexture2D(GL_DRAW_FRAMEBUFFER, GL_STENCIL_ATTACHMENT, GL_TEXTURE_2D, 0, 0); |  | ||||||
|             break; |  | ||||||
|         case VideoCore::Surface::SurfaceType::DepthStencil: |  | ||||||
|             depth_surface->Attach(GL_DEPTH_STENCIL_ATTACHMENT, GL_DRAW_FRAMEBUFFER); |  | ||||||
|             break; |  | ||||||
|         default: |  | ||||||
|             UNIMPLEMENTED(); |  | ||||||
|         } |  | ||||||
|     } else { |  | ||||||
|         glFramebufferTexture2D(GL_DRAW_FRAMEBUFFER, GL_DEPTH_STENCIL_ATTACHMENT, GL_TEXTURE_2D, 0, |  | ||||||
|                                0); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RasterizerOpenGL::Clear() { | void RasterizerOpenGL::Clear() { | ||||||
|  |  | ||||||
|  | @ -223,8 +223,6 @@ private: | ||||||
| 
 | 
 | ||||||
|     enum class AccelDraw { Disabled, Arrays, Indexed }; |     enum class AccelDraw { Disabled, Arrays, Indexed }; | ||||||
|     AccelDraw accelerate_draw = AccelDraw::Disabled; |     AccelDraw accelerate_draw = AccelDraw::Disabled; | ||||||
| 
 |  | ||||||
|     OGLFramebuffer clear_framebuffer; |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } // namespace OpenGL
 | } // namespace OpenGL
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp