<div dir="ltr">Reviewed-by: Jason Ekstrand <<a href="mailto:jason@jlekstrand.net">jason@jlekstrand.net</a>><br></div><br><div class="gmail_quote"><div dir="ltr">On Mon, Sep 17, 2018 at 3:52 PM Fritz Koenig <<a href="mailto:frkoenig@google.com">frkoenig@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">In the GL_MESA_framebuffer_flip_y implementation<br>
_mesa_is_winsys_fbo checks were replaced with<br>
FlipY checks.  rb->Name is also used to determine<br>
if a buffer is winsys.<br>
<br>
v2: Fixes annotation [for emil]<br>
<br>
Fixes: ab05dd183cc ("i965: implement GL_MESA_framebuffer_flip_y [v3]")<br>
---<br>
 src/mesa/drivers/dri/i965/brw_blorp.c        | 20 +++++++++-----------<br>
 src/mesa/drivers/dri/i965/intel_pixel_read.c |  4 ++--<br>
 2 files changed, 11 insertions(+), 13 deletions(-)<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/brw_blorp.c b/src/mesa/drivers/dri/i965/brw_blorp.c<br>
index ad747e0766..ad3a47ef03 100644<br>
--- a/src/mesa/drivers/dri/i965/brw_blorp.c<br>
+++ b/src/mesa/drivers/dri/i965/brw_blorp.c<br>
@@ -1224,12 +1224,12 @@ do_single_blorp_clear(struct brw_context *brw, struct gl_framebuffer *fb,<br>
<br>
    x0 = fb->_Xmin;<br>
    x1 = fb->_Xmax;<br>
-   if (rb->Name != 0) {<br>
-      y0 = fb->_Ymin;<br>
-      y1 = fb->_Ymax;<br>
-   } else {<br>
+   if (fb->FlipY) {<br>
       y0 = rb->Height - fb->_Ymax;<br>
       y1 = rb->Height - fb->_Ymin;<br>
+   } else {<br>
+      y0 = fb->_Ymin;<br>
+      y1 = fb->_Ymax;<br>
    }<br>
<br>
    /* If the clear region is empty, just return. */<br>
@@ -1415,9 +1415,8 @@ brw_blorp_clear_depth_stencil(struct brw_context *brw,<br>
    if (!(mask & (BUFFER_BITS_DEPTH_STENCIL)))<br>
       return;<br>
<br>
-   uint32_t x0, x1, y0, y1, rb_name, rb_height;<br>
+   uint32_t x0, x1, y0, y1, rb_height;<br>
    if (depth_rb) {<br>
-      rb_name = depth_rb->Name;<br>
       rb_height = depth_rb->Height;<br>
       if (stencil_rb) {<br>
          assert(depth_rb->Width == stencil_rb->Width);<br>
@@ -1425,18 +1424,17 @@ brw_blorp_clear_depth_stencil(struct brw_context *brw,<br>
       }<br>
    } else {<br>
       assert(stencil_rb);<br>
-      rb_name = stencil_rb->Name;<br>
       rb_height = stencil_rb->Height;<br>
    }<br>
<br>
    x0 = fb->_Xmin;<br>
    x1 = fb->_Xmax;<br>
-   if (rb_name != 0) {<br>
-      y0 = fb->_Ymin;<br>
-      y1 = fb->_Ymax;<br>
-   } else {<br>
+   if (fb->FlipY) {<br>
       y0 = rb_height - fb->_Ymax;<br>
       y1 = rb_height - fb->_Ymin;<br>
+   } else {<br>
+      y0 = fb->_Ymin;<br>
+      y1 = fb->_Ymax;<br>
    }<br>
<br>
    /* If the clear region is empty, just return. */<br>
diff --git a/src/mesa/drivers/dri/i965/intel_pixel_read.c b/src/mesa/drivers/dri/i965/intel_pixel_read.c<br>
index 6ed7895bc7..8a90b207ad 100644<br>
--- a/src/mesa/drivers/dri/i965/intel_pixel_read.c<br>
+++ b/src/mesa/drivers/dri/i965/intel_pixel_read.c<br>
@@ -181,7 +181,7 @@ intel_readpixels_tiled_memcpy(struct gl_context * ctx,<br>
     * tiled_to_linear a negative pitch so that it walks through the<br>
     * client's data backwards as it walks through the renderbufer forwards.<br>
     */<br>
-   if (rb->Name == 0) {<br>
+   if (ctx->ReadBuffer->FlipY) {<br>
       yoffset = rb->Height - yoffset - height;<br>
       pixels += (ptrdiff_t) (height - 1) * dst_pitch;<br>
       dst_pitch = -dst_pitch;<br>
@@ -249,7 +249,7 @@ intel_readpixels_blorp(struct gl_context *ctx,<br>
    return brw_blorp_download_miptree(brw, irb->mt, rb->Format, swizzle,<br>
                                      irb->mt_level, x, y, irb->mt_layer,<br>
                                      w, h, 1, GL_TEXTURE_2D, format, type,<br>
-                                     rb->Name == 0, pixels, packing);<br>
+                                     ctx->ReadBuffer->FlipY, pixels, packing);<br>
 }<br>
<br>
 void<br>
-- <br>
2.19.0.397.gdd90340f6a-goog<br>
<br>
_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org" target="_blank">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</blockquote></div>