drm/rockchip: vop2: Enforce scaling workaround in plane_check

It seems only cluster windows are capable of applying downscaling when
the source region has an odd width. Instead of applying a workaround
inside atomic_update, fail the plane check if this is requested.

Signed-off-by: Daniel Stone <daniels@collabora.com>
Signed-off-by: Nicolas Frattaroli <nicolas.frattaroli@collabora.com>
Signed-off-by: Heiko Stuebner <heiko@sntech.de>
Link: https://patch.msgid.link/20251215-vop2-atomic-fixups-v5-4-83463c075a8d@collabora.com
This commit is contained in:
Daniel Stone
2025-12-15 15:09:20 +01:00
committed by Heiko Stuebner
parent f403945d24
commit dfb673c71f

View File

@@ -998,6 +998,7 @@ static int vop2_plane_atomic_check(struct drm_plane *plane,
struct drm_crtc *crtc = pstate->crtc;
struct drm_crtc_state *cstate;
struct vop2_video_port *vp;
struct vop2_win *win = to_vop2_win(plane);
struct vop2 *vop2;
const struct vop2_data *vop2_data;
struct drm_rect *dest = &pstate->dst;
@@ -1065,6 +1066,16 @@ static int vop2_plane_atomic_check(struct drm_plane *plane,
return -EINVAL;
}
/*
* This is workaround solution for IC design:
* esmart can't support scale down when src_w % 16 == 1.
*/
if (!vop2_cluster_window(win) && src_w > dest_w && (src_w & 1)) {
drm_dbg_kms(vop2->drm,
"Esmart windows cannot downscale odd-width source regions\n");
return -EINVAL;
}
return 0;
}
@@ -1225,16 +1236,6 @@ static void vop2_plane_atomic_update(struct drm_plane *plane,
WARN_ON(src_w < 4) || WARN_ON(src_h < 4))
return;
/*
* This is workaround solution for IC design:
* esmart can't support scale down when src_w % 16 == 1.
*/
if (!vop2_cluster_window(win) && src_w > dsp_w && (src_w & 1)) {
drm_dbg_kms(vop2->drm, "vp%d %s act_w[%d] MODE 16 == 1\n",
vp->id, win->data->name, src_w);
src_w -= 1;
}
if (afbc_en && src_w % 4) {
drm_dbg_kms(vop2->drm, "vp%d %s src_w[%d] not 4 pixel aligned\n",
vp->id, win->data->name, src_w);