diff options
author | Topi Pohjolainen <[email protected]> | 2017-06-08 11:24:51 +0300 |
---|---|---|
committer | Topi Pohjolainen <[email protected]> | 2017-06-19 22:18:53 +0300 |
commit | a5e1c9f1d5b6063f0a92634967475a05362c0d31 (patch) | |
tree | ba0316c107cb79126106a4338b9042ef90171427 /src/mesa/drivers/dri/i965/intel_fbo.h | |
parent | a9c59c10a52f9a6a3bad96e77d03a0021f414a58 (diff) |
i965/gen4: Add support for single layer in alignment workaround
On gen < 6 one doesn't have level or layer specifiers available
for render and depth targets. In order to support rendering to
specific level/layer, driver needs to manually offset the surface
to the desired slice.
There are, however, alignment restrictions to respect as well and
in come cases the only option is to use temporary single slice
surface which driver copies after rendering to the full miptree.
Current alignment workaround introduces new texture images which
are added to the parent texture object. Texture validation later
on copies the additional levels back to the surface that contains
the full mipmap.
This only works for non-arrayed surfaces and driver currently
creates new arrayed images in vain - individual layers within the
newly created are still unaligned the same as before.
This patch drops this mechanism and instead attaches single
temporary slice into the render buffer. This gets immediately
copied back to the mipmapped and/or arrayed surface just after
the render is done.
Sitting on top of earlier series cleaning up the depth buffer
state, this patch additionally fixes the following piglit tests:
arb_framebuffer_object.fbo-generatemipmap-cubemap.g965m64
arb_texture_cube_map.copyteximage cube.g965m64
arb_texture_cube_map.copyteximage cube.ilkm64
arb_pixel_buffer_object.texsubimage array pbo.g965m64
ext_framebuffer_object.fbo-cubemap.g965m64
ext_texture_array.copyteximage 1d_array.g45m64
ext_texture_array.copyteximage 1d_array.g965m64
ext_texture_array.copyteximage 1d_array.ilkm64
ext_texture_array.copyteximage 2d_array.g45m64
ext_texture_array.copyteximage 2d_array.g965m64
ext_texture_array.copyteximage 2d_array.ilkm64
ext_texture_array.fbo-array.g965m64
ext_texture_array.fbo-generatemipmap-array.g965m64
ext_texture_array.gen-mipmap.g965m64
Reviewed-by: Jason Ekstrand <[email protected]>
Signed-off-by: Topi Pohjolainen <[email protected]>
Diffstat (limited to 'src/mesa/drivers/dri/i965/intel_fbo.h')
-rw-r--r-- | src/mesa/drivers/dri/i965/intel_fbo.h | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/src/mesa/drivers/dri/i965/intel_fbo.h b/src/mesa/drivers/dri/i965/intel_fbo.h index 86811b4225e..56c8e6b3b20 100644 --- a/src/mesa/drivers/dri/i965/intel_fbo.h +++ b/src/mesa/drivers/dri/i965/intel_fbo.h @@ -67,6 +67,16 @@ struct intel_renderbuffer */ struct intel_mipmap_tree *singlesample_mt; + /* Gen < 6 doesn't have layer specifier for render targets or depth. Driver + * needs to manually offset surfaces to correct level/layer. There are, + * however, alignment restrictions to respect as well and in come cases + * the only option is to use temporary single slice surface which driver + * copies after rendering to the full miptree. + * + * See intel_renderbuffer_move_to_temp(). + */ + struct intel_mipmap_tree *align_wa_mt; + /** * \name Miptree view * \{ @@ -136,6 +146,14 @@ intel_renderbuffer(struct gl_renderbuffer *rb) return NULL; } +static inline struct intel_mipmap_tree * +intel_renderbuffer_get_mt(struct intel_renderbuffer *irb) +{ + if (!irb) + return NULL; + + return (irb->align_wa_mt) ? irb->align_wa_mt : irb->mt; +} /** * \brief Return the framebuffer attachment specified by attIndex. @@ -188,6 +206,12 @@ intel_renderbuffer_get_tile_offsets(struct intel_renderbuffer *irb, uint32_t *tile_x, uint32_t *tile_y) { + if (irb->align_wa_mt) { + *tile_x = 0; + *tile_y = 0; + return 0; + } + return intel_miptree_get_tile_offsets(irb->mt, irb->mt_level, irb->mt_layer, tile_x, tile_y); } |