diff options
author | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2016-11-23 06:24:00 -0500 |
---|---|---|
committer | Tomi Valkeinen <tomi.valkeinen@ti.com> | 2017-04-03 05:36:40 -0400 |
commit | 50fa9f0bb8c1eb7d0dbd404766a67c34756d5a80 (patch) | |
tree | a3b4a85dfff24887da0ad08f8ed096b5e9648eb6 /drivers/gpu/drm/omapdrm/omap_crtc.c | |
parent | 956d4f9308d027119282330b54859cf20d222710 (diff) |
drm/omap: fix display SYNC/DE flags
At the moment VSYNC/HSYNC/DE high/low flags set by the panel/encoder
drivers get lost when the videotimings are translated to DRM's
videomode, as DRM's mode does not have corresponding flags.
DRM has bus-flags for this purpose, and while it lacks a few flags at
the moment, it should be used here. However, until we rewrite omapdrm's
device model, using bus-flags is rather difficult.
As a short term fix, this patch makes sure that every time the videomode
is set in omap_crtc_mode_set_nofb(), the driver asks for the SYNC/DE
flags from the panel/encoder drivers, and thus we get the correct flags
into use.
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'drivers/gpu/drm/omapdrm/omap_crtc.c')
-rw-r--r-- | drivers/gpu/drm/omapdrm/omap_crtc.c | 40 |
1 files changed, 37 insertions, 3 deletions
diff --git a/drivers/gpu/drm/omapdrm/omap_crtc.c b/drivers/gpu/drm/omapdrm/omap_crtc.c index 1db96b077ae8..4f03f74685f0 100644 --- a/drivers/gpu/drm/omapdrm/omap_crtc.c +++ b/drivers/gpu/drm/omapdrm/omap_crtc.c | |||
@@ -373,6 +373,11 @@ static void omap_crtc_mode_set_nofb(struct drm_crtc *crtc) | |||
373 | { | 373 | { |
374 | struct omap_crtc *omap_crtc = to_omap_crtc(crtc); | 374 | struct omap_crtc *omap_crtc = to_omap_crtc(crtc); |
375 | struct drm_display_mode *mode = &crtc->state->adjusted_mode; | 375 | struct drm_display_mode *mode = &crtc->state->adjusted_mode; |
376 | struct omap_drm_private *priv = crtc->dev->dev_private; | ||
377 | const u32 flags_mask = DISPLAY_FLAGS_DE_HIGH | DISPLAY_FLAGS_DE_LOW | | ||
378 | DISPLAY_FLAGS_PIXDATA_POSEDGE | DISPLAY_FLAGS_PIXDATA_NEGEDGE | | ||
379 | DISPLAY_FLAGS_SYNC_POSEDGE | DISPLAY_FLAGS_SYNC_NEGEDGE; | ||
380 | unsigned int i; | ||
376 | 381 | ||
377 | DBG("%s: set mode: %d:\"%s\" %d %d %d %d %d %d %d %d %d %d 0x%x 0x%x", | 382 | DBG("%s: set mode: %d:\"%s\" %d %d %d %d %d %d %d %d %d %d 0x%x 0x%x", |
378 | omap_crtc->name, mode->base.id, mode->name, | 383 | omap_crtc->name, mode->base.id, mode->name, |
@@ -382,9 +387,38 @@ static void omap_crtc_mode_set_nofb(struct drm_crtc *crtc) | |||
382 | mode->type, mode->flags); | 387 | mode->type, mode->flags); |
383 | 388 | ||
384 | drm_display_mode_to_videomode(mode, &omap_crtc->vm); | 389 | drm_display_mode_to_videomode(mode, &omap_crtc->vm); |
385 | omap_crtc->vm.flags |= DISPLAY_FLAGS_DE_HIGH | | 390 | |
386 | DISPLAY_FLAGS_PIXDATA_POSEDGE | | 391 | /* |
387 | DISPLAY_FLAGS_SYNC_NEGEDGE; | 392 | * HACK: This fixes the vm flags. |
393 | * struct drm_display_mode does not contain the VSYNC/HSYNC/DE flags | ||
394 | * and they get lost when converting back and forth between | ||
395 | * struct drm_display_mode and struct videomode. The hack below | ||
396 | * goes and fetches the missing flags from the panel drivers. | ||
397 | * | ||
398 | * Correct solution would be to use DRM's bus-flags, but that's not | ||
399 | * easily possible before the omapdrm's panel/encoder driver model | ||
400 | * has been changed to the DRM model. | ||
401 | */ | ||
402 | |||
403 | for (i = 0; i < priv->num_encoders; ++i) { | ||
404 | struct drm_encoder *encoder = priv->encoders[i]; | ||
405 | |||
406 | if (encoder->crtc == crtc) { | ||
407 | struct omap_dss_device *dssdev; | ||
408 | |||
409 | dssdev = omap_encoder_get_dssdev(encoder); | ||
410 | |||
411 | if (dssdev) { | ||
412 | struct videomode vm = {0}; | ||
413 | |||
414 | dssdev->driver->get_timings(dssdev, &vm); | ||
415 | |||
416 | omap_crtc->vm.flags |= vm.flags & flags_mask; | ||
417 | } | ||
418 | |||
419 | break; | ||
420 | } | ||
421 | } | ||
388 | } | 422 | } |
389 | 423 | ||
390 | static int omap_crtc_atomic_check(struct drm_crtc *crtc, | 424 | static int omap_crtc_atomic_check(struct drm_crtc *crtc, |