diff options
author | Jason Ekstrand <[email protected]> | 2018-05-11 12:29:07 -0700 |
---|---|---|
committer | Jason Ekstrand <[email protected]> | 2018-05-22 15:46:34 -0700 |
commit | 33affda8bf6cbcff14d51f6d99635c8f41432cda (patch) | |
tree | 77198e204bb21b70a339c5e54b4cd2feda3583b3 /src/mesa/drivers | |
parent | 0eedb0fca92c4a77ff650e0b565ee254adb7daee (diff) |
i965/miptree: Use blorp for blit maps on gen6+
Reviewed-by: Topi Pohjolainen <[email protected]>
Reviewed-by: Kenneth Graunke <[email protected]>
Diffstat (limited to 'src/mesa/drivers')
-rw-r--r-- | src/mesa/drivers/dri/i965/intel_mipmap_tree.c | 36 |
1 files changed, 25 insertions, 11 deletions
diff --git a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c index 288d4806cbe..ff7a1c00b92 100644 --- a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c +++ b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c @@ -3087,16 +3087,23 @@ intel_miptree_unmap_blit(struct brw_context *brw, unsigned int level, unsigned int slice) { + const struct gen_device_info *devinfo = &brw->screen->devinfo; struct gl_context *ctx = &brw->ctx; intel_miptree_unmap_raw(map->linear_mt); if (map->mode & GL_MAP_WRITE_BIT) { - bool ok = intel_miptree_copy(brw, - map->linear_mt, 0, 0, 0, 0, - mt, level, slice, map->x, map->y, - map->w, map->h); - WARN_ONCE(!ok, "Failed to blit from linear temporary mapping"); + if (devinfo->gen >= 6) { + brw_blorp_copy_miptrees(brw, map->linear_mt, 0, 0, + mt, level, slice, + 0, 0, map->x, map->y, map->w, map->h); + } else { + bool ok = intel_miptree_copy(brw, + map->linear_mt, 0, 0, 0, 0, + mt, level, slice, map->x, map->y, + map->w, map->h); + WARN_ONCE(!ok, "Failed to blit from linear temporary mapping"); + } } intel_miptree_release(&map->linear_mt); @@ -3108,6 +3115,7 @@ intel_miptree_map_blit(struct brw_context *brw, struct intel_miptree_map *map, unsigned int level, unsigned int slice) { + const struct gen_device_info *devinfo = &brw->screen->devinfo; map->linear_mt = intel_miptree_create(brw, GL_TEXTURE_2D, mt->format, /* first_level */ 0, /* last_level */ 0, @@ -3127,12 +3135,18 @@ intel_miptree_map_blit(struct brw_context *brw, * temporary buffer back out. */ if (!(map->mode & GL_MAP_INVALIDATE_RANGE_BIT)) { - if (!intel_miptree_copy(brw, - mt, level, slice, map->x, map->y, - map->linear_mt, 0, 0, 0, 0, - map->w, map->h)) { - fprintf(stderr, "Failed to blit\n"); - goto fail; + if (devinfo->gen >= 6) { + brw_blorp_copy_miptrees(brw, mt, level, slice, + map->linear_mt, 0, 0, + map->x, map->y, 0, 0, map->w, map->h); + } else { + if (!intel_miptree_copy(brw, + mt, level, slice, map->x, map->y, + map->linear_mt, 0, 0, 0, 0, + map->w, map->h)) { + fprintf(stderr, "Failed to blit\n"); + goto fail; + } } } |