Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4541349rwd; Sun, 4 Jun 2023 07:28:24 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7zVZQWDzerYcguCAkVezTGWDjz3lh0M/XxS+hkFRCZprUEIMRndXRV6EfVqeV2mfFOSnoX X-Received: by 2002:a05:6a20:4390:b0:10b:6b1f:acf1 with SMTP id i16-20020a056a20439000b0010b6b1facf1mr1483725pzl.29.1685888904526; Sun, 04 Jun 2023 07:28:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1685888904; cv=none; d=google.com; s=arc-20160816; b=U2a66fx+0GmphZBkxfmL5agbAmXki609UtZ62YFJFhky7gOZcPwEvB7RjyuTi5Va/W 0BcXi2lF6WRZtFsV2o9+ByEE/aZKmdhjakIjQ8sej2KQuhWyvAPzz6JL4GJ1EOY1S2z2 4a1E27zH5BGe/9lMLje14lHZU4Qhc2/A8MJzA+i9wRxler2uVJ69JLk+7XrV9WldPT48 Ts7X3wMeJMTjWjpOvBL00uFMMMyLHAIf8uf5sLPFMDCTaH2uhw/93I0+j3KVM63Nx1y7 P2zAfDTRe9RdWeZ+yhmPHXR03/NrrFk3EAqvecAnnOXW7JJ+gw5SrxZ6crnXF207yAQI eeDw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=B8GHLlrO1/SLKs4KHpOsCkEmwBIfPPQnjmh3R11XWsQ=; b=wb4TA3oclxZInekN1RKOzjQdN6OwkEcmJdEAQRMexmH7cqi7tRDMnYqD1jhzzb/EPs 5zCP36C03DVJgEIfcXMzu+4Z3d0q9ZPXRoV4SNbPaH95Oyta5Nsx71QQJnDJb2p709ce wvr+BKTsUI2e9m6HKjXyrq/GxfocqnqWDK/fHGQkyhjdbHzro1H2O3RVczEYi07ZSEOz 6iqGg8ISFzBvSCDCpp0upvCJw/ccGErTpPLOo9MR78nTeCXIcL92RcbkwsH2O0hIqMYJ JUL+S1t2guCXm0QHk92h5ma9DmuapQ/ZRWkUlmDpptrWamoZL5zuxdvGDUgzB4SouuET ZeAw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=BTIR39CJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i188-20020a6254c5000000b006434e20d023si3831049pfb.399.2023.06.04.07.28.11; Sun, 04 Jun 2023 07:28:24 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=BTIR39CJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229930AbjFDOYm (ORCPT + 99 others); Sun, 4 Jun 2023 10:24:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48166 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229635AbjFDOYk (ORCPT ); Sun, 4 Jun 2023 10:24:40 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3C583D2 for ; Sun, 4 Jun 2023 07:24:39 -0700 (PDT) Received: from pendragon.ideasonboard.com (om126166129043.28.openmobile.ne.jp [126.166.129.43]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 65C272B6; Sun, 4 Jun 2023 16:24:12 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1685888653; bh=n+Fq/GVdjovbc0B90ICxlqrFW3H2m2JgT1JFvlB0xzI=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=BTIR39CJ7ksEuyBDh3gH28Q+fr8Yq++i4GrHSBSZ1cT2HvRRe5zEgFgUSUdp1gLbo 4ZGkv8j1lUYypODO6c5KBbuHNRVoXVAn1GSX/4N9dBtZe7su5o5waB6JVdW/TNyPDh OPozY0D4G5xEilG+gCWjhyXy/7Kko4JJgO4JmZcE= Date: Sun, 4 Jun 2023 17:24:36 +0300 From: Laurent Pinchart To: Masahiro Yamada Cc: Andrzej Hajda , Neil Armstrong , Robert Foss , Jonas Karlman , Jernej Skrabec , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Liu Ying , Daniel Vetter , David Airlie , Fabio Estevam , NXP Linux Team , Nick Terrell , Pengutronix Kernel Team , Sascha Hauer , Shawn Guo , linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH v2 1/2] drm/bridge: imx: fix mixed module-builtin object Message-ID: <20230604142436.GE7754@pendragon.ideasonboard.com> References: <20230604075713.1027261-1-masahiroy@kernel.org> <20230604132602.GB7754@pendragon.ideasonboard.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Jun 04, 2023 at 10:45:07PM +0900, Masahiro Yamada wrote: > On Sun, Jun 4, 2023 at 10:26 PM Laurent Pinchart wrote: > > On Sun, Jun 04, 2023 at 04:57:12PM +0900, Masahiro Yamada wrote: > > > With CONFIG_DRM_IMX8QM_LDB=m and CONFIG_DRM_IMX8QXP_LDB=y (or vice > > > versa), imx-ldb-helper.o is linked to a module and also to vmlinux > > > even though the expected CFLAGS are different between builtins and > > > modules. > > > > > > This is the same situation as fixed by commit 637a642f5ca5 ("zstd: > > > Fixing mixed module-builtin objects"). > > > > > > Split imx-ldb-helper.c into a separate module. > > > > > > Signed-off-by: Masahiro Yamada > > > --- > > > > > > Changes in v2: > > > - Add a separate module instead of making the functions static inline > > > > > > drivers/gpu/drm/bridge/imx/Kconfig | 5 +++++ > > > drivers/gpu/drm/bridge/imx/Makefile | 5 +++-- > > > drivers/gpu/drm/bridge/imx/imx-ldb-helper.c | 20 ++++++++++++++++++++ > > > 3 files changed, 28 insertions(+), 2 deletions(-) > > > > > > diff --git a/drivers/gpu/drm/bridge/imx/Kconfig b/drivers/gpu/drm/bridge/imx/Kconfig > > > index 608f47f41bcd..9fae28db6aa7 100644 > > > --- a/drivers/gpu/drm/bridge/imx/Kconfig > > > +++ b/drivers/gpu/drm/bridge/imx/Kconfig > > > @@ -1,9 +1,13 @@ > > > if ARCH_MXC || COMPILE_TEST > > > > > > +config DRM_IMX_LDB_HELPER > > > + tristate > > > + > > > config DRM_IMX8QM_LDB > > > tristate "Freescale i.MX8QM LVDS display bridge" > > > depends on OF > > > depends on COMMON_CLK > > > + select DRM_IMX_LDB_HELPER > > > select DRM_KMS_HELPER > > > help > > > Choose this to enable the internal LVDS Display Bridge(LDB) found in > > > @@ -13,6 +17,7 @@ config DRM_IMX8QXP_LDB > > > tristate "Freescale i.MX8QXP LVDS display bridge" > > > depends on OF > > > depends on COMMON_CLK > > > + select DRM_IMX_LDB_HELPER > > > select DRM_KMS_HELPER > > > help > > > Choose this to enable the internal LVDS Display Bridge(LDB) found in > > > diff --git a/drivers/gpu/drm/bridge/imx/Makefile b/drivers/gpu/drm/bridge/imx/Makefile > > > index aa90ec8d5433..5fc821278693 100644 > > > --- a/drivers/gpu/drm/bridge/imx/Makefile > > > +++ b/drivers/gpu/drm/bridge/imx/Makefile > > > @@ -1,7 +1,8 @@ > > > -imx8qm-ldb-objs := imx-ldb-helper.o imx8qm-ldb-drv.o > > > +obj-$(CONFIG_DRM_IMX_LDB_HELPER) += imx-ldb-helper.o > > > +imx8qm-ldb-objs := imx8qm-ldb-drv.o > > > obj-$(CONFIG_DRM_IMX8QM_LDB) += imx8qm-ldb.o > > > > > > -imx8qxp-ldb-objs := imx-ldb-helper.o imx8qxp-ldb-drv.o > > > +imx8qxp-ldb-objs := imx8qxp-ldb-drv.o > > > obj-$(CONFIG_DRM_IMX8QXP_LDB) += imx8qxp-ldb.o > > > > > > obj-$(CONFIG_DRM_IMX8QXP_PIXEL_COMBINER) += imx8qxp-pixel-combiner.o > > > diff --git a/drivers/gpu/drm/bridge/imx/imx-ldb-helper.c b/drivers/gpu/drm/bridge/imx/imx-ldb-helper.c > > > index 7338b84bc83d..7382cb1fbfd7 100644 > > > --- a/drivers/gpu/drm/bridge/imx/imx-ldb-helper.c > > > +++ b/drivers/gpu/drm/bridge/imx/imx-ldb-helper.c > > > @@ -4,8 +4,10 @@ > > > * Copyright 2019,2020,2022 NXP > > > */ > > > > > > +#include > > > #include > > > #include > > > +#include > > > #include > > > #include > > > > > > @@ -15,16 +17,20 @@ > > > > > > #include "imx-ldb-helper.h" > > > > > > +#define DRIVER_NAME "imx-ldb-helper" > > > + > > > bool ldb_channel_is_single_link(struct ldb_channel *ldb_ch) > > > { > > > return ldb_ch->link_type == LDB_CH_SINGLE_LINK; > > > } > > > +EXPORT_SYMBOL_GPL(ldb_channel_is_single_link); > > > > > > bool ldb_channel_is_split_link(struct ldb_channel *ldb_ch) > > > { > > > return ldb_ch->link_type == LDB_CH_DUAL_LINK_EVEN_ODD_PIXELS || > > > ldb_ch->link_type == LDB_CH_DUAL_LINK_ODD_EVEN_PIXELS; > > > } > > > +EXPORT_SYMBOL_GPL(ldb_channel_is_split_link); > > > > > > int ldb_bridge_atomic_check_helper(struct drm_bridge *bridge, > > > struct drm_bridge_state *bridge_state, > > > @@ -38,6 +44,7 @@ int ldb_bridge_atomic_check_helper(struct drm_bridge *bridge, > > > > > > return 0; > > > } > > > +EXPORT_SYMBOL_GPL(ldb_bridge_atomic_check_helper); > > > > > > void ldb_bridge_mode_set_helper(struct drm_bridge *bridge, > > > const struct drm_display_mode *mode, > > > @@ -69,6 +76,7 @@ void ldb_bridge_mode_set_helper(struct drm_bridge *bridge, > > > break; > > > } > > > } > > > +EXPORT_SYMBOL_GPL(ldb_bridge_mode_set_helper); > > > > > > void ldb_bridge_enable_helper(struct drm_bridge *bridge) > > > { > > > @@ -81,6 +89,7 @@ void ldb_bridge_enable_helper(struct drm_bridge *bridge) > > > */ > > > regmap_write(ldb->regmap, ldb->ctrl_reg, ldb->ldb_ctrl); > > > } > > > +EXPORT_SYMBOL_GPL(ldb_bridge_enable_helper); > > > > > > void ldb_bridge_disable_helper(struct drm_bridge *bridge) > > > { > > > @@ -95,6 +104,7 @@ void ldb_bridge_disable_helper(struct drm_bridge *bridge) > > > > > > regmap_write(ldb->regmap, ldb->ctrl_reg, ldb->ldb_ctrl); > > > } > > > +EXPORT_SYMBOL_GPL(ldb_bridge_disable_helper); > > > > > > int ldb_bridge_attach_helper(struct drm_bridge *bridge, > > > enum drm_bridge_attach_flags flags) > > > @@ -117,6 +127,7 @@ int ldb_bridge_attach_helper(struct drm_bridge *bridge, > > > ldb_ch->next_bridge, bridge, > > > DRM_BRIDGE_ATTACH_NO_CONNECTOR); > > > } > > > +EXPORT_SYMBOL_GPL(ldb_bridge_attach_helper); > > > > > > int ldb_init_helper(struct ldb *ldb) > > > { > > > @@ -157,6 +168,7 @@ int ldb_init_helper(struct ldb *ldb) > > > > > > return 0; > > > } > > > +EXPORT_SYMBOL_GPL(ldb_init_helper); > > > > > > int ldb_find_next_bridge_helper(struct ldb *ldb) > > > { > > > @@ -184,6 +196,7 @@ int ldb_find_next_bridge_helper(struct ldb *ldb) > > > > > > return 0; > > > } > > > +EXPORT_SYMBOL_GPL(ldb_find_next_bridge_helper); > > > > > > void ldb_add_bridge_helper(struct ldb *ldb, > > > const struct drm_bridge_funcs *bridge_funcs) > > > @@ -204,6 +217,7 @@ void ldb_add_bridge_helper(struct ldb *ldb, > > > drm_bridge_add(&ldb_ch->bridge); > > > } > > > } > > > +EXPORT_SYMBOL_GPL(ldb_add_bridge_helper); > > > > > > void ldb_remove_bridge_helper(struct ldb *ldb) > > > { > > > @@ -219,3 +233,9 @@ void ldb_remove_bridge_helper(struct ldb *ldb) > > > drm_bridge_remove(&ldb_ch->bridge); > > > } > > > } > > > +EXPORT_SYMBOL_GPL(ldb_remove_bridge_helper); > > > + > > > +MODULE_DESCRIPTION("i.MX8 LVDS Display Bridge(LDB)/Pixel Mapper bridge helper"); > > > +MODULE_AUTHOR("Liu Ying "); > > > +MODULE_LICENSE("GPL"); > > > +MODULE_ALIAS("platform:" DRIVER_NAME); > > > > Is the alias needed ? With that fixed (if needed), > > I just tried to be consistent because all the modules > in drivers/gpu/drm/bridge/imx/ have this boilerplate. > > I do not know why MODULE_ALIAS() is needed, though. Unless I'm mistaken, it's used in those drivers to help with module auto-loading (although I wonder if it's still needed for devices that have an I2C or DT ID table). I don't think you need it here. > > Reviewed-by: Laurent Pinchart -- Regards, Laurent Pinchart