<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Dec 9, 2014 at 4:07 AM, Iago Toral Quiroga <span dir="ltr"><<a href="mailto:itoral@igalia.com" target="_blank">itoral@igalia.com</a>></span> wrote:<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This is the only place that uses _mesa_unpack_color_span_float so after<br>
this we should be able to remove that function.<br>
---<br>
 src/mesa/swrast/s_drawpix.c | 39 +++++++++++++++++++++++++++++++++++----<br>
 1 file changed, 35 insertions(+), 4 deletions(-)<br>
<br>
diff --git a/src/mesa/swrast/s_drawpix.c b/src/mesa/swrast/s_drawpix.c<br>
index 227faa2..dcf5581 100644<br>
--- a/src/mesa/swrast/s_drawpix.c<br>
+++ b/src/mesa/swrast/s_drawpix.c<br>
@@ -29,6 +29,8 @@<br>
 #include "main/condrender.h"<br>
 #include "main/context.h"<br>
 #include "main/format_pack.h"<br>
+#include "main/format_utils.h"<br>
+#include "main/glformats.h"<br>
 #include "main/image.h"<br>
 #include "main/imports.h"<br>
 #include "main/macros.h"<br>
@@ -451,6 +453,28 @@ draw_rgba_pixels( struct gl_context *ctx, GLint x, GLint y,<br>
  Â  Â  Â GLint skipPixels = 0;<br>
  Â  Â  Â /* use span array for temp color storage */<br>
  Â  Â  Â GLfloat *rgba = (GLfloat *) span.array->attribs[VARYING_SLOT_COL0];<br>
+  Â  Â  void *tempImage = NULL;<br>
+<br>
+  Â  Â  if (unpack->SwapBytes) {<br>
+  Â  Â  Â  Â /* We have to handle byte-swapping scenarios before calling<br>
+  Â  Â  Â  Â  * _mesa_format_convert<br>
+  Â  Â  Â  Â  */<br>
+  Â  Â  Â  Â GLint swapSize = _mesa_sizeof_packed_type(type);<br>
+  Â  Â  Â  Â if (swapSize == 2 || swapSize == 4) {<br>
+  Â  Â  Â  Â  Â  int components = _mesa_components_in_format(format);<br>
+  Â  Â  Â  Â  Â  int elementCount = width * height * components;<br>
+  Â  Â  Â  Â  Â  tempImage = malloc(elementCount * swapSize);<br>
+  Â  Â  Â  Â  Â  if (!tempImage) {<br>
+  Â  Â  Â  Â  Â  Â  Â _mesa_error(ctx, GL_OUT_OF_MEMORY, "glDrawPixels");<br>
+  Â  Â  Â  Â  Â  Â  Â return;<br>
+  Â  Â  Â  Â  Â  }<br>
+  Â  Â  Â  Â  Â  if (swapSize == 2)<br>
+  Â  Â  Â  Â  Â  Â  Â _mesa_swap2_copy(tempImage, (GLushort *) pixels, elementCount);<br>
+  Â  Â  Â  Â  Â  else<br>
+  Â  Â  Â  Â  Â  Â  Â _mesa_swap4_copy(tempImage, (GLuint *) pixels, elementCount);<br>
+  Â  Â  Â  Â  Â  pixels = tempImage;<br>
+  Â  Â  Â  Â }<br>
+  Â  Â  }<br>
<br>
  Â  Â  Â /* if the span is wider than SWRAST_MAX_WIDTH we have to do it in chunks */<br>
  Â  Â  Â while (skipPixels < width) {<br>
@@ -461,11 +485,15 @@ draw_rgba_pixels( struct gl_context *ctx, GLint x, GLint y,<br>
  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â type, 0, skipPixels);<br>
  Â  Â  Â  Â  GLint row;<br>
<br>
+  Â  Â  Â  Â /* get image row as float/RGBA */<br>
+  Â  Â  Â  Â uint32_t srcMesaFormat = _mesa_format_from_format_and_type(format, type);<br>
  Â  Â  Â  Â  for (row = 0; row < height; row++) {<br>
-  Â  Â  Â  Â  Â  /* get image row as float/RGBA */<br>
-  Â  Â  Â  Â  Â  _mesa_unpack_color_span_float(ctx, spanWidth, GL_RGBA, rgba,<br>
-  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â format, type, source, unpack,<br>
-  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â transferOps);<br>
+  Â  Â  Â  Â  Â  int dstRowStride = 4 * width * sizeof(float);<br>
+  Â  Â  Â  Â  Â  _mesa_format_convert(rgba, RGBA8888_FLOAT, dstRowStride,<br>
+  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â (void*)source, srcMesaFormat, srcStride,<br>
+  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â  Â spanWidth, 1, NULL);<br>
+  Â  Â  Â  Â  Â  if (transferOps)<br>
+  Â  Â  Â  Â  Â  Â  Â _mesa_apply_rgba_transfer_ops(ctx, transferOps, spanWidth, (GLfloat (*)[4])rgba);<br>
  Â  Â  Â  Â  Â  /* Set these for each row since the _swrast_write_* functions<br>
  Â  Â  Â  Â  Â  Â * may change them while clipping/rendering.<br>
  Â  Â  Â  Â  Â  Â */<br>
@@ -490,6 +518,9 @@ draw_rgba_pixels( struct gl_context *ctx, GLint x, GLint y,<br>
<br>
  Â  Â  Â /* XXX this is ugly/temporary, to undo above change */<br>
  Â  Â  Â span.array->ChanType = CHAN_TYPE;<br>
+<br>
+  Â  Â  if (tempImage)<br>
+  Â  Â  Â  Â free(tempImage);<br></blockquote><div><br></div><div>You don't need the if.  Otherwise, It looks fine.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  Â  }<br>
<br>
  Â  swrast_render_finish(ctx);<br>
<span class="HOEnZb"><font color="#888888">--<br>
1.9.1<br>
<br>
_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/mesa-dev" target="_blank">http://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</font></span></blockquote></div></div></div>