summaryrefslogtreecommitdiffstats
path: root/src/gallium/drivers/freedreno
diff options
context:
space:
mode:
Diffstat (limited to 'src/gallium/drivers/freedreno')
-rw-r--r--src/gallium/drivers/freedreno/a6xx/fd6_blitter.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/gallium/drivers/freedreno/a6xx/fd6_blitter.c b/src/gallium/drivers/freedreno/a6xx/fd6_blitter.c
index 13a5e4afb43..456aedd29d3 100644
--- a/src/gallium/drivers/freedreno/a6xx/fd6_blitter.c
+++ b/src/gallium/drivers/freedreno/a6xx/fd6_blitter.c
@@ -52,6 +52,19 @@ ok_dims(const struct pipe_resource *r, const struct pipe_box *b, int lvl)
(b->z >= 0) && (b->z + b->depth <= last_layer);
}
+static bool
+ok_format(enum pipe_format pfmt)
+{
+ enum a6xx_color_fmt fmt = fd6_pipe2color(pfmt);
+ if (fmt == ~0)
+ return false;
+
+ if (fd6_ifmt(fmt) == 0)
+ return false;
+
+ return true;
+}
+
#define DEBUG_BLIT_FALLBACK 0
#define fail_if(cond) \
do { \
@@ -81,6 +94,10 @@ can_do_blit(const struct pipe_blit_info *info)
fail_if(util_format_is_compressed(info->src.format) !=
util_format_is_compressed(info->src.format));
+ /* Fail if unsupported format: */
+ fail_if(!ok_format(info->src.format));
+ fail_if(!ok_format(info->dst.format));
+
/* ... but only if they're the same compression format. */
fail_if(util_format_is_compressed(info->src.format) &&
info->src.format != info->dst.format);