On 2023-09-13 12:43, Melissa Wen wrote:
> Hi,
> 
> This is an update of previous RFC [0] improving the data collection of
> Gamma Correction and Blend Gamma color blocks.
> 
> As I mentioned in the last version, I'm updating the color state part of
> DTN log to match DCN3.0 HW better. Currently, the DTN log considers the
> DCN10 color pipeline, which is useless for DCN3.0 because of all the
> differences in color caps between DCN versions. In addition to new color
> blocks and caps, some semantic differences made the DCN10 output not fit
> DCN30.
> 
> In this RFC, the first patch adds new color state elements to DPP and
> implements the reading of registers according to HW blocks. Similarly to
> MPC, the second patch also creates a DCN3-specific function to read the
> MPC state and add the MPC color state logging to it. With DPP and MPC
> color-register reading, I detach DCN10 color state logging from the HW
> log and create a `.log_color_state` hook for logging color state
> according to HW color blocks with DCN30 as the first use case. Finally,
> the last patch adds DPP and MPC color caps output to facilitate
> understanding of the color state log.
> 
> This version works well with the driver-specific color properties[1] and
> steamdeck/gamescope[2] together, where we can see color state changing
> from default values.
> 
> Here is a before vs. after example:
> 
> Without this series:
> ===================
> DPP:    IGAM format  IGAM mode    DGAM mode    RGAM mode  GAMUT mode  C11 C12 
>   C13 C14   C21 C22   C23 C24   C31 C32   C33 C34
> [ 0]:            0h  BypassFixed  Bypass       Bypass            0    
> 00000000h 00000000h 00000000h 00000000h 00000000h 00000000h
> [ 3]:            0h  BypassFixed  Bypass       Bypass            0    
> 00000000h 00000000h 00000000h 00000000h 00000000h 00000000h
> 
> MPCC:  OPP  DPP  MPCCBOT  MODE  ALPHA_MODE  PREMULT  OVERLAP_ONLY  IDLE
> [ 0]:   0h   0h       3h     3           2        0             0     0
> [ 3]:   0h   3h       fh     2           2        0             0     0
> 
> With this series (Steamdeck/Gamescope):
> ======================================
> 
> DPP:  DGAM ROM  DGAM ROM type  DGAM LUT  SHAPER mode  3DLUT mode  3DLUT bit 
> depth  3DLUT size  RGAM mode  GAMUT mode  C11 C12   C13 C14   C21 C22   C23 
> C24   C31 C32   C33 C34
> [ 0]:        1           sRGB    Bypass        RAM A       RAM B           
> 12-bit    17x17x17      RAM A           0  00000000h 00000000h 00000000h 
> 00000000h 00000000h 00000000h
> [ 1]:        1           sRGB    Bypass        RAM B       RAM A           
> 12-bit    17x17x17      RAM A           0  00000000h 00000000h 00000000h 
> 00000000h 00000000h 00000000h
> [ 2]:        1           sRGB    Bypass        RAM B       RAM A           
> 12-bit    17x17x17      RAM A           0  00000000h 00000000h 00000000h 
> 00000000h 00000000h 00000000h
> [ 3]:        1           sRGB    Bypass        RAM A       RAM B           
> 12-bit    17x17x17      RAM A           0  00000000h 00000000h 00000000h 
> 00000000h 00000000h 00000000h
> 
> DPP Color Caps: input_lut_shared:0  icsc:1  dgam_ram:0  dgam_rom: 
> srgb:1,bt2020:1,gamma2_2:1,pq:1,hlg:1  post_csc:1  gamcor:1  
> dgam_rom_for_yuv:0  3d_lut:1  blnd_lut:1  oscs:0
> 
> MPCC:  OPP  DPP  MPCCBOT  MODE  ALPHA_MODE  PREMULT  OVERLAP_ONLY  IDLE  
> SHAPER mode  3DLUT_mode  3DLUT bit-depth  3DLUT size  OGAM mode  OGAM LUT  
> GAMUT mode  C11 C12   C33 C34
> [ 0]:   0h   0h       2h     3           0        1             0     0       
> Bypass      Bypass           12-bit    17x17x17        RAM         A          
>  0 00000000h 00000000h
> [ 1]:   0h   1h       fh     2           2        0             0     0       
> Bypass      Bypass           12-bit    17x17x17     Bypass         A          
>  0 00000000h 00000000h
> [ 2]:   0h   2h       3h     3           0        1             0     0       
> Bypass      Bypass           12-bit    17x17x17     Bypass         A          
>  0 00000000h 00000000h
> [ 3]:   0h   3h       1h     3           2        0             0     0       
> Bypass      Bypass           12-bit    17x17x17     Bypass         A          
>  0 00000000h 00000000h
> 
> MPC Color Caps: gamut_remap:1, 3dlut:2, ogam_ram:1, ocsc:1
> 
> With this series (Steamdeck/KDE):
> ================================
> 
> DPP:  DGAM ROM  DGAM ROM type  DGAM LUT  SHAPER mode  3DLUT mode  3DLUT bit 
> depth  3DLUT size  RGAM mode  GAMUT mode  C11 C12   C13 C14   C21 C22   C23 
> C24   C31 C32   C33 C34
> [ 0]:        0           sRGB    Bypass       Bypass      Bypass           
> 12-bit       9x9x9     Bypass           0  00000000h 00000000h 00000000h 
> 00000000h 00000000h 00000000h
> [ 3]:        0           sRGB    Bypass       Bypass      Bypass           
> 12-bit       9x9x9     Bypass           0  00000000h 00000000h 00000000h 
> 00000000h 00000000h 00000000h
> 
> DPP Color Caps: input_lut_shared:0  icsc:1  dgam_ram:0  dgam_rom: 
> srgb:1,bt2020:1,gamma2_2:1,pq:1,hlg:1  post_csc:1  gamcor:1  
> dgam_rom_for_yuv:0  3d_lut:1  blnd_lut:1  oscs:0
> 
> MPCC:  OPP  DPP  MPCCBOT  MODE  ALPHA_MODE  PREMULT  OVERLAP_ONLY  IDLE  
> SHAPER mode  3DLUT_mode  3DLUT bit-depth  3DLUT size  OGAM mode  OGAM LUT  
> GAMUT mode  C11 C12   C33 C34
> [ 0]:   0h   0h       3h     3           2        0             0     0       
> Bypass      Bypass           12-bit    17x17x17        RAM         A          
>  1 00002000h 00002000h
> [ 3]:   0h   3h       fh     2           2        0             0     0       
> Bypass      Bypass           12-bit    17x17x17     Bypass         A          
>  0 00000000h 00000000h
> 
> MPC Color Caps: gamut_remap:1, 3dlut:2, ogam_ram:1, ocsc:1
> 
> Before extending it to other DCN families, I have some doubts.
> - Does this approach of the `.log_color_state` hook make sense for you?

Yes

> - Is there any conflict between logging color state by HW version and
>   DTN log usage?
> - Is there a template/style for DTN log output that I should follow or
>   information that I should include?
> 

At this point it looks like we only use the DTN log for debug purposes,
so no conflict and no need to follow a specific format, as long as the
output is human-parseable (which yours is).

At one point in the past these were used by automated tests on other
platforms but that's no longer the case.

Harry

> Let me know your thoughts.
> 
> Thanks,
> 
> Melissa
> 
> [0] https://lore.kernel.org/amd-gfx/20230905142545.451153-1-m...@igalia.com/
> [1] https://lore.kernel.org/amd-gfx/20230810160314.48225-1-m...@igalia.com/
> [2] https://github.com/ValveSoftware/gamescope
> 
> Melissa Wen (5):
>   drm/amd/display: detach color state from hw state logging
>   drm/amd/display: fill up DCN3 DPP color state
>   drm/amd/display: create DCN3-specific log for MPC state
>   drm/amd/display: hook DCN30 color state logging to DTN log
>   drm/amd/display: add DPP and MPC color caps to DTN log
> 
>  .../amd/display/dc/dcn10/dcn10_hw_sequencer.c |  53 +++++++--
>  .../gpu/drm/amd/display/dc/dcn30/dcn30_dpp.c  |  45 ++++++-
>  .../drm/amd/display/dc/dcn30/dcn30_hwseq.c    | 111 ++++++++++++++++++
>  .../drm/amd/display/dc/dcn30/dcn30_hwseq.h    |   3 +
>  .../gpu/drm/amd/display/dc/dcn30/dcn30_init.c |   1 +
>  .../gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c  |  55 ++++++++-
>  .../drm/amd/display/dc/dcn301/dcn301_init.c   |   1 +
>  drivers/gpu/drm/amd/display/dc/inc/hw/dpp.h   |   8 ++
>  drivers/gpu/drm/amd/display/dc/inc/hw/mpc.h   |  13 ++
>  .../gpu/drm/amd/display/dc/inc/hw_sequencer.h |   2 +
>  10 files changed, 280 insertions(+), 12 deletions(-)
> 

Reply via email to