disp: msm: sde: skip RM reserve for primary in cwb on/off usecase

Add changes to skip RM allocation during atomic_check for dsi connectors
which can have a seamless transition during CWB usecase. When CWB gets
enabled in alternate commits N, N+2 on dsi connectors there is back to
back connectors_changed modeset and poll gets enabled for the
consecutive commit N+1, N+3 on rsvp_nxt to get cleared. This rsvp_nxt
will be cleared on drm_atomic_state_put of commit N, N+2, hence
atomic_check of commit N+1,N+3 is blocked until this time causing commit
failures.

Change-Id: I320969862b8838a70a8cd3909d244c23871eb430
Signed-off-by: Charishma Jerripothula <quic_cjerripo@quicinc.com>
This commit is contained in:
Charishma Jerripothula
2023-11-08 19:54:00 +05:30
vanhempi 85be4c14bc
commit 9262701035

Näytä tiedosto

@@ -1130,6 +1130,13 @@ static int _sde_encoder_atomic_check_reserve(struct drm_encoder *drm_enc,
return ret;
}
/* Skip RM allocation for Primary during CWB usecase */
if (!crtc_state->mode_changed && !crtc_state->active_changed &&
crtc_state->connectors_changed &&
!msm_is_private_mode_changed(conn_state) && (conn_state->crtc ==
conn_state->connector->state->crtc))
goto skip_reserve;
/* Reserve dynamic resources, indicating atomic_check phase */
ret = sde_rm_reserve(&sde_kms->rm, drm_enc, crtc_state,
conn_state, true);
@@ -1140,6 +1147,7 @@ static int _sde_encoder_atomic_check_reserve(struct drm_encoder *drm_enc,
return ret;
}
skip_reserve:
/**
* Update connector state with the topology selected for the
* resource set validated. Reset the topology if we are