drm/nouveau: Fix nv50_mstc->best_encoder()
As mentioned in the previous commit, we currently prevent new modesets
on recently-removed MST connectors by returning no encoder from our
->best_encoder() callback once the MST port has disappeared. This is
wrong however, because it prevents legacy modesetting users from being
able to disable CRTCs on MST connectors after the connector's respective
topology has disappeared.
So, fix this by instead by just always returning a valid encoder.
Changes since v2:
- Remove usage of atomic MST helper for now, since that got replaced
with a much simpler solution
Signed-off-by: Lyude Paul <lyude@redhat.com>
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Reviewed-by: Ben Skeggs <bskeggs@redhat.com>
Cc: stable@vger.kernel.org
Link: https://patchwork.freedesktop.org/patch/msgid/20181008232437.5571-3-lyude@redhat.com
(cherry picked from commit e87b0bbc9f
)
Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
This commit is contained in:
parent
de9f8eea5a
commit
7b0f61e91b
|
@ -881,22 +881,16 @@ nv50_mstc_atomic_best_encoder(struct drm_connector *connector,
|
||||||
{
|
{
|
||||||
struct nv50_head *head = nv50_head(connector_state->crtc);
|
struct nv50_head *head = nv50_head(connector_state->crtc);
|
||||||
struct nv50_mstc *mstc = nv50_mstc(connector);
|
struct nv50_mstc *mstc = nv50_mstc(connector);
|
||||||
if (mstc->port) {
|
|
||||||
struct nv50_mstm *mstm = mstc->mstm;
|
return &mstc->mstm->msto[head->base.index]->encoder;
|
||||||
return &mstm->msto[head->base.index]->encoder;
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct drm_encoder *
|
static struct drm_encoder *
|
||||||
nv50_mstc_best_encoder(struct drm_connector *connector)
|
nv50_mstc_best_encoder(struct drm_connector *connector)
|
||||||
{
|
{
|
||||||
struct nv50_mstc *mstc = nv50_mstc(connector);
|
struct nv50_mstc *mstc = nv50_mstc(connector);
|
||||||
if (mstc->port) {
|
|
||||||
struct nv50_mstm *mstm = mstc->mstm;
|
return &mstc->mstm->msto[0]->encoder;
|
||||||
return &mstm->msto[0]->encoder;
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static enum drm_mode_status
|
static enum drm_mode_status
|
||||||
|
|
Loading…
Reference in New Issue