[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <c6821033-57be-4d10-9e37-935f7748570e@kernel.org>
Date: Sun, 22 Sep 2024 10:15:01 +0200
From: Krzysztof Kozlowski <krzk@...nel.org>
To: Jonas Karlman <jonas@...boo.se>, Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>, Conor Dooley
<conor+dt@...nel.org>, Sandy Huang <hjc@...k-chips.com>,
Heiko Stuebner <heiko@...ech.de>, Andy Yan <andy.yan@...k-chips.com>,
Maarten Lankhorst <maarten.lankhorst@...ux.intel.com>,
Maxime Ripard <mripard@...nel.org>, Thomas Zimmermann <tzimmermann@...e.de>,
David Airlie <airlied@...il.com>, Simona Vetter <simona@...ll.ch>
Cc: linux-rockchip@...ts.infradead.org, devicetree@...r.kernel.org,
dri-devel@...ts.freedesktop.org, linux-arm-kernel@...ts.infradead.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH 3/3] drm/rockchip: vop: Split rk3288-vop into big and lit
On 22/09/2024 00:20, Jonas Karlman wrote:
> The Rockchip RK3288 SoC contain two different Visual Output Processor
> (VOP) blocks, VOP_BIG and VOP_LIT. The VOP blocks support different max
> output resolution, 3840x2160 and 2560x1600.
>
> Add support for the compatible used to differentiate between VOP_BIG and
> VOP_LIT, support for the old compatible is kept for compatibility with
> older device tree.
>
> Signed-off-by: Jonas Karlman <jonas@...boo.se>
> ---
> drivers/gpu/drm/rockchip/rockchip_vop_reg.c | 27 +++++++++++++++------
> 1 file changed, 20 insertions(+), 7 deletions(-)
>
> diff --git a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c
> index e2c6ba26f437..978db93cda33 100644
> --- a/drivers/gpu/drm/rockchip/rockchip_vop_reg.c
> +++ b/drivers/gpu/drm/rockchip/rockchip_vop_reg.c
> @@ -762,7 +762,7 @@ static const struct vop_intr rk3288_vop_intr = {
> .clear = VOP_REG(RK3288_INTR_CTRL0, 0xf, 8),
> };
>
> -static const struct vop_data rk3288_vop = {
> +static const struct vop_data rk3288_vop_big = {
> .version = VOP_VERSION(3, 1),
> .feature = VOP_FEATURE_OUTPUT_RGB10,
> .intr = &rk3288_vop_intr,
> @@ -772,14 +772,22 @@ static const struct vop_data rk3288_vop = {
> .win = rk3288_vop_win_data,
> .win_size = ARRAY_SIZE(rk3288_vop_win_data),
> .lut_size = 1024,
> - /*
> - * This is the maximum resolution for the VOPB, the VOPL can only do
> - * 2560x1600, but we can't distinguish them as they have the same
> - * compatible.
> - */
> .max_output = { 3840, 2160 },
> };
>
> +static const struct vop_data rk3288_vop_lit = {
> + .version = VOP_VERSION(3, 1),
> + .feature = VOP_FEATURE_OUTPUT_RGB10,
> + .intr = &rk3288_vop_intr,
> + .common = &rk3288_common,
> + .modeset = &rk3288_modeset,
> + .output = &rk3288_output,
> + .win = rk3288_vop_win_data,
> + .win_size = ARRAY_SIZE(rk3288_vop_win_data),
> + .lut_size = 1024,
> + .max_output = { 2560, 1600 },
> +};
> +
> static const int rk3368_vop_intrs[] = {
> FS_INTR,
> 0, 0,
> @@ -1245,8 +1253,13 @@ static const struct of_device_id vop_driver_dt_match[] = {
> .data = &rk3066_vop },
> { .compatible = "rockchip,rk3188-vop",
> .data = &rk3188_vop },
> + { .compatible = "rockchip,rk3288-vop-big",
> + .data = &rk3288_vop_big },
Hm... that's not really needed. Instead of having three compatibles, you
could keep "rk3288-vop" as big and then my comment on bindings patch
could be ignored (you keep the compatible).
Best regards,
Krzysztof
Powered by blists - more mailing lists