From patchwork Wed Jan 11 16:30:11 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chris Morgan X-Patchwork-Id: 13096931 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id D77FAC54EBC for ; Wed, 11 Jan 2023 16:30:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=qJpM+BjxDoDFtD5x3Fh/7mwsofZfcP5M6m4s7YLABEc=; b=nZLWHTAKVIpRv6 fBtXnl1sVgPsBRB7kQJ+I7dzH7I9fpg1elUtRZR8XQZe4rHU8o5LK6mWi0FKTTidckjJ/+NDMRDb5 jgLKs7MyAqWavVak9D4D/olyU5Z6z0e/Mc4R8ZsI75mJWu3WmgwVnMrUMf/oAOGfIJSJAav4s8KNA NLzsQwsx/eiAhUBm/iZ/XSZ1IOfJUrGxAgQKEE36WwlXzfi1hyWCeN2VPuOnD8JZPzk66rci+NU3r MPAW9NwSKYi47KiPxSYF5DQIxlM2wCVViFnitA9T7EVs7WvRM7Qqpm94kym79S6NLY4Lbqd9xRFcR WZe5TaNz1gfb/5/u8dvw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1pFdzj-00CAiG-7s; Wed, 11 Jan 2023 16:30:31 +0000 Received: from mail-oa1-x36.google.com ([2001:4860:4864:20::36]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1pFdzc-00CAeU-Ob for linux-rockchip@lists.infradead.org; Wed, 11 Jan 2023 16:30:27 +0000 Received: by mail-oa1-x36.google.com with SMTP id 586e51a60fabf-150debe2b7cso16157150fac.0 for ; Wed, 11 Jan 2023 08:30:24 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=Ug9Qalu5EQh2ykE3eLRnhG5I3plTxJnHDwIw/1EQhJ8=; b=VtR+OrCVZbhFyS0t9lG0yMTWeKF5YHNYvH48cuNDc+maj3lSo1gcqwBzcdjJ5hUdry bKyEaDYOksoexlQnx70WwajoMQqvsX0ZdvW1ZDescJWTHnafcPZikr+wQ+qDap0zXqJy Agp7Bw2PpwbDKjypCyikUyxkx7SiBvKy1XgWhgtw0sfB4ORu16x+5x4YLOhKVxQH1pV3 LivmXjtYD46cTSkoN0PsTwlMqhe3nnPJ+3uII4coBuMIWP21kTiWFM2akATatFi7qmDv RFjBBPkpl7V5glOPPaEVgOIhRR3GrDo2ePvLeojidfVLLXTbXbB2+bRIzXbPzLv65Ofw 7/Xg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=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:message-id:reply-to; bh=Ug9Qalu5EQh2ykE3eLRnhG5I3plTxJnHDwIw/1EQhJ8=; b=NN8CedTiGXvvbf9O82HTFd+yRKtiqiQ4toO0KM+jHA2atLLL++DQV3Neb+9kDOOnlS cW9P2bSZEb6xpEVHmJI76te6uN+Tih0coPzilPPkCCWdWBxsUKXY8hbEWljiLiTvIDxN g3aXRqPgBRX/J8RhTG4LtZnWd7A9cIj9ErYXlXK1ipIaaIj+l+xBd9pn6TpMobEZ6WSu 3BEGjpv+nEQpON2cewO1+lEjOGhUYV854Fl6q/5tSid8MRBo+mT4yXWrQE2GzqsOe6lw unnxfF1dPwcmOO5wUY7NibJdk6sVfRaHYlSpPoxu0kEEQmvOgqjczD/Ea9/CXJSuMIp0 MWog== X-Gm-Message-State: AFqh2krpIB3joFHnmAs6QIHJC9gO/2FlcIvkrImAJW+MDfsf5T1fEO2e GhRGS7IyuUh6Tnnc/jflEC0= X-Google-Smtp-Source: AMrXdXs8aiaUa41cpYoWafAJ8VopY2MHpG6lH4II5rzZGR3LSPh3oC4rkO+ULWZoCv7Z/nFTWU1MTQ== X-Received: by 2002:a05:6871:8508:b0:15b:8fc1:fb14 with SMTP id sx8-20020a056871850800b0015b8fc1fb14mr4579135oab.33.1673454623741; Wed, 11 Jan 2023 08:30:23 -0800 (PST) Received: from localhost.localdomain (76-244-6-13.lightspeed.rcsntx.sbcglobal.net. [76.244.6.13]) by smtp.gmail.com with ESMTPSA id z13-20020a056870738d00b0013ae39d0575sm7629003oam.15.2023.01.11.08.30.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 11 Jan 2023 08:30:23 -0800 (PST) From: Chris Morgan To: dri-devel@lists.freedesktop.org Cc: linux-rockchip@lists.infradead.org, devicetree@vger.kernel.org, maccraft123mc@gmail.com, tzimmermann@suse.de, mripard@kernel.org, maarten.lankhorst@linux.intel.com, heiko@sntech.de, krzysztof.kozlowski+dt@linaro.org, robh+dt@kernel.org, daniel@ffwll.ch, airlied@gmail.com, sam@ravnborg.org, thierry.reding@gmail.com, linus.walleij@linaro.org, Chris Morgan Subject: [PATCH v9 3/4] drm/panel: Add Magnachip D53E6EA8966 Panel Driver Date: Wed, 11 Jan 2023 10:30:11 -0600 Message-Id: <20230111163012.310945-4-macroalpha82@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230111163012.310945-1-macroalpha82@gmail.com> References: <20230111163012.310945-1-macroalpha82@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230111_083024_843114_54CB6873 X-CRM114-Status: GOOD ( 21.78 ) X-BeenThere: linux-rockchip@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: Upstream kernel work for Rockchip platforms List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "Linux-rockchip" Errors-To: linux-rockchip-bounces+linux-rockchip=archiver.kernel.org@lists.infradead.org From: Chris Morgan Support Magnachip D53E6EA8966 based panels such as the Samsung AMS495QA01 panel as found on the Anbernic RG503. Note this driver supports only the AMS495QA01 today which receives video signals via DSI, however it receives commands via 3-wire SPI using DBI. Signed-off-by: Chris Morgan Signed-off-by: Maya Matuszczyk --- drivers/gpu/drm/panel/Kconfig | 11 + drivers/gpu/drm/panel/Makefile | 1 + .../drm/panel/panel-magnachip-d53e6ea8966.c | 522 ++++++++++++++++++ 3 files changed, 534 insertions(+) create mode 100644 drivers/gpu/drm/panel/panel-magnachip-d53e6ea8966.c diff --git a/drivers/gpu/drm/panel/Kconfig b/drivers/gpu/drm/panel/Kconfig index 737edcdf9eef..204b84a83604 100644 --- a/drivers/gpu/drm/panel/Kconfig +++ b/drivers/gpu/drm/panel/Kconfig @@ -298,6 +298,17 @@ config DRM_PANEL_LG_LG4573 Say Y here if you want to enable support for LG4573 RGB panel. To compile this driver as a module, choose M here. +config DRM_PANEL_MAGNACHIP_D53E6EA8966 + tristate "Magnachip D53E6EA8966 DSI panel" + depends on OF && SPI + depends on DRM_MIPI_DSI + depends on BACKLIGHT_CLASS_DEVICE + select DRM_MIPI_DBI + help + DRM panel driver for the Samsung AMS495QA01 panel controlled + with the Magnachip D53E6EA8966 panel IC. This panel receives + video data via DSI but commands via 9-bit SPI using DBI. + config DRM_PANEL_NEC_NL8048HL11 tristate "NEC NL8048HL11 RGB panel" depends on GPIOLIB && OF && SPI diff --git a/drivers/gpu/drm/panel/Makefile b/drivers/gpu/drm/panel/Makefile index f8f9d9f6a307..20de312aa5e9 100644 --- a/drivers/gpu/drm/panel/Makefile +++ b/drivers/gpu/drm/panel/Makefile @@ -27,6 +27,7 @@ obj-$(CONFIG_DRM_PANEL_LEADTEK_LTK050H3146W) += panel-leadtek-ltk050h3146w.o obj-$(CONFIG_DRM_PANEL_LEADTEK_LTK500HD1829) += panel-leadtek-ltk500hd1829.o obj-$(CONFIG_DRM_PANEL_LG_LB035Q02) += panel-lg-lb035q02.o obj-$(CONFIG_DRM_PANEL_LG_LG4573) += panel-lg-lg4573.o +obj-$(CONFIG_DRM_PANEL_MAGNACHIP_D53E6EA8966) += panel-magnachip-d53e6ea8966.o obj-$(CONFIG_DRM_PANEL_NEC_NL8048HL11) += panel-nec-nl8048hl11.o obj-$(CONFIG_DRM_PANEL_NEWVISION_NV3051D) += panel-newvision-nv3051d.o obj-$(CONFIG_DRM_PANEL_NEWVISION_NV3052C) += panel-newvision-nv3052c.o diff --git a/drivers/gpu/drm/panel/panel-magnachip-d53e6ea8966.c b/drivers/gpu/drm/panel/panel-magnachip-d53e6ea8966.c new file mode 100644 index 000000000000..09ee12f0a147 --- /dev/null +++ b/drivers/gpu/drm/panel/panel-magnachip-d53e6ea8966.c @@ -0,0 +1,522 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Magnachip d53e6ea8966 MIPI-DSI panel driver + * Copyright (C) 2023 Chris Morgan + */ + +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include