forked from eden-emu/eden
		
	gl_resource_manager: Ensure non EXT_framebuffer objects are created
This commit is contained in:
		
							parent
							
								
									099b0b3167
								
							
						
					
					
						commit
						9fc1fa1b0d
					
				
					 2 changed files with 8 additions and 13 deletions
				
			
		|  | @ -166,7 +166,12 @@ void OGLFramebuffer::Create() { | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|     MICROPROFILE_SCOPE(OpenGL_ResourceCreation); |     MICROPROFILE_SCOPE(OpenGL_ResourceCreation); | ||||||
|     glCreateFramebuffers(1, &handle); |     // Bind to READ_FRAMEBUFFER to stop Nvidia's driver from creating an EXT_framebuffer instead of
 | ||||||
|  |     // a core framebuffer. EXT framebuffer attachments have to match in size and can be shared
 | ||||||
|  |     // across contexts. yuzu doesn't share framebuffers across contexts and we need attachments with
 | ||||||
|  |     // mismatching size, this is why core framebuffers are preferred.
 | ||||||
|  |     glGenFramebuffers(1, &handle); | ||||||
|  |     glBindFramebuffer(GL_READ_FRAMEBUFFER, handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void OGLFramebuffer::Release() { | void OGLFramebuffer::Release() { | ||||||
|  |  | ||||||
|  | @ -478,10 +478,6 @@ TextureCacheRuntime::TextureCacheRuntime(const Device& device_, ProgramManager& | ||||||
|         for (size_t i = 0; i < rescale_draw_fbos.size(); ++i) { |         for (size_t i = 0; i < rescale_draw_fbos.size(); ++i) { | ||||||
|             rescale_draw_fbos[i].Create(); |             rescale_draw_fbos[i].Create(); | ||||||
|             rescale_read_fbos[i].Create(); |             rescale_read_fbos[i].Create(); | ||||||
| 
 |  | ||||||
|             // Make sure the framebuffer is created without DSA
 |  | ||||||
|             glBindFramebuffer(GL_READ_FRAMEBUFFER, rescale_draw_fbos[i].handle); |  | ||||||
|             glBindFramebuffer(GL_READ_FRAMEBUFFER, rescale_read_fbos[i].handle); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -1224,13 +1220,8 @@ Sampler::Sampler(TextureCacheRuntime& runtime, const TSCEntry& config) { | ||||||
| 
 | 
 | ||||||
| Framebuffer::Framebuffer(TextureCacheRuntime& runtime, std::span<ImageView*, NUM_RT> color_buffers, | Framebuffer::Framebuffer(TextureCacheRuntime& runtime, std::span<ImageView*, NUM_RT> color_buffers, | ||||||
|                          ImageView* depth_buffer, const VideoCommon::RenderTargets& key) { |                          ImageView* depth_buffer, const VideoCommon::RenderTargets& key) { | ||||||
|     // Bind to READ_FRAMEBUFFER to stop Nvidia's driver from creating an EXT_framebuffer instead of
 |     framebuffer.Create(); | ||||||
|     // a core framebuffer. EXT framebuffer attachments have to match in size and can be shared
 |     GLuint handle = framebuffer.handle; | ||||||
|     // across contexts. yuzu doesn't share framebuffers across contexts and we need attachments with
 |  | ||||||
|     // mismatching size, this is why core framebuffers are preferred.
 |  | ||||||
|     GLuint handle; |  | ||||||
|     glGenFramebuffers(1, &handle); |  | ||||||
|     glBindFramebuffer(GL_READ_FRAMEBUFFER, handle); |  | ||||||
| 
 | 
 | ||||||
|     GLsizei num_buffers = 0; |     GLsizei num_buffers = 0; | ||||||
|     std::array<GLenum, NUM_RT> gl_draw_buffers; |     std::array<GLenum, NUM_RT> gl_draw_buffers; | ||||||
|  | @ -1278,7 +1269,6 @@ Framebuffer::Framebuffer(TextureCacheRuntime& runtime, std::span<ImageView*, NUM | ||||||
|         const std::string name = VideoCommon::Name(key); |         const std::string name = VideoCommon::Name(key); | ||||||
|         glObjectLabel(GL_FRAMEBUFFER, handle, static_cast<GLsizei>(name.size()), name.data()); |         glObjectLabel(GL_FRAMEBUFFER, handle, static_cast<GLsizei>(name.size()), name.data()); | ||||||
|     } |     } | ||||||
|     framebuffer.handle = handle; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void BGRCopyPass::CopyBGR(Image& dst_image, Image& src_image, | void BGRCopyPass::CopyBGR(Image& dst_image, Image& src_image, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ameerj
						ameerj