• Lyude Paul's avatar
    drm/nouveau/kms/gv100-: Re-set LUT after clearing for modesets · f287d3d1
    Lyude Paul authored
    While certain modeset operations on gv100+ need us to temporarily
    disable the LUT, we make the mistake of sometimes neglecting to
    reprogram the LUT after such modesets. In particular, moving a head from
    one encoder to another seems to trigger this quite often. GV100+ is very
    picky about having a LUT in most scenarios, so this causes the display
    engine to hang with the following error code:
    
    disp: chid 1 stat 00005080 reason 5 [INVALID_STATE] mthd 0200 data
    00000001 code 0000002d)
    
    So, fix this by always re-programming the LUT if we're clearing it in a
    state where the wndw is still visible, and has a XLUT handle programmed.
    Signed-off-by: default avatarLyude Paul <lyude@redhat.com>
    Fixes: facaed62 ("drm/nouveau/kms/gv100: initial support")
    Cc: <stable@vger.kernel.org> # v4.18+
    Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
    f287d3d1
wndw.c 19.9 KB