diff options
author | Noralf Trønnes <noralf@tronnes.org> | 2016-05-11 12:09:20 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2016-05-11 12:53:15 -0400 |
commit | 2827635e39a35f7263fc290c0a39ea3d1dbe35fa (patch) | |
tree | f30ab49451dfad7a4792d3fc3e6c47fb25605f6a | |
parent | 02da16d0fbe2cde3d7befb8a907c167c4a79a681 (diff) |
drm/atomic: Don't skip drm_bridge_*() calls if !drm_encoder_helper_funcs
Don't skip drm_bridge_*() calls if encoder->helper_private is NULL.
Signed-off-by: Noralf Trønnes <noralf@tronnes.org>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: http://patchwork.freedesktop.org/patch/msgid/1462982962-10530-5-git-send-email-noralf@tronnes.org
-rw-r--r-- | drivers/gpu/drm/drm_atomic_helper.c | 39 |
1 files changed, 17 insertions, 22 deletions
diff --git a/drivers/gpu/drm/drm_atomic_helper.c b/drivers/gpu/drm/drm_atomic_helper.c index 027b2274b4bf..46a3201b9851 100644 --- a/drivers/gpu/drm/drm_atomic_helper.c +++ b/drivers/gpu/drm/drm_atomic_helper.c | |||
@@ -384,8 +384,6 @@ mode_fixup(struct drm_atomic_state *state) | |||
384 | */ | 384 | */ |
385 | encoder = conn_state->best_encoder; | 385 | encoder = conn_state->best_encoder; |
386 | funcs = encoder->helper_private; | 386 | funcs = encoder->helper_private; |
387 | if (!funcs) | ||
388 | continue; | ||
389 | 387 | ||
390 | ret = drm_bridge_mode_fixup(encoder->bridge, &crtc_state->mode, | 388 | ret = drm_bridge_mode_fixup(encoder->bridge, &crtc_state->mode, |
391 | &crtc_state->adjusted_mode); | 389 | &crtc_state->adjusted_mode); |
@@ -394,7 +392,7 @@ mode_fixup(struct drm_atomic_state *state) | |||
394 | return -EINVAL; | 392 | return -EINVAL; |
395 | } | 393 | } |
396 | 394 | ||
397 | if (funcs->atomic_check) { | 395 | if (funcs && funcs->atomic_check) { |
398 | ret = funcs->atomic_check(encoder, crtc_state, | 396 | ret = funcs->atomic_check(encoder, crtc_state, |
399 | conn_state); | 397 | conn_state); |
400 | if (ret) { | 398 | if (ret) { |
@@ -402,7 +400,7 @@ mode_fixup(struct drm_atomic_state *state) | |||
402 | encoder->base.id, encoder->name); | 400 | encoder->base.id, encoder->name); |
403 | return ret; | 401 | return ret; |
404 | } | 402 | } |
405 | } else if (funcs->mode_fixup) { | 403 | } else if (funcs && funcs->mode_fixup) { |
406 | ret = funcs->mode_fixup(encoder, &crtc_state->mode, | 404 | ret = funcs->mode_fixup(encoder, &crtc_state->mode, |
407 | &crtc_state->adjusted_mode); | 405 | &crtc_state->adjusted_mode); |
408 | if (!ret) { | 406 | if (!ret) { |
@@ -696,8 +694,6 @@ disable_outputs(struct drm_device *dev, struct drm_atomic_state *old_state) | |||
696 | continue; | 694 | continue; |
697 | 695 | ||
698 | funcs = encoder->helper_private; | 696 | funcs = encoder->helper_private; |
699 | if (!funcs) | ||
700 | continue; | ||
701 | 697 | ||
702 | DRM_DEBUG_ATOMIC("disabling [ENCODER:%d:%s]\n", | 698 | DRM_DEBUG_ATOMIC("disabling [ENCODER:%d:%s]\n", |
703 | encoder->base.id, encoder->name); | 699 | encoder->base.id, encoder->name); |
@@ -709,12 +705,14 @@ disable_outputs(struct drm_device *dev, struct drm_atomic_state *old_state) | |||
709 | drm_bridge_disable(encoder->bridge); | 705 | drm_bridge_disable(encoder->bridge); |
710 | 706 | ||
711 | /* Right function depends upon target state. */ | 707 | /* Right function depends upon target state. */ |
712 | if (connector->state->crtc && funcs->prepare) | 708 | if (funcs) { |
713 | funcs->prepare(encoder); | 709 | if (connector->state->crtc && funcs->prepare) |
714 | else if (funcs->disable) | 710 | funcs->prepare(encoder); |
715 | funcs->disable(encoder); | 711 | else if (funcs->disable) |
716 | else if (funcs->dpms) | 712 | funcs->disable(encoder); |
717 | funcs->dpms(encoder, DRM_MODE_DPMS_OFF); | 713 | else if (funcs->dpms) |
714 | funcs->dpms(encoder, DRM_MODE_DPMS_OFF); | ||
715 | } | ||
718 | 716 | ||
719 | drm_bridge_post_disable(encoder->bridge); | 717 | drm_bridge_post_disable(encoder->bridge); |
720 | } | 718 | } |
@@ -861,9 +859,6 @@ crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state) | |||
861 | 859 | ||
862 | encoder = connector->state->best_encoder; | 860 | encoder = connector->state->best_encoder; |
863 | funcs = encoder->helper_private; | 861 | funcs = encoder->helper_private; |
864 | if (!funcs) | ||
865 | continue; | ||
866 | |||
867 | new_crtc_state = connector->state->crtc->state; | 862 | new_crtc_state = connector->state->crtc->state; |
868 | mode = &new_crtc_state->mode; | 863 | mode = &new_crtc_state->mode; |
869 | adjusted_mode = &new_crtc_state->adjusted_mode; | 864 | adjusted_mode = &new_crtc_state->adjusted_mode; |
@@ -878,7 +873,7 @@ crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state) | |||
878 | * Each encoder has at most one connector (since we always steal | 873 | * Each encoder has at most one connector (since we always steal |
879 | * it away), so we won't call mode_set hooks twice. | 874 | * it away), so we won't call mode_set hooks twice. |
880 | */ | 875 | */ |
881 | if (funcs->mode_set) | 876 | if (funcs && funcs->mode_set) |
882 | funcs->mode_set(encoder, mode, adjusted_mode); | 877 | funcs->mode_set(encoder, mode, adjusted_mode); |
883 | 878 | ||
884 | drm_bridge_mode_set(encoder->bridge, mode, adjusted_mode); | 879 | drm_bridge_mode_set(encoder->bridge, mode, adjusted_mode); |
@@ -969,8 +964,6 @@ void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev, | |||
969 | 964 | ||
970 | encoder = connector->state->best_encoder; | 965 | encoder = connector->state->best_encoder; |
971 | funcs = encoder->helper_private; | 966 | funcs = encoder->helper_private; |
972 | if (!funcs) | ||
973 | continue; | ||
974 | 967 | ||
975 | DRM_DEBUG_ATOMIC("enabling [ENCODER:%d:%s]\n", | 968 | DRM_DEBUG_ATOMIC("enabling [ENCODER:%d:%s]\n", |
976 | encoder->base.id, encoder->name); | 969 | encoder->base.id, encoder->name); |
@@ -981,10 +974,12 @@ void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev, | |||
981 | */ | 974 | */ |
982 | drm_bridge_pre_enable(encoder->bridge); | 975 | drm_bridge_pre_enable(encoder->bridge); |
983 | 976 | ||
984 | if (funcs->enable) | 977 | if (funcs) { |
985 | funcs->enable(encoder); | 978 | if (funcs->enable) |
986 | else if (funcs->commit) | 979 | funcs->enable(encoder); |
987 | funcs->commit(encoder); | 980 | else if (funcs->commit) |
981 | funcs->commit(encoder); | ||
982 | } | ||
988 | 983 | ||
989 | drm_bridge_enable(encoder->bridge); | 984 | drm_bridge_enable(encoder->bridge); |
990 | } | 985 | } |