[Mesa-dev] [PATCH 3/6] main: Added entry point for glTransformFeedbackBufferRange
Laura Ekstrand
laura at jlekstrand.net
Thu Jan 29 10:35:44 PST 2015
On Thu, Jan 29, 2015 at 4:55 AM, Martin Peres <martin.peres at linux.intel.com>
wrote:
> v2: review from Laura Ekstrand
> - use the refactored code to lookup the objects
> - improve some error messages
> - factor out the gl method name computation
> - better handle the spec differences between the DSA and non-DSA cases
> - quote the spec a little more
>
> Signed-off-by: Martin Peres <martin.peres at linux.intel.com>
> ---
> src/mapi/glapi/gen/ARB_direct_state_access.xml | 8 +++
> src/mesa/main/bufferobj.c | 3 +-
> src/mesa/main/tests/dispatch_sanity.cpp | 1 +
> src/mesa/main/transformfeedback.c | 94
> +++++++++++++++++++++-----
> src/mesa/main/transformfeedback.h | 6 +-
> 5 files changed, 94 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 35d6906..b3c090f 100644
> --- a/src/mapi/glapi/gen/ARB_direct_state_access.xml
> +++ b/src/mapi/glapi/gen/ARB_direct_state_access.xml
> @@ -20,6 +20,14 @@
> <param name="buffer" type="GLuint" />
> </function>
>
> + <function name="TransformFeedbackBufferRange" offset="assign">
> + <param name="xfb" type="GLuint" />
> + <param name="index" type="GLuint" />
> + <param name="buffer" type="GLuint" />
> + <param name="offset" type="GLintptr" />
> + <param name="size" type="GLsizeiptr" />
> + </function>
> +
> <!-- Texture object functions -->
>
> <function name="CreateTextures" offset="assign">
> diff --git a/src/mesa/main/bufferobj.c b/src/mesa/main/bufferobj.c
> index 86532ea..7558e17 100644
> --- a/src/mesa/main/bufferobj.c
> +++ b/src/mesa/main/bufferobj.c
> @@ -3548,7 +3548,8 @@ _mesa_BindBufferRange(GLenum target, GLuint index,
> case GL_TRANSFORM_FEEDBACK_BUFFER:
> _mesa_bind_buffer_range_transform_feedback(ctx,
>
> ctx->TransformFeedback.CurrentObject,
> - index, bufObj, offset,
> size);
> + index, bufObj, offset,
> size,
> + false);
> return;
> case GL_UNIFORM_BUFFER:
> bind_buffer_range_uniform_buffer(ctx, index, bufObj, offset, size);
> diff --git a/src/mesa/main/tests/dispatch_sanity.cpp
> b/src/mesa/main/tests/dispatch_sanity.cpp
> index 166401a..3b34f7b 100644
> --- a/src/mesa/main/tests/dispatch_sanity.cpp
> +++ b/src/mesa/main/tests/dispatch_sanity.cpp
> @@ -957,6 +957,7 @@ const struct function gl_core_functions_possible[] = {
> /* GL_ARB_direct_state_access */
> { "glCreateTransformFeedbacks", 45, -1 },
> { "glTransformFeedbackBufferBase", 45, -1 },
> + { "glTransformFeedbackBufferRange", 45, -1 },
> { "glCreateTextures", 45, -1 },
> { "glTextureStorage1D", 45, -1 },
> { "glTextureStorage2D", 45, -1 },
> diff --git a/src/mesa/main/transformfeedback.c
> b/src/mesa/main/transformfeedback.c
> index 6583974..7564b6f 100644
> --- a/src/mesa/main/transformfeedback.c
> +++ b/src/mesa/main/transformfeedback.c
> @@ -541,7 +541,8 @@ bind_buffer_range(struct gl_context *ctx,
> /**
> * Specify a buffer object to receive transform feedback results. Plus,
> * specify the starting offset to place the results, and max size.
> - * Called from the glBindBufferRange() function.
> + * Called from the glBindBufferRange() and glTransformFeedbackBufferRange
> + * functions.
> */
> void
> _mesa_bind_buffer_range_transform_feedback(struct gl_context *ctx,
> @@ -549,35 +550,72 @@ _mesa_bind_buffer_range_transform_feedback(struct
> gl_context *ctx,
> GLuint index,
> struct gl_buffer_object
> *bufObj,
> GLintptr offset,
> - GLsizeiptr size)
> + GLsizeiptr size,
> + bool dsa)
> {
> + const char *gl_methd_name;
> + if (dsa)
> + gl_methd_name = "glTransformFeedbackBufferRange";
> + else
> + gl_methd_name = "glBindBufferRange";
> +
> +
> if (obj->Active) {
> - _mesa_error(ctx, GL_INVALID_OPERATION,
> - "glBindBufferRange(transform feedback active)");
> + _mesa_error(ctx, GL_INVALID_OPERATION, "%s(transform feedback
> active)",
> + gl_methd_name);
> return;
> }
>
> if (index >= ctx->Const.MaxTransformFeedbackBuffers) {
> - _mesa_error(ctx, GL_INVALID_VALUE, "glBindBufferRange(index=%d "
> - "out of bounds)", index);
> + /* An INVALID_VALUE error is generated if index is greater than or
> equal
> + * to the number of binding points for transform feedback, as
> described
> + * in section 6.7.1.
> + */
> + _mesa_error(ctx, GL_INVALID_VALUE, "%s(index=%d out of bounds)",
> + gl_methd_name, index);
> return;
> }
>
> if (size & 0x3) {
> - /* must a multiple of four */
> - _mesa_error(ctx, GL_INVALID_VALUE, "glBindBufferRange(size=%d)",
> - (int) size);
> + /* must a be multiple of four */
> + _mesa_error(ctx, GL_INVALID_VALUE, "%s(size=%d must be a multiple
> of "
> + "four)", gl_methd_name, (int) size);
> return;
> }
>
> if (offset & 0x3) {
> /* must be multiple of four */
> - _mesa_error(ctx, GL_INVALID_VALUE,
> - "glBindBufferRange(offset=%d)", (int) offset);
> + _mesa_error(ctx, GL_INVALID_VALUE, "gl%s(offset=%d must be a
> multiple "
> + "of four)", gl_methd_name, (int) offset);
> return;
> - }
> + }
> +
>
I think you got your offset and size comments in the wrong functions. They
are mixed up.
> + if (offset < 0) {
> + /* An INVALID_VALUE error is generated by BindBufferRange if offset
> is
> + * negative.
> + */
> + /* An INVALID_VALUE error is generated by
> TransformFeedbackBufferRange
> + * if size is less than or equal to zero.
> + */
> + _mesa_error(ctx, GL_INVALID_VALUE, "%s(offset=%d must be >= 0)",
> + gl_methd_name,
> + (int) offset);
> + return;
> + }
>
> - bind_buffer_range(ctx, obj, index, bufObj, offset, size, false);
> + if (size <= 0 && (dsa || bufObj != ctx->Shared->NullBufferObj)) {
> + /* An INVALID_VALUE error is generated by BindBufferRange if buffer
> is
> + * non-zero and size is less than or equal to zero.
> + */
> + /* An INVALID_VALUE error is generated by
> TransformFeedbackBufferRange
> + * if offset is negative.
> + */
> + _mesa_error(ctx, GL_INVALID_VALUE, "%s(size=%d must be > 0)",
> + gl_methd_name, (int) size);
> + return;
> + }
> +
> + bind_buffer_range(ctx, obj, index, bufObj, offset, size, dsa);
> }
>
>
>
> @@ -596,14 +634,14 @@ _mesa_bind_buffer_base_transform_feedback(struct
> gl_context *ctx,
> {
> if (obj->Active) {
> _mesa_error(ctx, GL_INVALID_OPERATION,
> - "%s(transform feedback active)",
> - dsa?"glTransformFeedbackBufferBase":"glBindBufferBase");
> + "gl%s(transform feedback active)",
> + dsa?"TransformFeedbackBufferBase":"BindBufferBase");
> return;
> }
>
> if (index >= ctx->Const.MaxTransformFeedbackBuffers) {
> _mesa_error(ctx, GL_INVALID_VALUE, "%s(index=%d out of bounds)",
> - dsa?"glTransformFeedbackBufferBase":"glBindBufferBase",
> + dsa ? "glTransformFeedbackBufferBase" :
> "glBindBufferBase",
> index);
> return;
> }
> @@ -679,6 +717,30 @@ _mesa_TransformFeedbackBufferBase(GLuint xfb, GLuint
> index, GLuint buffer)
> _mesa_bind_buffer_base_transform_feedback(ctx, obj, index, bufObj,
> true);
> }
>
> +void GLAPIENTRY
> +_mesa_TransformFeedbackBufferRange(GLuint xfb, GLuint index, GLuint
> buffer,
> + GLintptr offset, GLsizeiptr size)
> +{
> + GET_CURRENT_CONTEXT(ctx);
> + struct gl_transform_feedback_object *obj;
> + struct gl_buffer_object *bufObj;
> +
> + obj = _mesa_lookup_transform_feedback_object_err(ctx, xfb,
> +
> "glTransformFeedbackBufferRange");
> + if(!obj) {
> + return;
> + }
> +
> + bufObj = _mesa_lookup_bufferobj_err(ctx, buffer,
> + "glTransformFeedbackBufferRange");
> + if(!bufObj) {
> + return;
> + }
> +
> + _mesa_bind_buffer_range_transform_feedback(ctx, obj, index, bufObj,
> offset,
> + size, true);
> +}
> +
> /**
> * Specify a buffer object to receive transform feedback results, plus the
> * offset in the buffer to start placing results.
> diff --git a/src/mesa/main/transformfeedback.h
> b/src/mesa/main/transformfeedback.h
> index 2c4ce58..1178169 100644
> --- a/src/mesa/main/transformfeedback.h
> +++ b/src/mesa/main/transformfeedback.h
> @@ -69,7 +69,7 @@ _mesa_bind_buffer_range_transform_feedback(struct
> gl_context *ctx,
> GLuint index,
> struct gl_buffer_object *bufObj,
> GLintptr offset,
> - GLsizeiptr size);
> + GLsizeiptr size, bool dsa);
>
> extern void
> _mesa_bind_buffer_base_transform_feedback(struct gl_context *ctx,
> @@ -162,4 +162,8 @@ _mesa_lookup_bufferobj_err(struct gl_context *ctx,
> GLuint buffer,
> extern void GLAPIENTRY
> _mesa_TransformFeedbackBufferBase(GLuint xfb, GLuint index, GLuint
> buffer);
>
> +extern void GLAPIENTRY
> +_mesa_TransformFeedbackBufferRange(GLuint xfb, GLuint index, GLuint
> buffer,
> + GLintptr offset, GLsizeiptr size);
> +
> #endif /* TRANSFORM_FEEDBACK_H */
> --
> 2.2.2
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20150129/1035196c/attachment.html>
More information about the mesa-dev
mailing list