Merge "disp: msm: sde: support qsync and vrr in same atomic commit"
此提交包含在:
@@ -2340,6 +2340,7 @@ static int sde_connector_atomic_check(struct drm_connector *connector,
|
||||
struct sde_connector_state *c_state;
|
||||
bool qsync_dirty = false, has_modeset = false;
|
||||
struct drm_connector_state *new_conn_state;
|
||||
struct drm_crtc_state *new_crtc_state = NULL;
|
||||
|
||||
if (!connector) {
|
||||
SDE_ERROR("invalid connector\n");
|
||||
@@ -2355,6 +2356,9 @@ static int sde_connector_atomic_check(struct drm_connector *connector,
|
||||
}
|
||||
|
||||
c_state = to_sde_connector_state(new_conn_state);
|
||||
if (new_conn_state->crtc)
|
||||
new_crtc_state = drm_atomic_get_new_crtc_state(state,
|
||||
new_conn_state->crtc);
|
||||
|
||||
has_modeset = sde_crtc_atomic_check_has_modeset(new_conn_state->state,
|
||||
new_conn_state->crtc);
|
||||
@@ -2363,7 +2367,8 @@ static int sde_connector_atomic_check(struct drm_connector *connector,
|
||||
CONNECTOR_PROP_QSYNC_MODE);
|
||||
|
||||
SDE_DEBUG("has_modeset %d qsync_dirty %d\n", has_modeset, qsync_dirty);
|
||||
if (has_modeset && qsync_dirty) {
|
||||
if (has_modeset && qsync_dirty && new_crtc_state &&
|
||||
!msm_is_mode_seamless_vrr(&new_crtc_state->adjusted_mode)) {
|
||||
SDE_ERROR("invalid qsync update during modeset\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
新增問題並參考
封鎖使用者