i965: Export format comparison for blitting between miptrees
Since the introduction of commit 536003c11e4cb1172c540932ce3cce06f03bf44e Author: Boyan Ding <boyan.j.ding@gmail.com> Date: Wed Mar 25 19:36:54 2015 +0800 i965: Add XRGB8888 format to intel_screen_make_configs winsys buffers no longer have an alpha channel. This causes _mesa_format_matches_format_and_type() to reject previously working BGRA uploads from using the BLT fast path. Instead of using the generic routine for matching formats exactly, export the slightly more relaxed check from intel_miptree_blit() which importantly allows the blitter routine to apply a small number of format conversions. References: https://bugs.freedesktop.org/show_bug.cgi?id=90839 Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Jason Ekstrand <jason@jlekstrand.net> Cc: Alexander Monakov <amonakov@gmail.com> Cc: Kristian Høgsberg <krh@bitplanet.net> Cc: Kenneth Graunke <kenneth@whitecape.org> Reviewed-by: Kenneth Graunke <kenneth@whitecape.org> Cc: mesa-stable@lists.freedesktop.org
This commit is contained in:
@@ -139,8 +139,8 @@ blt_pitch(struct intel_mipmap_tree *mt)
|
|||||||
return pitch;
|
return pitch;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
bool
|
||||||
blt_compatible_formats(mesa_format src, mesa_format dst)
|
intel_miptree_blit_compatible_formats(mesa_format src, mesa_format dst)
|
||||||
{
|
{
|
||||||
/* The BLT doesn't handle sRGB conversion */
|
/* The BLT doesn't handle sRGB conversion */
|
||||||
assert(src == _mesa_get_srgb_format_linear(src));
|
assert(src == _mesa_get_srgb_format_linear(src));
|
||||||
@@ -206,7 +206,7 @@ intel_miptree_blit(struct brw_context *brw,
|
|||||||
* the X channel don't matter), and XRGB8888 to ARGB8888 by setting the A
|
* the X channel don't matter), and XRGB8888 to ARGB8888 by setting the A
|
||||||
* channel to 1.0 at the end.
|
* channel to 1.0 at the end.
|
||||||
*/
|
*/
|
||||||
if (!blt_compatible_formats(src_format, dst_format)) {
|
if (!intel_miptree_blit_compatible_formats(src_format, dst_format)) {
|
||||||
perf_debug("%s: Can't use hardware blitter from %s to %s, "
|
perf_debug("%s: Can't use hardware blitter from %s to %s, "
|
||||||
"falling back.\n", __func__,
|
"falling back.\n", __func__,
|
||||||
_mesa_get_format_name(src_format),
|
_mesa_get_format_name(src_format),
|
||||||
|
@@ -46,6 +46,8 @@ intelEmitCopyBlit(struct brw_context *brw,
|
|||||||
GLshort w, GLshort h,
|
GLshort w, GLshort h,
|
||||||
GLenum logicop );
|
GLenum logicop );
|
||||||
|
|
||||||
|
bool intel_miptree_blit_compatible_formats(mesa_format src, mesa_format dst);
|
||||||
|
|
||||||
bool intel_miptree_blit(struct brw_context *brw,
|
bool intel_miptree_blit(struct brw_context *brw,
|
||||||
struct intel_mipmap_tree *src_mt,
|
struct intel_mipmap_tree *src_mt,
|
||||||
int src_level, int src_slice,
|
int src_level, int src_slice,
|
||||||
|
@@ -28,6 +28,7 @@
|
|||||||
#include "main/glheader.h"
|
#include "main/glheader.h"
|
||||||
#include "main/enums.h"
|
#include "main/enums.h"
|
||||||
#include "main/image.h"
|
#include "main/image.h"
|
||||||
|
#include "main/glformats.h"
|
||||||
#include "main/mtypes.h"
|
#include "main/mtypes.h"
|
||||||
#include "main/condrender.h"
|
#include "main/condrender.h"
|
||||||
#include "main/fbobject.h"
|
#include "main/fbobject.h"
|
||||||
@@ -76,8 +77,14 @@ do_blit_drawpixels(struct gl_context * ctx,
|
|||||||
struct gl_renderbuffer *rb = ctx->DrawBuffer->_ColorDrawBuffers[0];
|
struct gl_renderbuffer *rb = ctx->DrawBuffer->_ColorDrawBuffers[0];
|
||||||
struct intel_renderbuffer *irb = intel_renderbuffer(rb);
|
struct intel_renderbuffer *irb = intel_renderbuffer(rb);
|
||||||
|
|
||||||
if (!_mesa_format_matches_format_and_type(irb->mt->format, format, type,
|
mesa_format src_format = _mesa_format_from_format_and_type(format, type);
|
||||||
false)) {
|
mesa_format dst_format = irb->mt->format;
|
||||||
|
|
||||||
|
/* We can safely discard sRGB encode/decode for the DrawPixels interface */
|
||||||
|
src_format = _mesa_get_srgb_format_linear(src_format);
|
||||||
|
dst_format = _mesa_get_srgb_format_linear(dst_format);
|
||||||
|
|
||||||
|
if (!intel_miptree_blit_compatible_formats(src_format, dst_format)) {
|
||||||
DBG("%s: bad format for blit\n", __func__);
|
DBG("%s: bad format for blit\n", __func__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user