drm/sun4i: Cleanup video/YUV source before enabling a layer
This adds a dedicated function for cleaning the video and YUV source channel layer enable bits. This function is called first on layer atomic update to make sure that there are no leftover bits from previous plane configuration that were not cleaned until now. It fixes issues when alternating between video and YUV planes, where both bits would be set eventually, leading to broken plane display. Signed-off-by: Paul Kocialkowski <paul.kocialkowski@bootlin.com> Signed-off-by: Maxime Ripard <maxime.ripard@bootlin.com> Link: https://patchwork.freedesktop.org/patch/msgid/20181123092515.2511-2-paul.kocialkowski@bootlin.com
This commit is contained in:

committed by
Maxime Ripard

parent
a42facc82c
commit
686d263856
@@ -395,6 +395,15 @@ int sun4i_backend_update_layer_zpos(struct sun4i_backend *backend, int layer,
|
||||
return 0;
|
||||
}
|
||||
|
||||
void sun4i_backend_cleanup_layer(struct sun4i_backend *backend,
|
||||
int layer)
|
||||
{
|
||||
regmap_update_bits(backend->engine.regs,
|
||||
SUN4I_BACKEND_ATTCTL_REG0(layer),
|
||||
SUN4I_BACKEND_ATTCTL_REG0_LAY_VDOEN |
|
||||
SUN4I_BACKEND_ATTCTL_REG0_LAY_YUVEN, 0);
|
||||
}
|
||||
|
||||
static bool sun4i_backend_plane_uses_scaler(struct drm_plane_state *state)
|
||||
{
|
||||
u16 src_h = state->src_h >> 16;
|
||||
|
Reference in New Issue
Block a user