From patchwork Sat Oct 1 08:06:41 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Jagan Teki X-Patchwork-Id: 2402 Return-Path: X-Original-To: linux-amarula@patchwork.amarulasolutions.com Delivered-To: linux-amarula@patchwork.amarulasolutions.com Received: from mail-pf1-f197.google.com (mail-pf1-f197.google.com [209.85.210.197]) by ganimede.amarulasolutions.com (Postfix) with ESMTPS id 4F9753F06D for ; Sat, 1 Oct 2022 10:07:35 +0200 (CEST) Received: by mail-pf1-f197.google.com with SMTP id 2-20020a621502000000b00541081df73esf3971913pfv.9 for ; Sat, 01 Oct 2022 01:07:35 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1664611654; cv=pass; d=google.com; s=arc-20160816; b=fMAoQHbJ93NJxYZ2wdJ9V03uq6wb9PYvw0ypWkvdQ/yxUcqZfjf/wzTImcsXFsY3WR bNnkLsf405XP7mP8uYsaoRk/PvyE0W3sB2zcpCO6/X81GivJtuWRon/NLSBOd5A5Cr+e 62M72E4P1ztwLlwttrF+8AYiBALOflLjOxE6iHtr1rHdgCIyrHvMLCx8rUpBNggJRqEh nwgiHtvC/UvU5pWp08cLg/JBt4VPw9V+LrMBc9rWrcdBJmVsR1QRpw0msAlDW/id2qF9 mxQ6eIMcgKsPB1+zPwW8mvH+POBR5vA+n3/guN46V6WNa4STeWIQ0aWeQIcBTa1E+KxB J/kA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-unsubscribe:list-archive:list-help:list-post:list-id :mailing-list:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=floDY12wt6oe3XKMKRGhk4IZ3bhuwdlBFGGDrJzRy8Q=; b=UUM/hEsmTxuU5+X7a8gpWb+clugtqee90WhMsCd+wnQPRf2C1ZU/tcdSK/xzKK8LPI +buGy/dh3c3mvtAJcVyJil3wDp8PAS/S0oLuTDa4Yo7crAdXil/Zi++yg1glxp7w7SeI tEm5XC4045baSi+zT2ENYbdPYb+5u5U4mRAXycir453oHxCSHrOIZeCU/YDFLYn6Wmra VyWoRQT1uTO1C+BVWIr1fXorVNhprwKFc8CkpblgmS8/TEVXWhJG9AyzIM5+1H1W4QEn etHZiyIp+oMXyDfezldPu+ko/2WmVlOmX/hirAUVxwMi6HD8wF8wenBtRo447+cRDZF3 ZDrQ== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=NNbEWZVK; spf=pass (google.com: domain of jagan@amarulasolutions.com designates 209.85.220.41 as permitted sender) smtp.mailfrom=jagan@amarulasolutions.com; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=amarulasolutions.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=list-unsubscribe:list-archive:list-help:list-post:list-id :mailing-list:precedence:x-original-authentication-results :x-original-sender:content-transfer-encoding:mime-version:references :in-reply-to:message-id:date:subject:cc:to:from:from:to:cc:subject :date; bh=floDY12wt6oe3XKMKRGhk4IZ3bhuwdlBFGGDrJzRy8Q=; b=Iax5Y1R8eHSl+Yw2fvk0VQ7bMdjaNpMMe6R8I4kVHJPQS6ECJv1yrXe+fg/PL3MI10 soJ9kWt26L4ILrRUfd33238idlXA6LBTZHZahcXRf01zA0UKLedlY0bAv79xzE/sI1ru /6GUoJKRI4wB6dGFmtRnmZh9mPiXtzO/bLyMs= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=list-unsubscribe:list-archive:list-help:list-post :x-spam-checked-in-group:list-id:mailing-list:precedence :x-original-authentication-results:x-original-sender :content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date; bh=floDY12wt6oe3XKMKRGhk4IZ3bhuwdlBFGGDrJzRy8Q=; b=DmMoS077u7RXzChBHqky8Uz+CHQNFFCQIcNJSd9GaWBtE18P4ECwM2rlT1b1MTHaH9 b5ScHie82LGmAjvLsXkBFBWHee6MUnf2q+WppkYHTb+vUWSp54lzFivkGXxvBdix2X+d H4a9P4rgH9CAXW1OMOv39Yo2ctsN0g4r905oe1J5DHJ8ZRoDWU0MG8W0eh1epy2ywOyl u7ai7/o1XQuJ6wmVlNV8uru9DyzISidbil7mz3LYtoNZZZUe3eHx9bIjrRW6XB73kJ6e ZU/P5mvcCcf7Th1j7Jm/xloPASkLfFZLO04J20jaSjuN6Hx1ZIQdLsqdLJBjsjP+oS+x CeRA== X-Gm-Message-State: ACrzQf2OQlDELhHz5UMgFDPCaN9/trgpZm2j5/Uq0IdJkyuBWKITqZCH pHeOi7e3NdMe6c22gYw/8ekH3PuD X-Google-Smtp-Source: AMsMyM6g0yUBzO40pFjtE3HE8BCE/xWbqYP9eIFlWtQHB+uFakU3oo75bTB34nzrjpi8e2gmXuMU6g== X-Received: by 2002:aa7:810a:0:b0:55b:674d:d123 with SMTP id b10-20020aa7810a000000b0055b674dd123mr7773317pfi.52.1664611653892; Sat, 01 Oct 2022 01:07:33 -0700 (PDT) X-BeenThere: linux-amarula@amarulasolutions.com Received: by 2002:a63:181:0:b0:43c:e346:6c2f with SMTP id 123-20020a630181000000b0043ce3466c2fls3747717pgb.3.-pod-prod-gmail; Sat, 01 Oct 2022 01:07:33 -0700 (PDT) X-Received: by 2002:a05:6a00:b92:b0:545:e8c5:8945 with SMTP id g18-20020a056a000b9200b00545e8c58945mr12682343pfj.56.1664611652720; Sat, 01 Oct 2022 01:07:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664611652; cv=none; d=google.com; s=arc-20160816; b=WFZ87IxbV7uQOIio8zBWkXCEyXEeYrp/h3U0W04Jz8mQABem586IZ4llkbqgkcUTK8 BoJimKj6K2YQ2RYctDh/jziqLuvCX1gYEnVRFrbqw1Z3b0C4NBOXTqxGwrunkWDV6ZWX SelSCwLjLVMv+yzGR7jv7E+WBTp/5CSCvnkfI6tuFvJ0ods4M6NmUiTJt31hI1jw9kKD 9T22tR+L+Ds4m/COv0AdJeHfTdr0TqQBhkGbUGkRWV+D9SMjg/zqCnUxOyqs9waMDubD PmVx/OytkFAbHFp2G0j1HGrIRPzcQVN4/pztgd9ztRhGQGE/wzoVwyIc0uF2o65wuuja kyvw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=ubDxt/vmVl9+h6PTD2Ljf5mNLiTIRIkHFwdGOzqb37k=; b=mr/T1+gE/Wm8JwJ2RXj/DuIVWWSrPanO24IWkfX+jdYGeebmS9e2EJoX+YuKQ1Asl4 v/aUcjKckpLqMLi46R5H5IaJnmzHtB0AxQ0NHkWhcJK2sd+hEcUWUA3OFCr2xFFOirsH I1v45+9g2BfYHydcRKOPfAV/QVcugt3WptvIUOc4WgbBzx3Dcnfu/X4c8hlrU0N/sgn0 2XbaIzmk4W7VAmRNvqN2i2Si+YiZ8YW6/P6+Ch90FuNETIULWXUBwY4L+8rRi0TsGtMK OtTwg+Jmf4Lt1+bG5jIREfT73detq2AMQUzo7u5Pv8ESit+gb5DzhpAXQaGVxtHC+79k 97lA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=NNbEWZVK; spf=pass (google.com: domain of jagan@amarulasolutions.com designates 209.85.220.41 as permitted sender) smtp.mailfrom=jagan@amarulasolutions.com; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=amarulasolutions.com Received: from mail-sor-f41.google.com (mail-sor-f41.google.com. [209.85.220.41]) by mx.google.com with SMTPS id lj1-20020a17090b344100b002003bb0489bsor1779140pjb.33.2022.10.01.01.07.32 for (Google Transport Security); Sat, 01 Oct 2022 01:07:32 -0700 (PDT) Received-SPF: pass (google.com: domain of jagan@amarulasolutions.com designates 209.85.220.41 as permitted sender) client-ip=209.85.220.41; X-Received: by 2002:a17:90b:4a89:b0:202:b1b7:7ae with SMTP id lp9-20020a17090b4a8900b00202b1b707aemr2253475pjb.149.1664611651742; Sat, 01 Oct 2022 01:07:31 -0700 (PDT) Received: from localhost.localdomain ([2405:201:c00a:a073:7254:4392:bc7c:c69]) by smtp.gmail.com with ESMTPSA id c194-20020a624ecb000000b005409c9d2d41sm3167041pfb.62.2022.10.01.01.07.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 01 Oct 2022 01:07:31 -0700 (PDT) From: Jagan Teki To: Andrzej Hajda , Inki Dae , Marek Szyprowski , Joonyoung Shim , Seung-Woo Kim , Kyungmin Park , Frieder Schrempf , Fancy Fang , Tim Harvey , Michael Nazzareno Trimarchi , Adam Ford , Neil Armstrong , Robert Foss , Laurent Pinchart , Tommaso Merciai , Marek Vasut Cc: Matteo Lisi , dri-devel@lists.freedesktop.org, linux-samsung-soc@vger.kernel.org, linux-arm-kernel@lists.infradead.org, NXP Linux Team , linux-amarula , Jagan Teki Subject: [PATCH v6 01/10] drm: bridge: Add Samsung DSIM bridge driver Date: Sat, 1 Oct 2022 13:36:41 +0530 Message-Id: <20221001080650.1007043-2-jagan@amarulasolutions.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20221001080650.1007043-1-jagan@amarulasolutions.com> References: <20221001080650.1007043-1-jagan@amarulasolutions.com> MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" X-Original-Sender: jagan@amarulasolutions.com X-Original-Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=NNbEWZVK; spf=pass (google.com: domain of jagan@amarulasolutions.com designates 209.85.220.41 as permitted sender) smtp.mailfrom=jagan@amarulasolutions.com; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=amarulasolutions.com Precedence: list Mailing-list: list linux-amarula@amarulasolutions.com; contact linux-amarula+owners@amarulasolutions.com List-ID: X-Spam-Checked-In-Group: linux-amarula@amarulasolutions.com X-Google-Group-Id: 476853432473 List-Post: , List-Help: , List-Archive: List-Unsubscribe: , Samsung MIPI DSIM controller is common DSI IP that can be used in various SoCs like Exynos, i.MX8M Mini/Nano. In order to access this DSI controller between various platform SoCs, the ideal way to incorporate this in the drm stack is via the drm bridge driver. This patch is trying to differentiate platform-specific and bridge driver code by maintaining exynos platform glue code in exynos_drm_dsi.c driver and common bridge driver code in samsung-dsim.c providing that the new platform-specific glue should be supported in the bridge driver, unlike exynos platform drm drivers. - Add samsung_dsim_plat_data for keeping platform-specific attributes like host_ops, irq_ops, and hw_type. - Initialize the plat_data hooks for exynos platform in exynos_drm_dsi.c. - samsung_dsim_probe is the common probe call across exynos_drm_dsi.c and samsung-dsim.c. - plat_data hooks like host_ops and irq_ops are invoked during the respective bridge call chains. v6: * handle previous bridge pointer for exynos dsi v5: * [mszyprow] reworked driver initialization using the same approach as in drivers/gpu/drm/{exynos/exynos_dp.c, bridge/analogix/analogix_dp_core.c}, removed weak functions, moved exynos_dsi_driver back to exynos_drm_dsi.c and restored integration with exynos_drm custom initialization. * updated the commit message [Jagan] v4: * include Inki Dae in MAINTAINERS * remove dsi_driver probe in exynos_drm_drv to support multi-arch build v3: * restore gpio related fixes * restore proper bridge chain * rework initialization issue * fix header includes in proper way v2: * fixed exynos dsi driver conversion (Marek Szyprowski) * updated commit message * updated MAINTAINERS file v1: * don't maintain component_ops in bridge driver * don't maintain platform glue code in bridge driver * add platform-specific glue code and make a common bridge Signed-off-by: Marek Szyprowski Signed-off-by: Jagan Teki --- MAINTAINERS | 9 + drivers/gpu/drm/bridge/Kconfig | 12 + drivers/gpu/drm/bridge/Makefile | 1 + drivers/gpu/drm/bridge/samsung-dsim.c | 1703 ++++++++++++++++++++++ drivers/gpu/drm/exynos/Kconfig | 1 + drivers/gpu/drm/exynos/exynos_drm_dsi.c | 1769 ++--------------------- include/drm/bridge/samsung-dsim.h | 113 ++ 7 files changed, 1955 insertions(+), 1653 deletions(-) create mode 100644 drivers/gpu/drm/bridge/samsung-dsim.c create mode 100644 include/drm/bridge/samsung-dsim.h diff --git a/MAINTAINERS b/MAINTAINERS index 9ae989b32ebb..ba7a6721443c 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -6624,6 +6624,15 @@ T: git git://anongit.freedesktop.org/drm/drm-misc F: Documentation/devicetree/bindings/display/panel/samsung,lms397kf04.yaml F: drivers/gpu/drm/panel/panel-samsung-db7430.c +DRM DRIVER FOR SAMSUNG MIPI DSIM BRIDGE +M: Jagan Teki +M: Marek Szyprowski +M: Inki Dae S: Maintained diff --git a/drivers/gpu/drm/bridge/Kconfig b/drivers/gpu/drm/bridge/Kconfig index 57946d80b02d..8e85dac9f53e 100644 --- a/drivers/gpu/drm/bridge/Kconfig +++ b/drivers/gpu/drm/bridge/Kconfig @@ -231,6 +231,18 @@ config DRM_PARADE_PS8640 The PS8640 is a high-performance and low-power MIPI DSI to eDP converter +config DRM_SAMSUNG_DSIM + tristate "Samsung MIPI DSIM bridge driver" + depends on COMMON_CLK + depends on OF && HAS_IOMEM + select DRM_KMS_HELPER + select DRM_MIPI_DSI + select DRM_PANEL_BRIDGE + help + The Samsung MIPI DSIM bridge controller driver. + This MIPI DSIM bridge can be found it on Exynos SoCs and + NXP's i.MX8M Mini/Nano. + config DRM_SIL_SII8620 tristate "Silicon Image SII8620 HDMI/MHL bridge" depends on OF diff --git a/drivers/gpu/drm/bridge/Makefile b/drivers/gpu/drm/bridge/Makefile index 1884803c6860..dae843723991 100644 --- a/drivers/gpu/drm/bridge/Makefile +++ b/drivers/gpu/drm/bridge/Makefile @@ -15,6 +15,7 @@ obj-$(CONFIG_DRM_MEGACHIPS_STDPXXXX_GE_B850V3_FW) += megachips-stdpxxxx-ge-b850v obj-$(CONFIG_DRM_NXP_PTN3460) += nxp-ptn3460.o obj-$(CONFIG_DRM_PARADE_PS8622) += parade-ps8622.o obj-$(CONFIG_DRM_PARADE_PS8640) += parade-ps8640.o +obj-$(CONFIG_DRM_SAMSUNG_DSIM) += samsung-dsim.o obj-$(CONFIG_DRM_SIL_SII8620) += sil-sii8620.o obj-$(CONFIG_DRM_SII902X) += sii902x.o obj-$(CONFIG_DRM_SII9234) += sii9234.o diff --git a/drivers/gpu/drm/bridge/samsung-dsim.c b/drivers/gpu/drm/bridge/samsung-dsim.c new file mode 100644 index 000000000000..73dcd825c654 --- /dev/null +++ b/drivers/gpu/drm/bridge/samsung-dsim.c @@ -0,0 +1,1703 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Samsung MIPI DSIM bridge driver. + * + * Copyright (C) 2021 Amarula Solutions(India) + * Copyright (c) 2014 Samsung Electronics Co., Ltd + * Author: Jagan Teki + * + * Based on exynos_drm_dsi from + * Tomasz Figa + */ + +#include + +#include +#include +#include +#include +#include + +#include