Commit 89e0c53c authored by Russell King's avatar Russell King

drm/armada: add missing interlaced support for overlay frame

Interlaced support has been missing from the overlay frame, which is
sub-optimal.  Add support for this missing feature.
Signed-off-by: default avatarRussell King <rmk+kernel@armlinux.org.uk>
parent 1d1547ec
...@@ -106,12 +106,13 @@ static void armada_drm_overlay_plane_atomic_update(struct drm_plane *plane, ...@@ -106,12 +106,13 @@ static void armada_drm_overlay_plane_atomic_update(struct drm_plane *plane,
/* FIXME: overlay on an interlaced display */ /* FIXME: overlay on an interlaced display */
if (old_state->src.x1 != state->src.x1 || if (old_state->src.x1 != state->src.x1 ||
old_state->src.y1 != state->src.y1 || old_state->src.y1 != state->src.y1 ||
old_state->fb != state->fb) { old_state->fb != state->fb ||
state->crtc->state->mode_changed) {
const struct drm_format_info *format; const struct drm_format_info *format;
u16 src_x, pitches[3]; u16 src_x, pitches[3];
u32 addrs[2][3]; u32 addrs[2][3];
armada_drm_plane_calc(state, addrs, pitches, false); armada_drm_plane_calc(state, addrs, pitches, dcrtc->interlaced);
armada_reg_queue_set(regs, idx, addrs[0][0], armada_reg_queue_set(regs, idx, addrs[0][0],
LCD_SPU_DMA_START_ADDR_Y0); LCD_SPU_DMA_START_ADDR_Y0);
...@@ -146,6 +147,8 @@ static void armada_drm_overlay_plane_atomic_update(struct drm_plane *plane, ...@@ -146,6 +147,8 @@ static void armada_drm_overlay_plane_atomic_update(struct drm_plane *plane,
src_x = state->src.x1 >> 16; src_x = state->src.x1 >> 16;
if (format->num_planes == 1 && src_x & (format->hsub - 1)) if (format->num_planes == 1 && src_x & (format->hsub - 1))
cfg ^= CFG_DMA_MOD(CFG_SWAPUV); cfg ^= CFG_DMA_MOD(CFG_SWAPUV);
if (dcrtc->interlaced)
cfg |= CFG_DMA_FTOGGLE;
cfg_mask = CFG_CBSH_ENA | CFG_DMAFORMAT | cfg_mask = CFG_CBSH_ENA | CFG_DMAFORMAT |
CFG_DMA_MOD(CFG_SWAPRB | CFG_SWAPUV | CFG_DMA_MOD(CFG_SWAPRB | CFG_SWAPUV |
CFG_SWAPYU | CFG_YUV2RGB) | CFG_SWAPYU | CFG_YUV2RGB) |
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment