From: Eric Anholt Date: Wed, 17 Apr 2013 00:21:21 +0000 (-0700) Subject: intel: Add support for blitting 6 byte-per-pixel formats. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=645b610b6228a00bdcef0748fdb5fcbd2f1fadb8;p=mesa.git intel: Add support for blitting 6 byte-per-pixel formats. The next commit introduces what is apparently our first one, which tripped over this in glReadPixels. Reviewed-by: Kenneth Graunke --- diff --git a/src/mesa/drivers/dri/intel/intel_blit.c b/src/mesa/drivers/dri/intel/intel_blit.c index 63378b6740a..f9cba85f1fb 100644 --- a/src/mesa/drivers/dri/intel/intel_blit.c +++ b/src/mesa/drivers/dri/intel/intel_blit.c @@ -151,15 +151,22 @@ intelEmitCopyBlit(struct intel_context *intel, if (src_pitch % 4 != 0 || dst_pitch % 4 != 0) return false; - /* For big formats (such as floating point), do the copy using 32bpp and - * multiply the coordinates. + /* For big formats (such as floating point), do the copy using 16 or 32bpp + * and multiply the coordinates. */ if (cpp > 4) { - assert(cpp % 4 == 0); - dst_x *= cpp / 4; - dst_x2 *= cpp / 4; - src_x *= cpp / 4; - cpp = 4; + if (cpp % 4 == 2) { + dst_x *= cpp / 2; + dst_x2 *= cpp / 2; + src_x *= cpp / 2; + cpp = 2; + } else { + assert(cpp % 4 == 0); + dst_x *= cpp / 4; + dst_x2 *= cpp / 4; + src_x *= cpp / 4; + cpp = 4; + } } BR13 = br13_for_cpp(cpp) | translate_raster_op(logic_op) << 16;