<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Feb 23, 2015 at 6:48 AM, Martin Peres <span dir="ltr"><<a href="mailto:martin.peres@linux.intel.com" target="_blank">martin.peres@linux.intel.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">v2: review from Laura Ekstrand<br>
- use the refactored code to lookup the objects<br>
- improve some error messages<br>
- factor out the gl method name computation<br>
- better handle the spec differences between the DSA and non-DSA cases<br>
- quote the spec a little more<br>
<br>
v3: review from Laura Ekstrand<br>
- use the new name of _mesa_lookup_bufferobj_err<br>
- swap the comments around the offset and size checks<br>
<br>
v4: review from Laura Ekstrand<br>
- add more spec quotes<br>
- properly fix the comments around the offset and size checks<br>
<br>
</span>v5: review from Laura Ekstrand<br>
- add quotes on the spec citations<br>
- revert some changes in the printf format<br>
<br>
Signed-off-by: Martin Peres <<a href="mailto:martin.peres@linux.intel.com">martin.peres@linux.intel.com</a>><br>
<span class="">---<br>
 src/mapi/glapi/gen/ARB_direct_state_access.xml |  8 +++<br>
 src/mesa/main/bufferobj.c                      |  3 +-<br>
 src/mesa/main/tests/dispatch_sanity.cpp        |  1 +<br>
</span> src/mesa/main/transformfeedback.c              | 92 ++++++++++++++++++++++----<br>
 src/mesa/main/transformfeedback.h              |  6 +-<br>
 5 files changed, 94 insertions(+), 16 deletions(-)<br>
<span class=""><br>
diff --git a/src/mapi/glapi/gen/ARB_direct_state_access.xml b/src/mapi/glapi/gen/ARB_direct_state_access.xml<br>
index 35d6906..b3c090f 100644<br>
--- a/src/mapi/glapi/gen/ARB_direct_state_access.xml<br>
+++ b/src/mapi/glapi/gen/ARB_direct_state_access.xml<br>
@@ -20,6 +20,14 @@<br>
       <param name="buffer" type="GLuint" /><br>
    </function><br>
<br>
+   <function name="TransformFeedbackBufferRange" offset="assign"><br>
+      <param name="xfb" type="GLuint" /><br>
+      <param name="index" type="GLuint" /><br>
+      <param name="buffer" type="GLuint" /><br>
+      <param name="offset" type="GLintptr" /><br>
+      <param name="size" type="GLsizeiptr" /><br>
+   </function><br>
+<br>
    <!-- Texture object functions --><br>
<br>
    <function name="CreateTextures" offset="assign"><br>
diff --git a/src/mesa/main/bufferobj.c b/src/mesa/main/bufferobj.c<br>
</span>index 96d43c8..fb8eb1e 100644<br>
--- a/src/mesa/main/bufferobj.c<br>
+++ b/src/mesa/main/bufferobj.c<br>
@@ -3577,7 +3577,8 @@ _mesa_BindBufferRange(GLenum target, GLuint index,<br>
<span class="">    case GL_TRANSFORM_FEEDBACK_BUFFER:<br>
       _mesa_bind_buffer_range_transform_feedback(ctx,<br>
                                                  ctx->TransformFeedback.CurrentObject,<br>
-                                                 index, bufObj, offset, size);<br>
+                                                 index, bufObj, offset, size,<br>
+                                                 false);<br>
       return;<br>
    case GL_UNIFORM_BUFFER:<br>
       bind_buffer_range_uniform_buffer(ctx, index, bufObj, offset, size);<br>
diff --git a/src/mesa/main/tests/dispatch_sanity.cpp b/src/mesa/main/tests/dispatch_sanity.cpp<br>
</span>index 3195abb..ba57034 100644<br>
<span class="">--- a/src/mesa/main/tests/dispatch_sanity.cpp<br>
+++ b/src/mesa/main/tests/dispatch_sanity.cpp<br>
@@ -957,6 +957,7 @@ const struct function gl_core_functions_possible[] = {<br>
    /* GL_ARB_direct_state_access */<br>
    { "glCreateTransformFeedbacks", 45, -1 },<br>
    { "glTransformFeedbackBufferBase", 45, -1 },<br>
+   { "glTransformFeedbackBufferRange", 45, -1 },<br>
    { "glCreateTextures", 45, -1 },<br>
    { "glTextureStorage1D", 45, -1 },<br>
    { "glTextureStorage2D", 45, -1 },<br>
diff --git a/src/mesa/main/transformfeedback.c b/src/mesa/main/transformfeedback.c<br>
</span>index 159fa62..dd96a3b 100644<br>
<div><div class="h5">--- a/src/mesa/main/transformfeedback.c<br>
+++ b/src/mesa/main/transformfeedback.c<br>
@@ -541,7 +541,8 @@ bind_buffer_range(struct gl_context *ctx,<br>
 /**<br>
  * Specify a buffer object to receive transform feedback results.  Plus,<br>
  * specify the starting offset to place the results, and max size.<br>
- * Called from the glBindBufferRange() function.<br>
+ * Called from the glBindBufferRange() and glTransformFeedbackBufferRange<br>
+ * functions.<br>
  */<br>
 void<br>
 _mesa_bind_buffer_range_transform_feedback(struct gl_context *ctx,<br>
@@ -549,35 +550,74 @@ _mesa_bind_buffer_range_transform_feedback(struct gl_context *ctx,<br>
                                            GLuint index,<br>
                                            struct gl_buffer_object *bufObj,<br>
                                            GLintptr offset,<br>
-                                           GLsizeiptr size)<br>
+                                           GLsizeiptr size,<br>
+                                           bool dsa)<br>
 {<br>
+   const char *gl_methd_name;<br>
+   if (dsa)<br>
+      gl_methd_name = "glTransformFeedbackBufferRange";<br>
+   else<br>
+      gl_methd_name = "glBindBufferRange";<br>
+<br>
+<br>
    if (obj->Active) {<br>
-      _mesa_error(ctx, GL_INVALID_OPERATION,<br>
-                  "glBindBufferRange(transform feedback active)");<br>
+      _mesa_error(ctx, GL_INVALID_OPERATION, "%s(transform feedback active)",<br>
+                  gl_methd_name);<br>
       return;<br>
    }<br>
<br>
    if (index >= ctx->Const.MaxTransformFeedbackBuffers) {<br>
-      _mesa_error(ctx, GL_INVALID_VALUE, "glBindBufferRange(index=%d "<br>
-                  "out of bounds)", index);<br>
+      /* OpenGL 4.5 core profile, 6.1, pdf page 82: "An INVALID_VALUE error is<br>
+       * generated if index is greater than or equal to the number of binding<br>
+       * points for transform feedback, as described in section 6.7.1."<br>
</div></div><span class="">+       */<br>
+      _mesa_error(ctx, GL_INVALID_VALUE, "%s(index=%d out of bounds)",<br>
+                  gl_methd_name, index);<br>
       return;<br>
    }<br>
<br>
    if (size & 0x3) {<br>
-      /* must a multiple of four */<br>
-      _mesa_error(ctx, GL_INVALID_VALUE, "glBindBufferRange(size=%d)",<br>
-                  (int) size);<br>
+      /* OpenGL 4.5 core profile, 6.7, pdf page 103: multiple of 4 */<br>
+      _mesa_error(ctx, GL_INVALID_VALUE, "%s(size=%d must be a multiple of "<br>
+                  "four)", gl_methd_name, (int) size);<br>
       return;<br>
    }<br>
<br>
    if (offset & 0x3) {<br>
-      /* must be multiple of four */<br>
-      _mesa_error(ctx, GL_INVALID_VALUE,<br>
-                  "glBindBufferRange(offset=%d)", (int) offset);<br>
+      /* OpenGL 4.5 core profile, 6.7, pdf page 103: multiple of 4 */<br>
+      _mesa_error(ctx, GL_INVALID_VALUE, "gl%s(offset=%d must be a multiple "<br></span></blockquote><div>Redundant "gl" here -------------------------------------->^^ <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
</span><div><div class="h5">+                  "of four)", gl_methd_name, (int) offset);<br>
       return;<br>
-   }<br>
+   }<br>
+<br>
+   if (offset < 0) {<br>
+      /* OpenGL 4.5 core profile, 6.1, pdf page 82: "An INVALID_VALUE error is<br>
+       * generated by BindBufferRange if offset is negative."<br>
+       *<br>
+       * OpenGL 4.5 core profile, 13.2, pdf page 445: "An INVALID_VALUE error<br>
+       * is generated by TransformFeedbackBufferRange if offset is negative."<br>
+       */<br>
+      _mesa_error(ctx, GL_INVALID_VALUE, "%s(offset=%d must be >= 0)",<br>
+                  gl_methd_name,<br>
+                  (int) offset);<br>
+      return;<br>
+   }<br>
+<br>
+   if (size <= 0 && (dsa || bufObj != ctx->Shared->NullBufferObj)) {<br>
+      /* OpenGL 4.5 core profile, 6.1, pdf page 82: "An INVALID_VALUE error is<br>
+       * generated by BindBufferRange if buffer is non-zero and size is less<br>
+       * than or equal to zero."<br>
+       *<br>
+       * OpenGL 4.5 core profile, 13.2, pdf page 445: "An INVALID_VALUE error<br>
+       * is generated by TransformFeedbackBufferRange if size is less than or<br>
+       * equal to zero."<br>
+       */<br>
+      _mesa_error(ctx, GL_INVALID_VALUE, "%s(size=%d must be > 0)",<br>
+                  gl_methd_name, (int) size);<br>
+      return;<br>
+   }<br>
<br>
-   bind_buffer_range(ctx, obj, index, bufObj, offset, size, false);<br>
+   bind_buffer_range(ctx, obj, index, bufObj, offset, size, dsa);<br>
 }<br>
<br>
<br>
</div></div><div><div class="h5">@@ -681,6 +721,30 @@ _mesa_TransformFeedbackBufferBase(GLuint xfb, GLuint index, GLuint buffer)<br>
    _mesa_bind_buffer_base_transform_feedback(ctx, obj, index, bufObj, true);<br>
 }<br>
<br>
+void GLAPIENTRY<br>
+_mesa_TransformFeedbackBufferRange(GLuint xfb, GLuint index, GLuint buffer,<br>
+                                   GLintptr offset, GLsizeiptr size)<br>
+{<br>
+   GET_CURRENT_CONTEXT(ctx);<br>
+   struct gl_transform_feedback_object *obj;<br>
+   struct gl_buffer_object *bufObj;<br>
+<br>
+   obj = lookup_transform_feedback_object_err(ctx, xfb,<br>
+                                              "glTransformFeedbackBufferRange");<br>
+   if(!obj) {<br>
+      return;<br>
+   }<br>
+<br>
+   bufObj = lookup_transform_feedback_bufferobj_err(ctx, buffer,<br>
+                                              "glTransformFeedbackBufferRange");<br>
+   if(!bufObj) {<br>
+      return;<br>
+   }<br>
+<br>
+   _mesa_bind_buffer_range_transform_feedback(ctx, obj, index, bufObj, offset,<br>
+                                              size, true);<br>
+}<br>
+<br>
 /**<br>
  * Specify a buffer object to receive transform feedback results, plus the<br>
  * offset in the buffer to start placing results.<br>
diff --git a/src/mesa/main/transformfeedback.h b/src/mesa/main/transformfeedback.h<br>
</div></div>index aac7433..9ec7d38 100644<br>
<span class="">--- a/src/mesa/main/transformfeedback.h<br>
+++ b/src/mesa/main/transformfeedback.h<br>
@@ -69,7 +69,7 @@ _mesa_bind_buffer_range_transform_feedback(struct gl_context *ctx,<br>
                                           GLuint index,<br>
                                           struct gl_buffer_object *bufObj,<br>
                                           GLintptr offset,<br>
-                                          GLsizeiptr size);<br>
+                                          GLsizeiptr size, bool dsa);<br>
<br>
 extern void<br>
 _mesa_bind_buffer_base_transform_feedback(struct gl_context *ctx,<br>
</span>@@ -152,4 +152,8 @@ _mesa_set_transform_feedback_binding(struct gl_context *ctx,<br>
<span class=""> extern void GLAPIENTRY<br>
 _mesa_TransformFeedbackBufferBase(GLuint xfb, GLuint index, GLuint buffer);<br>
<br>
+extern void GLAPIENTRY<br>
+_mesa_TransformFeedbackBufferRange(GLuint xfb, GLuint index, GLuint buffer,<br>
+                                   GLintptr offset, GLsizeiptr size);<br>
+<br>
 #endif /* TRANSFORM_FEEDBACK_H */<br>
--<br>
2.3.0<br>
<br></span></blockquote><div>With that little nit fixed,<br><br></div><div>Reviewed-by: Laura Ekstrand <<a href="mailto:laura@jlekstrand.net">laura@jlekstrand.net</a>> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
</span><a href="http://lists.freedesktop.org/mailman/listinfo/mesa-dev" target="_blank">http://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</blockquote></div><br></div></div>