* [PATCH] drm/rockchip: Open-code drm_simple_encoder_init()
@ 2026-05-06 16:53 x
2026-05-07 10:24 ` Dmitry Baryshkov
0 siblings, 1 reply; 2+ messages in thread
From: x @ 2026-05-06 16:53 UTC (permalink / raw)
To: dri-devel, linux-arm-kernel, linux-rockchip, linux-kernel
From: Favilances Noir <favilances@proton.me>
drm_simple_encoder_init() wraps drm_encoder_init().
It uses drm_encoder_cleanup() as the encoder destroy callback.
Add driver-local drm_encoder_funcs and call drm_encoder_init() directly.
This is a TODO cleanup towards removing drm_simple_encoder_init().
No functional change intended.
Signed-off-by: Favilances Noir <favilances@proton.me>
---
drivers/gpu/drm/rockchip/rockchip_rgb.c | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/drivers/gpu/drm/rockchip/rockchip_rgb.c b/drivers/gpu/drm/rockchip/rockchip_rgb.c
index 5c0c6e2cc28d..fd93ffedad64 100644
--- a/drivers/gpu/drm/rockchip/rockchip_rgb.c
+++ b/drivers/gpu/drm/rockchip/rockchip_rgb.c
@@ -13,11 +13,11 @@
#include <drm/drm_atomic_helper.h>
#include <drm/drm_bridge.h>
#include <drm/drm_bridge_connector.h>
+#include <drm/drm_encoder.h>
#include <drm/drm_of.h>
#include <drm/drm_panel.h>
#include <drm/drm_print.h>
#include <drm/drm_probe_helper.h>
-#include <drm/drm_simple_kms_helper.h>
#include "rockchip_drm_drv.h"
#include "rockchip_rgb.h"
@@ -70,6 +70,10 @@ struct drm_encoder_helper_funcs rockchip_rgb_encoder_helper_funcs = {
.atomic_check = rockchip_rgb_encoder_atomic_check,
};
+static const struct drm_encoder_funcs rockchip_rgb_encoder_funcs = {
+ .destroy = drm_encoder_cleanup,
+};
+
struct rockchip_rgb *rockchip_rgb_init(struct device *dev,
struct drm_crtc *crtc,
struct drm_device *drm_dev,
@@ -127,7 +131,8 @@ struct rockchip_rgb *rockchip_rgb_init(struct device *dev,
encoder = &rgb->encoder.encoder;
encoder->possible_crtcs = drm_crtc_mask(crtc);
- ret = drm_simple_encoder_init(drm_dev, encoder, DRM_MODE_ENCODER_NONE);
+ ret = drm_encoder_init(drm_dev, encoder, &rockchip_rgb_encoder_funcs,
+ DRM_MODE_ENCODER_NONE, NULL);
if (ret < 0) {
DRM_DEV_ERROR(drm_dev->dev,
"failed to initialize encoder: %d\n", ret);
--
2.54.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] drm/rockchip: Open-code drm_simple_encoder_init()
2026-05-06 16:53 [PATCH] drm/rockchip: Open-code drm_simple_encoder_init() x
@ 2026-05-07 10:24 ` Dmitry Baryshkov
0 siblings, 0 replies; 2+ messages in thread
From: Dmitry Baryshkov @ 2026-05-07 10:24 UTC (permalink / raw)
To: x; +Cc: dri-devel, linux-arm-kernel, linux-rockchip, linux-kernel
On Wed, May 06, 2026 at 07:53:45PM +0300, x@2005.tr wrote:
> From: Favilances Noir <favilances@proton.me>
>
> drm_simple_encoder_init() wraps drm_encoder_init().
>
> It uses drm_encoder_cleanup() as the encoder destroy callback.
>
> Add driver-local drm_encoder_funcs and call drm_encoder_init() directly.
>
> This is a TODO cleanup towards removing drm_simple_encoder_init().
>
> No functional change intended.
>
> Signed-off-by: Favilances Noir <favilances@proton.me>
> ---
> drivers/gpu/drm/rockchip/rockchip_rgb.c | 9 +++++++--
> 1 file changed, 7 insertions(+), 2 deletions(-)
>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
--
With best wishes
Dmitry
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2026-05-07 10:24 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-05-06 16:53 [PATCH] drm/rockchip: Open-code drm_simple_encoder_init() x
2026-05-07 10:24 ` Dmitry Baryshkov
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox