On 6/5/19 1:30 PM, Deucher, Alexander wrote: > Maybe add a reference to the bug report? > Acked-by: Alex Deucher <alexander.deucher@xxxxxxx> Oh right, I can add the bugzilla when this gets reviewed and I push. Thanks! Nicholas Kazlauskas > ------------------------------------------------------------------------ > *From:* amd-gfx <amd-gfx-bounces@xxxxxxxxxxxxxxxxxxxxx> on behalf of > Nicholas Kazlauskas <nicholas.kazlauskas@xxxxxxx> > *Sent:* Wednesday, June 5, 2019 12:33 PM > *To:* amd-gfx@xxxxxxxxxxxxxxxxxxxxx > *Cc:* Li, Sun peng (Leo); Wentland, Harry; Kazlauskas, Nicholas > *Subject:* [PATCH] drm/amd/display: Use current connector state if NULL > when checking bpc > [Why] > The old logic for checking which output depth to use relied on using > the current connector state rather than the new proposed state. This > was a problem when performing atomic commits since we weren't verifying > it against the incoming max_requested_bpc. > > But switching this to only use the new state and not the current state > breaks filtering modes - it'll always assume that the maximum bpc > supported by the display is in use, which will cause certain modes > like 1440p@144Hz to be filtered even when using 8bpc. > > [How] > Still use the connector->state if we aren't passed an explicit state. > This will respect the max_bpc the user currently has when filtering > modes. > > Also remember to reset the default max_requested_bpc to 8 whenever > connector reset is called to retain old behavior when using the new > property. > > Cc: Harry Wentland <harry.wentland@xxxxxxx> > Cc: Leo Li <sunpeng.li@xxxxxxx> > Signed-off-by: Nicholas Kazlauskas <nicholas.kazlauskas@xxxxxxx> > --- > drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 4 ++++ > 1 file changed, 4 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 a698c8f272ed..f627c17a1039 100644 > --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c > @@ -3046,6 +3046,9 @@ convert_color_depth_from_display_info(const struct > drm_connector *connector, > { > uint32_t bpc = connector->display_info.bpc; > > + if (!state) > + state = connector->state; > + > if (state) { > bpc = state->max_bpc; > /* Round down to the nearest even number. */ > @@ -3820,6 +3823,7 @@ void amdgpu_dm_connector_funcs_reset(struct > drm_connector *connector) > state->underscan_enable = false; > state->underscan_hborder = 0; > state->underscan_vborder = 0; > + state->base.max_requested_bpc = 8; > > __drm_atomic_helper_connector_reset(connector, > &state->base); > } > -- > 2.17.1 > > _______________________________________________ > amd-gfx mailing list > amd-gfx@xxxxxxxxxxxxxxxxxxxxx > https://lists.freedesktop.org/mailman/listinfo/amd-gfx _______________________________________________ amd-gfx mailing list amd-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/amd-gfx