From patchwork Thu Dec 15 18:52:10 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chris Morgan X-Patchwork-Id: 13074471 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 00382C4167B for ; Thu, 15 Dec 2022 18:52:36 +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=b8lczkZza7Y3m2hJtO1Oo2i1MV4xpyu6rwbHh3/iaPs=; b=iQwtpXM8MzBVmj b9MhmEB3GSylQJWtyTi2iFEcxwlzhDEIBd/vqJYZRdHBq5OmDJtsbbrgMsImeT27sacGY+eZN1YlQ WhT9UO3pRAEKsHEIBoFl+a14CGekOsltZldoQHfsh1WSnpn8exFaAPxoWSUw0AwL9olx/y+VgdQVK sfLysU1DBRwCnK4bDrJBGve9+IXVl7XVqn6uIkhbBpXxDLO/XZKU9SSanwmrzhy8C7CF4d4ZGK9oI LsuurFNxBSe9a85b85CN+MGQs2QoBVlPbLvvK/+YOMJvTClpJ6xXxH1FsrGpG4xBBCA82BcTu1oSK KDFix4wjLwdmO64jWXPA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1p5tLI-00Au1i-Tf; Thu, 15 Dec 2022 18:52:28 +0000 Received: from mail-oa1-x35.google.com ([2001:4860:4864:20::35]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1p5tLE-00Atxj-Qm for linux-rockchip@lists.infradead.org; Thu, 15 Dec 2022 18:52:27 +0000 Received: by mail-oa1-x35.google.com with SMTP id 586e51a60fabf-1443a16b71cso367302fac.13 for ; Thu, 15 Dec 2022 10:52:21 -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=DPCglAEbRJpSIj0IExAJLedLOzM/yqHo7P3ZSPUs9oo=; b=LGXn66bUmiYQBni+DUI6/iYoDeN/AXKfYqHH0aE6bQy6PC0aRFyWmowcz8FJj1SeYX l60O25Z57EVwwBktkfdU6qyRDjKAMQ0uk57FW6t4izJuWwtN4e1yQFHIjV/6NhwRsWMM ZLB5+dpiGYye7ruxkrKZpP4ykpk1pRKErt5HXy1whQriS+dxZCBrzA0gE1C1XjgSQFQD 1ASEanzgXXqv3aRwljDpY6V7Hi3DfWLS/xISHqmEEySRY198fAPf4LmSsW04OvnYC6w6 EhRgrwL1LcRZEXnDgYzNjTPQR1xTR2pv1pKZkompGRCVxDmuj2Cts3KcXCYHYacOdGFg RY1g== 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=DPCglAEbRJpSIj0IExAJLedLOzM/yqHo7P3ZSPUs9oo=; b=M+fQtBc5RYOrW3Qt/lSro8fXOGCnIQ1ysUCSLynLzbIzcldAn6v0STkHrXkSIxKQrV EO5gzEHIExexBB+ilNy/EXIpPVw8pLKDoI2oIAl9rBt0iPl1+r03+U8p3V1y/BZXF3zn 8jXezt3DIUUilHT86bOMezwav/wZxuC0KmVDzxlJ06DVPcT0A2RKmVYlI2pOYPn+qesi z87ic9U9il6GOl4sAPd6eO2prmofazs1jFK23ThZRDwRJTdCHE2NtyrRkmX8VoHSGSmN ct+t3c5klqBZVi/9C7RgKXsbMLqEEhBykgqynGdzVve5Dma2ayZxLibS0sib7GcKgiAl B9Ow== X-Gm-Message-State: ANoB5pmJyUo4W7WfNdAm6jbRLCkT2V1FlZZuQs9akcWh6k2tOxx/Erh6 tPPShMCQFAf84AX3ke+cW1U= X-Google-Smtp-Source: AA0mqf4Iao9iuhUieQ1Fa6p/ftvl03foqbmcCxZwdLImqObZQ8V347h4jS31HVTe44oBLEWHFZJjBQ== X-Received: by 2002:a05:6870:2420:b0:144:77eb:7a7 with SMTP id n32-20020a056870242000b0014477eb07a7mr14920383oap.47.1671130340770; Thu, 15 Dec 2022 10:52:20 -0800 (PST) Received: from localhost.localdomain ([76.244.6.13]) by smtp.gmail.com with ESMTPSA id g11-20020a4ad84b000000b004a09df5a1dbsm72264oov.8.2022.12.15.10.52.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 15 Dec 2022 10:52:20 -0800 (PST) From: Chris Morgan To: dri-devel@lists.freedesktop.org Cc: devicetree@vger.kernel.org, maccraft123mc@gmail.com, tzimmermann@suse.de, mripard@kernel.org, maarten.lankhorst@linux.intel.com, heiko@sntech.de, linux-rockchip@lists.infradead.org, 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 V6 3/4] drm/panel: Add Magnachip D53E6EA8966 Panel Driver Date: Thu, 15 Dec 2022 12:52:10 -0600 Message-Id: <20221215185211.1560736-4-macroalpha82@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221215185211.1560736-1-macroalpha82@gmail.com> References: <20221215185211.1560736-1-macroalpha82@gmail.com> MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20221215_105224_930146_33498A21 X-CRM114-Status: GOOD ( 22.28 ) 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 Reviewed-by: Linus Walleij --- drivers/gpu/drm/panel/Kconfig | 11 + drivers/gpu/drm/panel/Makefile | 1 + .../drm/panel/panel-magnachip-d53e6ea8966.c | 514 ++++++++++++++++++ 3 files changed, 526 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..2aa73f8aeef3 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..ec90da8e2ae7 --- /dev/null +++ b/drivers/gpu/drm/panel/panel-magnachip-d53e6ea8966.c @@ -0,0 +1,514 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Magnachip d53e6ea8966 MIPI-DSI panel driver + * Copyright (C) 2022 Chris Morgan + */ + +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include