This looks good. Reviewed-by: Laura Ekstrand <la...@jlekstrand.net>
On Tue, Mar 24, 2015 at 7:42 AM, Martin Peres <martin.pe...@linux.intel.com> wrote: > v2: > - improve an error message > > Reviewed-by: Laura Ekstrand <la...@jlekstrand.net> > > v3: > - move a test to less generic functions > - fix an alignment > > v4: > - take the caller as a parameter instead of bool dsa > - check that the lookup returns a valid renderbuffer > > Signed-off-by: Martin Peres <martin.pe...@linux.intel.com> > --- > src/mapi/glapi/gen/ARB_direct_state_access.xml | 6 +++ > src/mesa/main/fbobject.c | 63 > ++++++++++++++++++-------- > src/mesa/main/fbobject.h | 4 ++ > src/mesa/main/tests/dispatch_sanity.cpp | 1 + > 4 files changed, 56 insertions(+), 18 deletions(-) > > diff --git a/src/mapi/glapi/gen/ARB_direct_state_access.xml > b/src/mapi/glapi/gen/ARB_direct_state_access.xml > index 976dcc8..d4e1f7c 100644 > --- a/src/mapi/glapi/gen/ARB_direct_state_access.xml > +++ b/src/mapi/glapi/gen/ARB_direct_state_access.xml > @@ -159,6 +159,12 @@ > <param name="renderbuffers" type="GLuint *" /> > </function> > > + <function name="GetNamedRenderbufferParameteriv" offset="assign"> > + <param name="renderbuffer" type="GLuint" /> > + <param name="pname" type="GLenum" /> > + <param name="params" type="GLint *" /> > + </function> > + > <!-- Texture object functions --> > > <function name="CreateTextures" offset="assign"> > diff --git a/src/mesa/main/fbobject.c b/src/mesa/main/fbobject.c > index 8083bc1..377f915 100644 > --- a/src/mesa/main/fbobject.c > +++ b/src/mesa/main/fbobject.c > @@ -1993,25 +1993,11 @@ _es_RenderbufferStorageEXT(GLenum target, GLenum > internalFormat, > } > > > -void GLAPIENTRY > -_mesa_GetRenderbufferParameteriv(GLenum target, GLenum pname, GLint > *params) > +static void > +get_render_buffer_parameteriv(struct gl_context *ctx, > + struct gl_renderbuffer *rb, GLenum pname, > + GLint *params, const char *func) > { > - struct gl_renderbuffer *rb; > - GET_CURRENT_CONTEXT(ctx); > - > - if (target != GL_RENDERBUFFER_EXT) { > - _mesa_error(ctx, GL_INVALID_ENUM, > - "glGetRenderbufferParameterivEXT(target)"); > - return; > - } > - > - rb = ctx->CurrentRenderbuffer; > - if (!rb) { > - _mesa_error(ctx, GL_INVALID_OPERATION, > - "glGetRenderbufferParameterivEXT"); > - return; > - } > - > /* No need to flush here since we're just quering state which is > * not effected by rendering. > */ > @@ -2042,10 +2028,51 @@ _mesa_GetRenderbufferParameteriv(GLenum target, > GLenum pname, GLint *params) > } > /* fallthrough */ > default: > + _mesa_error(ctx, GL_INVALID_ENUM, "%s(invalid pname=%s)", func, > + _mesa_lookup_enum_by_nr(pname)); > + return; > + } > +} > + > + > +void GLAPIENTRY > +_mesa_GetRenderbufferParameteriv(GLenum target, GLenum pname, GLint > *params) > +{ > + GET_CURRENT_CONTEXT(ctx); > + > + if (target != GL_RENDERBUFFER_EXT) { > _mesa_error(ctx, GL_INVALID_ENUM, > "glGetRenderbufferParameterivEXT(target)"); > return; > } > + > + if (!ctx->CurrentRenderbuffer) { > + _mesa_error(ctx, GL_INVALID_OPERATION, > "glGetRenderbufferParameterivEXT" > + "(no renderbuffer bound)"); > + return; > + } > + > + get_render_buffer_parameteriv(ctx, ctx->CurrentRenderbuffer, pname, > + params, "glGetRenderbufferParameteriv"); > +} > + > + > +void GLAPIENTRY > +_mesa_GetNamedRenderbufferParameteriv(GLuint renderbuffer, GLenum pname, > + GLint *params) > +{ > + GET_CURRENT_CONTEXT(ctx); > + > + struct gl_renderbuffer *rb = _mesa_lookup_renderbuffer(ctx, > renderbuffer); > + if (!rb || rb == &DummyRenderbuffer) { > + /* ID was reserved, but no real renderbuffer object made yet */ > + _mesa_error(ctx, GL_INVALID_OPERATION, > "glGetNamedRenderbufferParameteriv" > + "(invalid renderbuffer %i)", renderbuffer); > + return; > + } > + > + get_render_buffer_parameteriv(ctx, rb, pname, params, > + "glGetNamedRenderbufferParameteriv"); > } > > > diff --git a/src/mesa/main/fbobject.h b/src/mesa/main/fbobject.h > index 9ab6b0b..b92149b 100644 > --- a/src/mesa/main/fbobject.h > +++ b/src/mesa/main/fbobject.h > @@ -137,6 +137,10 @@ extern void GLAPIENTRY > _mesa_GetRenderbufferParameteriv(GLenum target, GLenum pname, > GLint *params); > > +void GLAPIENTRY > +_mesa_GetNamedRenderbufferParameteriv(GLuint renderbuffer, GLenum pname, > + GLint *params); > + > extern GLboolean GLAPIENTRY > _mesa_IsFramebuffer(GLuint framebuffer); > > diff --git a/src/mesa/main/tests/dispatch_sanity.cpp > b/src/mesa/main/tests/dispatch_sanity.cpp > index 5383865..bb573d4 100644 > --- a/src/mesa/main/tests/dispatch_sanity.cpp > +++ b/src/mesa/main/tests/dispatch_sanity.cpp > @@ -944,6 +944,7 @@ const struct function gl_core_functions_possible[] = { > { "glGetNamedBufferPointerv", 45, -1 }, > { "glGetNamedBufferSubData", 45, -1 }, > { "glCreateRenderbuffers", 45, -1 }, > + { "glGetNamedRenderbufferParameteriv", 45, -1 }, > { "glCreateTextures", 45, -1 }, > { "glTextureStorage1D", 45, -1 }, > { "glTextureStorage2D", 45, -1 }, > -- > 2.3.3 > > _______________________________________________ > mesa-dev mailing list > mesa-dev@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/mesa-dev >
_______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev