From: Marek Olšák Date: Fri, 15 Jun 2012 00:00:36 +0000 (+0200) Subject: st/mesa: make unsupported renderbuffer formats always fail as FBO incomplete X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c760283159dbf3607b0f072b0d1ff50859feb3f4;p=mesa.git st/mesa: make unsupported renderbuffer formats always fail as FBO incomplete instead of failing to allocate a renderbuffer. This also fixes piglit/get-renderbuffer-internalformat with non-renderable formats. Reviewed-by: Brian Paul --- diff --git a/src/mesa/state_tracker/st_cb_fbo.c b/src/mesa/state_tracker/st_cb_fbo.c index 01269998453..88c6fa2da96 100644 --- a/src/mesa/state_tracker/st_cb_fbo.c +++ b/src/mesa/state_tracker/st_cb_fbo.c @@ -81,10 +81,13 @@ st_renderbuffer_alloc_sw_storage(struct gl_context * ctx, } else { format = st_choose_renderbuffer_format(screen, internalFormat, 0); - } - if (format == PIPE_FORMAT_NONE) { - return FALSE; + /* Not setting gl_renderbuffer::Format here will cause + * FRAMEBUFFER_UNSUPPORTED and ValidateFramebuffer will not be called. + */ + if (format == PIPE_FORMAT_NONE) { + return GL_TRUE; + } } strb->Base.Format = st_pipe_format_to_mesa_format(format); @@ -133,8 +136,11 @@ st_renderbuffer_alloc_storage(struct gl_context * ctx, format = st_choose_renderbuffer_format(screen, internalFormat, rb->NumSamples); + /* Not setting gl_renderbuffer::Format here will cause + * FRAMEBUFFER_UNSUPPORTED and ValidateFramebuffer will not be called. + */ if (format == PIPE_FORMAT_NONE) { - return FALSE; + return GL_TRUE; } strb->Base.Format = st_pipe_format_to_mesa_format(format);