Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp3452839ybz; Mon, 20 Apr 2020 03:05:12 -0700 (PDT) X-Google-Smtp-Source: APiQypJs0NjUUauL6+MV0GuASZQ/3rRu44GrAhQvq4mkGdBBMR5wP/iGL7QE+SBMK4/MC6IY/gxl X-Received: by 2002:a05:6402:1d89:: with SMTP id dk9mr13281630edb.382.1587377111820; Mon, 20 Apr 2020 03:05:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587377111; cv=none; d=google.com; s=arc-20160816; b=lcXM0n5H4zUTSzpjNNZeveZOWhJ5d0x5wvEJ6FZdsImzTeTz3RPerZSYIKt9IatmIN 2kTrTum8oPdm9dMeMqh2Q2VpQafZxvFJU+mjE2er9wYHe5iBFfSqSa/pqks0XcGFvhap fO1xWjWPKVK5QmdKl7ZlJL2MKGau3BeYbEaxlNKseo9CwC6NuYDcFl9U9N80DOimj3j6 kju2oOyWBVH4Dk4YC/04RA51r+yvoNIG04cFSOfKSPaCHk6QjNr/VcyxPiQFUFmGXjXg 4WHIoFAMKiINIzhYi39yodMCP5y+zDDUlyEz4tOzLcyPQRPiI6wpU+VnP8ERChd5oAw4 vTAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=U+m2TWy16xfbdgnTvEOHOPiRR2FwfP62YgzY/2O9jvY=; b=L59QI5VajpXkqXVd3oO22zCr50BMNWbCLL2y3xIefqpIvTwIR7LjKGzldxtM68RJmi 2oq8H2Ge6QmMKuMcRl8PJXrMQwY/EjewyB5tftX/zvkwK9g7kbDH4pZwRX/ub+s+L2vO ndBkW5V2GUxtA5WwbBLdovMO9hefrS12gksmhbRu3r53ta3BznuqHpPeeRAWPUR9CMuR Gu8kq+XUyER9FM6/MxXKSAx1l+nkGFbEkc/tsVEUv6XUDPbJdU/yKJhrRwzHuoKCpket y9UDH9r6G7gorh+BosaN5H/7pdt25yUsG6kGrLCoJwUBO1uHXX9Av7MZsdkXYmOCwKaf HvcA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y13si228341ede.350.2020.04.20.03.04.46; Mon, 20 Apr 2020 03:05:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726173AbgDTKBX (ORCPT + 99 others); Mon, 20 Apr 2020 06:01:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36188 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1725773AbgDTKBX (ORCPT ); Mon, 20 Apr 2020 06:01:23 -0400 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e3e3]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DA7B2C061A0C for ; Mon, 20 Apr 2020 03:01:22 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: aratiu) with ESMTPSA id E48D82A044A From: Adrian Ratiu To: NXP Linux Team Cc: Philipp Zabel , Shawn Guo , Sascha Hauer , dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, kernel@collabora.com, Pengutronix Kernel Team , Fabio Estevam , Laurent Pinchart , Enric Balletbo Serra Subject: [PATCH] drm: imx: Unify encoder creation Date: Mon, 20 Apr 2020 13:02:22 +0300 Message-Id: <20200420100222.1308898-1-adrian.ratiu@collabora.com> X-Mailer: git-send-email 2.26.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org imx drivers don't require drm encoders and they all had empty/no-op implementations which got converted to simple objects to pacify the drm core which still requires something to be defined. The problem now is that each driver duplicates the same encoder initialization logic and I'm working on adding yet-another driver (for imx6 mipi-dsi), so instead of copy-pasting the initialization let's move it from the drivers to a shared function in imx-drm-core. The imx_drm_encoder_parse_of() logic is made part of the newly added imx_drm_create_encoder() which was its only caller after the move to imx-drm-core. Suggested-by: Laurent Pinchart Suggested-by: Enric Balletbo Serra Signed-off-by: Adrian Ratiu --- drivers/gpu/drm/imx/dw_hdmi-imx.c | 18 ++++++------------ drivers/gpu/drm/imx/imx-drm-core.c | 13 ++++++++++--- drivers/gpu/drm/imx/imx-drm.h | 2 +- drivers/gpu/drm/imx/imx-ldb.c | 8 ++++---- drivers/gpu/drm/imx/imx-tve.c | 8 ++++---- drivers/gpu/drm/imx/parallel-display.c | 11 +++++------ 6 files changed, 30 insertions(+), 30 deletions(-) diff --git a/drivers/gpu/drm/imx/dw_hdmi-imx.c b/drivers/gpu/drm/imx/dw_hdmi-imx.c index ba4ca17fd4d8..a710e3d576b4 100644 --- a/drivers/gpu/drm/imx/dw_hdmi-imx.c +++ b/drivers/gpu/drm/imx/dw_hdmi-imx.c @@ -18,7 +18,6 @@ #include #include #include -#include #include "imx-drm.h" @@ -218,22 +217,17 @@ static int dw_hdmi_imx_bind(struct device *dev, struct device *master, hdmi->dev = &pdev->dev; encoder = &hdmi->encoder; - encoder->possible_crtcs = drm_of_find_possible_crtcs(drm, dev->of_node); - /* - * If we failed to find the CRTC(s) which this encoder is - * supposed to be connected to, it's because the CRTC has - * not been registered yet. Defer probing, and hope that - * the required CRTC is added later. - */ - if (encoder->possible_crtcs == 0) - return -EPROBE_DEFER; - ret = dw_hdmi_imx_parse_dt(hdmi); if (ret < 0) return ret; + ret = imx_drm_create_encoder(drm, encoder, dev->of_node); + if (ret) { + dev_err(dev, "Failed to create drm encoder\n"); + return ret; + } + drm_encoder_helper_add(encoder, &dw_hdmi_imx_encoder_helper_funcs); - drm_simple_encoder_init(drm, encoder, DRM_MODE_ENCODER_TMDS); platform_set_drvdata(pdev, hdmi); diff --git a/drivers/gpu/drm/imx/imx-drm-core.c b/drivers/gpu/drm/imx/imx-drm-core.c index 2e38f1a5cf8d..eaf087ed354f 100644 --- a/drivers/gpu/drm/imx/imx-drm-core.c +++ b/drivers/gpu/drm/imx/imx-drm-core.c @@ -23,6 +23,7 @@ #include #include #include +#include #include #include "imx-drm.h" @@ -116,11 +117,11 @@ static const struct drm_mode_config_helper_funcs imx_drm_mode_config_helpers = { .atomic_commit_tail = imx_drm_atomic_commit_tail, }; - -int imx_drm_encoder_parse_of(struct drm_device *drm, +int imx_drm_create_encoder(struct drm_device *drm, struct drm_encoder *encoder, struct device_node *np) { uint32_t crtc_mask = drm_of_find_possible_crtcs(drm, np); + int ret; /* * If we failed to find the CRTC(s) which this encoder is @@ -136,9 +137,15 @@ int imx_drm_encoder_parse_of(struct drm_device *drm, /* FIXME: cloning support not clear, disable it all for now */ encoder->possible_clones = 0; + ret = drm_simple_encoder_init(drm, encoder, DRM_MODE_ENCODER_NONE); + if (ret) { + DRM_ERROR("Failed to initialize simple drm encoder\n"); + return ret; + } + return 0; } -EXPORT_SYMBOL_GPL(imx_drm_encoder_parse_of); +EXPORT_SYMBOL_GPL(imx_drm_create_encoder); static const struct drm_ioctl_desc imx_drm_ioctls[] = { /* none so far */ diff --git a/drivers/gpu/drm/imx/imx-drm.h b/drivers/gpu/drm/imx/imx-drm.h index c3e1a3f14d30..8573a668a5f5 100644 --- a/drivers/gpu/drm/imx/imx-drm.h +++ b/drivers/gpu/drm/imx/imx-drm.h @@ -34,7 +34,7 @@ void imx_drm_mode_config_init(struct drm_device *drm); struct drm_gem_cma_object *imx_drm_fb_get_obj(struct drm_framebuffer *fb); -int imx_drm_encoder_parse_of(struct drm_device *drm, +int imx_drm_create_encoder(struct drm_device *drm, struct drm_encoder *encoder, struct device_node *np); void imx_drm_connector_destroy(struct drm_connector *connector); diff --git a/drivers/gpu/drm/imx/imx-ldb.c b/drivers/gpu/drm/imx/imx-ldb.c index 66ea68e8da87..a37fa325a8c3 100644 --- a/drivers/gpu/drm/imx/imx-ldb.c +++ b/drivers/gpu/drm/imx/imx-ldb.c @@ -26,7 +26,6 @@ #include #include #include -#include #include "imx-drm.h" @@ -423,9 +422,11 @@ static int imx_ldb_register(struct drm_device *drm, struct drm_encoder *encoder = &imx_ldb_ch->encoder; int ret; - ret = imx_drm_encoder_parse_of(drm, encoder, imx_ldb_ch->child); - if (ret) + ret = imx_drm_create_encoder(drm, encoder, imx_ldb_ch->child); + if (ret) { + dev_err(ldb->dev, "Failed to create drm encoder\n"); return ret; + } ret = imx_ldb_get_clk(ldb, imx_ldb_ch->chno); if (ret) @@ -438,7 +439,6 @@ static int imx_ldb_register(struct drm_device *drm, } drm_encoder_helper_add(encoder, &imx_ldb_encoder_helper_funcs); - drm_simple_encoder_init(drm, encoder, DRM_MODE_ENCODER_LVDS); if (imx_ldb_ch->bridge) { ret = drm_bridge_attach(&imx_ldb_ch->encoder, diff --git a/drivers/gpu/drm/imx/imx-tve.c b/drivers/gpu/drm/imx/imx-tve.c index ee63782c77e9..2d88aca0f7e7 100644 --- a/drivers/gpu/drm/imx/imx-tve.c +++ b/drivers/gpu/drm/imx/imx-tve.c @@ -21,7 +21,6 @@ #include #include #include -#include #include "imx-drm.h" @@ -471,12 +470,13 @@ static int imx_tve_register(struct drm_device *drm, struct imx_tve *tve) encoder_type = tve->mode == TVE_MODE_VGA ? DRM_MODE_ENCODER_DAC : DRM_MODE_ENCODER_TVDAC; - ret = imx_drm_encoder_parse_of(drm, &tve->encoder, tve->dev->of_node); - if (ret) + ret = imx_drm_create_encoder(drm, &tve->encoder, tve->dev->of_node); + if (ret) { + dev_err(tve->dev, "failed to create drm encoder\n"); return ret; + } drm_encoder_helper_add(&tve->encoder, &imx_tve_encoder_helper_funcs); - drm_simple_encoder_init(drm, &tve->encoder, encoder_type); drm_connector_helper_add(&tve->connector, &imx_tve_connector_helper_funcs); diff --git a/drivers/gpu/drm/imx/parallel-display.c b/drivers/gpu/drm/imx/parallel-display.c index 4465e9c602f8..321accb4ca7c 100644 --- a/drivers/gpu/drm/imx/parallel-display.c +++ b/drivers/gpu/drm/imx/parallel-display.c @@ -18,7 +18,6 @@ #include #include #include -#include #include "imx-drm.h" @@ -274,10 +273,6 @@ static int imx_pd_register(struct drm_device *drm, struct drm_encoder *encoder = &imxpd->encoder; int ret; - ret = imx_drm_encoder_parse_of(drm, encoder, imxpd->dev->of_node); - if (ret) - return ret; - /* set the connector's dpms to OFF so that * drm_helper_connector_dpms() won't return * immediately since the current state is ON @@ -285,7 +280,11 @@ static int imx_pd_register(struct drm_device *drm, */ imxpd->connector.dpms = DRM_MODE_DPMS_OFF; - drm_simple_encoder_init(drm, encoder, DRM_MODE_ENCODER_NONE); + ret = imx_drm_create_encoder(drm, encoder, imxpd->dev->of_node); + if (ret) { + dev_err(imxpd->dev, "failed to create drm encoder\n"); + return ret; + } imxpd->bridge.funcs = &imx_pd_bridge_funcs; drm_bridge_attach(encoder, &imxpd->bridge, NULL, 0); -- 2.26.0