aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/omapdrm/omap_encoder.c
diff options
context:
space:
mode:
authorMaxime Ripard <maxime.ripard@bootlin.com>2019-01-11 10:32:10 -0500
committerMaxime Ripard <maxime.ripard@bootlin.com>2019-01-11 10:32:10 -0500
commit23d19ba06b9c5614d6457f5fed349ec8f6d4dac9 (patch)
tree39f0b657e5b1b5b958780cae4ae6360f69548d50 /drivers/gpu/drm/omapdrm/omap_encoder.c
parent7d0250ed8e69fb6a66caecf60b8753a21224cc1a (diff)
parente3d093070eb0b5e3df668d3eb04100ea79343c65 (diff)
Merge drm/drm-next into drm-misc-next
drm-next has been forwarded to 5.0-rc1, and we need it to apply the damage helper for dirtyfb series from Noralf Trønnes. Signed-off-by: Maxime Ripard <maxime.ripard@bootlin.com>
Diffstat (limited to 'drivers/gpu/drm/omapdrm/omap_encoder.c')
-rw-r--r--drivers/gpu/drm/omapdrm/omap_encoder.c58
1 files changed, 33 insertions, 25 deletions
diff --git a/drivers/gpu/drm/omapdrm/omap_encoder.c b/drivers/gpu/drm/omapdrm/omap_encoder.c
index 4566e0a75cb8..148b6b20274f 100644
--- a/drivers/gpu/drm/omapdrm/omap_encoder.c
+++ b/drivers/gpu/drm/omapdrm/omap_encoder.c
@@ -52,17 +52,44 @@ static const struct drm_encoder_funcs omap_encoder_funcs = {
52 .destroy = omap_encoder_destroy, 52 .destroy = omap_encoder_destroy,
53}; 53};
54 54
55static void omap_encoder_hdmi_mode_set(struct drm_encoder *encoder,
56 struct drm_display_mode *adjusted_mode)
57{
58 struct drm_device *dev = encoder->dev;
59 struct omap_encoder *omap_encoder = to_omap_encoder(encoder);
60 struct omap_dss_device *dssdev = omap_encoder->output;
61 struct drm_connector *connector;
62 bool hdmi_mode;
63
64 hdmi_mode = false;
65 list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
66 if (connector->encoder == encoder) {
67 hdmi_mode = omap_connector_get_hdmi_mode(connector);
68 break;
69 }
70 }
71
72 if (dssdev->ops->hdmi.set_hdmi_mode)
73 dssdev->ops->hdmi.set_hdmi_mode(dssdev, hdmi_mode);
74
75 if (hdmi_mode && dssdev->ops->hdmi.set_infoframe) {
76 struct hdmi_avi_infoframe avi;
77 int r;
78
79 r = drm_hdmi_avi_infoframe_from_display_mode(&avi, connector,
80 adjusted_mode);
81 if (r == 0)
82 dssdev->ops->hdmi.set_infoframe(dssdev, &avi);
83 }
84}
85
55static void omap_encoder_mode_set(struct drm_encoder *encoder, 86static void omap_encoder_mode_set(struct drm_encoder *encoder,
56 struct drm_display_mode *mode, 87 struct drm_display_mode *mode,
57 struct drm_display_mode *adjusted_mode) 88 struct drm_display_mode *adjusted_mode)
58{ 89{
59 struct drm_device *dev = encoder->dev;
60 struct omap_encoder *omap_encoder = to_omap_encoder(encoder); 90 struct omap_encoder *omap_encoder = to_omap_encoder(encoder);
61 struct drm_connector *connector;
62 struct omap_dss_device *dssdev; 91 struct omap_dss_device *dssdev;
63 struct videomode vm = { 0 }; 92 struct videomode vm = { 0 };
64 bool hdmi_mode;
65 int r;
66 93
67 drm_display_mode_to_videomode(adjusted_mode, &vm); 94 drm_display_mode_to_videomode(adjusted_mode, &vm);
68 95
@@ -112,27 +139,8 @@ static void omap_encoder_mode_set(struct drm_encoder *encoder,
112 } 139 }
113 140
114 /* Set the HDMI mode and HDMI infoframe if applicable. */ 141 /* Set the HDMI mode and HDMI infoframe if applicable. */
115 hdmi_mode = false; 142 if (omap_encoder->output->output_type == OMAP_DISPLAY_TYPE_HDMI)
116 list_for_each_entry(connector, &dev->mode_config.connector_list, head) { 143 omap_encoder_hdmi_mode_set(encoder, adjusted_mode);
117 if (connector->encoder == encoder) {
118 hdmi_mode = omap_connector_get_hdmi_mode(connector);
119 break;
120 }
121 }
122
123 dssdev = omap_encoder->output;
124
125 if (dssdev->ops->hdmi.set_hdmi_mode)
126 dssdev->ops->hdmi.set_hdmi_mode(dssdev, hdmi_mode);
127
128 if (hdmi_mode && dssdev->ops->hdmi.set_infoframe) {
129 struct hdmi_avi_infoframe avi;
130
131 r = drm_hdmi_avi_infoframe_from_display_mode(&avi, connector,
132 adjusted_mode);
133 if (r == 0)
134 dssdev->ops->hdmi.set_infoframe(dssdev, &avi);
135 }
136} 144}
137 145
138static void omap_encoder_disable(struct drm_encoder *encoder) 146static void omap_encoder_disable(struct drm_encoder *encoder)