Ah, I forgot about 4K. It looks good. Thanks! Marek
On Wed, Sep 15, 2021 at 8:23 PM Joshua Ashton <jos...@froggi.es> wrote: > > > On 9/16/21 01:11, Marek Olšák wrote: > > Based on the discussions we had about displayable DCC internally, only > > MAX_COMPRESSED_BLOCK = 64B with both DCC_INDEPENDENT_64B_BLOCKS and > > DCC_INDEPENDENT_128B_BLOCKS is supported by DCN on RDNA 2. > > > From my testing: > > It works fine when setting PRIMARY_SURFACE_DCC_IND_BLK to 2 > (hubp_ind_block_128b) with 128b blocks alone. > > Previously, PRIMARY_SURFACE_DCC_IND_BLK would only ever be 1 or 0, and > both of these values do not work for 128b. > > This change has been tested with both Gamescope compositing and for Doom > Eternal. > > I have validated that the modifiers are in use in both of these > scenarios and the register values were found and tested with > > sudo umr -O bits -r vangogh.dcn301.mmHUBPREQ0_DCSURF_SURFACE_CONTROL > > - Joshie 🐸✨ > > > > Is there something new on the hardware side that I missed? > > > > Marek > > > > On Tue, Sep 14, 2021 at 7:59 PM Joshua Ashton <jos...@froggi.es > > <mailto:jos...@froggi.es>> wrote: > > > > Some games, ie. Doom Eternal, present from compute following compute > > post-fx and would benefit from having DCC image stores available. > > > > DCN on gfx10_3 doesn't need INDEPENDENT_128B_BLOCKS = 0 so we can > expose > > these modifiers capable of DCC image stores. > > > > Signed-off-by: Joshua Ashton <jos...@froggi.es > > <mailto:jos...@froggi.es>> > > Reviewed-by: Bas Nieuwenhuizen <b...@basnieuwenhuizen.nl > > <mailto:b...@basnieuwenhuizen.nl>> > > --- > > .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 21 > +++++++++++++++++++ > > 1 file changed, 21 insertions(+) > > > > diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > index 2a24e43623cb..a4e33a4336a0 100644 > > --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > > @@ -4817,6 +4817,16 @@ add_gfx10_3_modifiers(const struct > > amdgpu_device *adev, > > AMD_FMT_MOD_SET(DCC_INDEPENDENT_128B, 1) | > > AMD_FMT_MOD_SET(DCC_MAX_COMPRESSED_BLOCK, > > AMD_FMT_MOD_DCC_BLOCK_64B)); > > > > + add_modifier(mods, size, capacity, AMD_FMT_MOD | > > + AMD_FMT_MOD_SET(TILE, > > AMD_FMT_MOD_TILE_GFX9_64K_R_X) | > > + AMD_FMT_MOD_SET(TILE_VERSION, > > AMD_FMT_MOD_TILE_VER_GFX10_RBPLUS) | > > + AMD_FMT_MOD_SET(PIPE_XOR_BITS, pipe_xor_bits) | > > + AMD_FMT_MOD_SET(PACKERS, pkrs) | > > + AMD_FMT_MOD_SET(DCC, 1) | > > + AMD_FMT_MOD_SET(DCC_CONSTANT_ENCODE, 1) | > > + AMD_FMT_MOD_SET(DCC_INDEPENDENT_128B, 1) | > > + AMD_FMT_MOD_SET(DCC_MAX_COMPRESSED_BLOCK, > > AMD_FMT_MOD_DCC_BLOCK_128B)); > > + > > add_modifier(mods, size, capacity, AMD_FMT_MOD | > > AMD_FMT_MOD_SET(TILE, > > AMD_FMT_MOD_TILE_GFX9_64K_R_X) | > > AMD_FMT_MOD_SET(TILE_VERSION, > > AMD_FMT_MOD_TILE_VER_GFX10_RBPLUS) | > > @@ -4829,6 +4839,17 @@ add_gfx10_3_modifiers(const struct > > amdgpu_device *adev, > > AMD_FMT_MOD_SET(DCC_INDEPENDENT_128B, 1) | > > AMD_FMT_MOD_SET(DCC_MAX_COMPRESSED_BLOCK, > > AMD_FMT_MOD_DCC_BLOCK_64B)); > > > > + add_modifier(mods, size, capacity, AMD_FMT_MOD | > > + AMD_FMT_MOD_SET(TILE, > > AMD_FMT_MOD_TILE_GFX9_64K_R_X) | > > + AMD_FMT_MOD_SET(TILE_VERSION, > > AMD_FMT_MOD_TILE_VER_GFX10_RBPLUS) | > > + AMD_FMT_MOD_SET(PIPE_XOR_BITS, pipe_xor_bits) | > > + AMD_FMT_MOD_SET(PACKERS, pkrs) | > > + AMD_FMT_MOD_SET(DCC, 1) | > > + AMD_FMT_MOD_SET(DCC_RETILE, 1) | > > + AMD_FMT_MOD_SET(DCC_CONSTANT_ENCODE, 1) | > > + AMD_FMT_MOD_SET(DCC_INDEPENDENT_128B, 1) | > > + AMD_FMT_MOD_SET(DCC_MAX_COMPRESSED_BLOCK, > > AMD_FMT_MOD_DCC_BLOCK_128B)); > > + > > add_modifier(mods, size, capacity, AMD_FMT_MOD | > > AMD_FMT_MOD_SET(TILE, > > AMD_FMT_MOD_TILE_GFX9_64K_R_X) | > > AMD_FMT_MOD_SET(TILE_VERSION, > > AMD_FMT_MOD_TILE_VER_GFX10_RBPLUS) | > > -- > > 2.33.0 > > >