Merge "disp: msm: sde: support qsync and vrr in same atomic commit"

此提交包含在:
qctecmdr
2020-10-16 00:13:41 -07:00
提交者 Gerrit - the friendly Code Review server
當前提交 81b698b276
共有 2 個檔案被更改,包括 16 行新增3 行删除

查看文件

@@ -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;
}