From patchwork Tue Jun 10 19:09:21 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Luca Weiss X-Patchwork-Id: 896745 Received: from ahti.lucaweiss.eu (ahti.lucaweiss.eu [128.199.32.197]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 542CA261362; Tue, 10 Jun 2025 19:10:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=128.199.32.197 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1749582625; cv=none; b=KtnIvnlKLKQSLhvDaArh/r1KGiAA9fMleFmxreCT/JyjKDV8lypdFe6IT+VM8lojM35TxeUxWmWyfvzTKe1DI4plMhCmmGfhpsYS0DmsdPWIxDlklTfGNAHKhWtTsvdY2DVHo21Kkn38shSWXoq/cZhYD1PHvRgfc/5fAhZEXoM= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1749582625; c=relaxed/simple; bh=fRx46KkayEzsivJFvBrNSxcXpzAiz7fIHTubaBETNEM=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=unE/a1aSjUlrCvdXbX6zPRrUzaSPEXwJK8zmIZyY9SnF/SiamemWrVmdrjOmhGKXty7NzmqZBT9f7jnGo9Sb/XQTZNxWD7uDHJC+rG20FkIucAwrs4BmCx2aJp0UtskLiBc7uqNJvCx2wtOW47MM73XT3RrrK+deOnOzH6DgMZg= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=lucaweiss.eu; spf=pass smtp.mailfrom=lucaweiss.eu; dkim=pass (1024-bit key) header.d=lucaweiss.eu header.i=@lucaweiss.eu header.b=KtPPCaRY; arc=none smtp.client-ip=128.199.32.197 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=lucaweiss.eu Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=lucaweiss.eu Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=lucaweiss.eu header.i=@lucaweiss.eu header.b="KtPPCaRY" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=lucaweiss.eu; s=s1; t=1749582621; bh=fRx46KkayEzsivJFvBrNSxcXpzAiz7fIHTubaBETNEM=; h=From:Date:Subject:References:In-Reply-To:To:Cc; b=KtPPCaRY5KXO6YVzCd6REihBUQGz4XjMr7t6nQCoF9FVCi0ButqZgt1yERaGkdCaJ CmcWjWQsMkd1d63yXNGW3HkWiiJ3NqP1D1h9PqdZdx8kh5dlqw2aHthbilASPkDrQF I42OSrLBhE1H+u3HfCC3b7VlEZFgyzFu+yfZUvAM= From: Luca Weiss Date: Tue, 10 Jun 2025 21:09:21 +0200 Subject: [PATCH v3 3/4] drm/panel: Add driver for DJN HX83112B LCD panel Precedence: bulk X-Mailing-List: linux-arm-msm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Message-Id: <20250610-fp3-display-v3-3-e7e7561812e1@lucaweiss.eu> References: <20250610-fp3-display-v3-0-e7e7561812e1@lucaweiss.eu> In-Reply-To: <20250610-fp3-display-v3-0-e7e7561812e1@lucaweiss.eu> To: ~postmarketos/upstreaming@lists.sr.ht, phone-devel@vger.kernel.org, Neil Armstrong , Jessica Zhang , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Bjorn Andersson , Konrad Dybcio Cc: dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, Luca Weiss , Dmitry Baryshkov X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=openpgp-sha256; l=18991; i=luca@lucaweiss.eu; h=from:subject:message-id; bh=fRx46KkayEzsivJFvBrNSxcXpzAiz7fIHTubaBETNEM=; b=kA0DAAoBcthDuJ1N11YByyZiAGhIgxqgRMehPjhArAL/gexdr/90bhPksr0McM3j1mzLG+uRF 4kCMwQAAQoAHRYhBDm60i8ILNqRuhWP+nLYQ7idTddWBQJoSIMaAAoJEHLYQ7idTddW+jUP/3eh FD8w1mfdDlPmkKdROOfC0lPf6kZZyRCMo71vKQIm5fkpRS4LMns2qGGyi5yBXEYYI266fVkqL0H /qLbaBQHEox+ECFMl+aTCycg187gekCu6leiE4LIp9j9yX0dd51XH+7bIH8NpYycArxsn1JgmzA JDEQvOU2WUysye9ShH5mDBZCCx+OWIKs5U9ZAZ6fl1+J2pnxWR25S+mQkzWyN4ji5WKuMDJ1Acs 1U9m6oE1LCNxQFUQryRgXbvhbt5frrLye5yS/+rL/tCQYDz//6Vl8Bd6xfrT8Q9M0Px3H0Mam+p 2pGtkPBYY/wiVlyX5Ucki4bUD0TDpJ/6oZ/q653oF4A6RZDPAo3N2szIpVHB0ILikmKU3nUEPAC siWbqVMtOBWMvQ6PXjXq+qXyoTVdVbaXHF87aEmf1JBD8x+7lCo8rJDrQEFQGEinTZs+COaSetH riMfnRlYChPxV6ZXTCb/4Z/EWcXOOfPE1Fy0xuDWe5hm2FdL7pjymPex9WicSuMixpzL++zJtlO sg2mRrfr0tS0uNW7kVviJViCh7w7yfPeftKf/nS9/e3YTwB0jHajcMirYFJ+uRGSqXoI0nRDCja 129Q4OJsUIYBJFQ9sex3WjmjsJ1/vF4lpL8YoCfLzeeV7ngfyMv2Qoq/AcbouDHm2Qjd+rla9Ba gDJds X-Developer-Key: i=luca@lucaweiss.eu; a=openpgp; fpr=BD04DA24C971B8D587B2B8D7FAF69CF6CD2D02CD Add support for the 2160x1080 LCD panel from DJN (98-03057-6598B-I) bundled with a HX83112B driver IC, as found on the Fairphone 3 smartphone. Reviewed-by: Dmitry Baryshkov Signed-off-by: Luca Weiss --- drivers/gpu/drm/panel/Kconfig | 10 + drivers/gpu/drm/panel/Makefile | 1 + drivers/gpu/drm/panel/panel-himax-hx83112b.c | 430 +++++++++++++++++++++++++++ 3 files changed, 441 insertions(+) diff --git a/drivers/gpu/drm/panel/Kconfig b/drivers/gpu/drm/panel/Kconfig index cfebb08e8a62680a14a500d28decfafc2daf743a..deee941ffa707f0795f5edd9349eddebc33e0958 100644 --- a/drivers/gpu/drm/panel/Kconfig +++ b/drivers/gpu/drm/panel/Kconfig @@ -193,6 +193,16 @@ config DRM_PANEL_HIMAX_HX83112A Say Y here if you want to enable support for Himax HX83112A-based display panels, such as the one found in the Fairphone 4 smartphone. +config DRM_PANEL_HIMAX_HX83112B + tristate "Himax HX83112B-based DSI panel" + depends on OF + depends on DRM_MIPI_DSI + depends on BACKLIGHT_CLASS_DEVICE + select DRM_KMS_HELPER + help + Say Y here if you want to enable support for Himax HX83112B-based + display panels, such as the one found in the Fairphone 3 smartphone. + config DRM_PANEL_HIMAX_HX8394 tristate "HIMAX HX8394 MIPI-DSI LCD panels" depends on OF diff --git a/drivers/gpu/drm/panel/Makefile b/drivers/gpu/drm/panel/Makefile index 714cbac830e3f0be3659f1907c5dbacef863bbd8..5f61b4542b28d013b6475d1a6b84bfe912551e9c 100644 --- a/drivers/gpu/drm/panel/Makefile +++ b/drivers/gpu/drm/panel/Makefile @@ -20,6 +20,7 @@ obj-$(CONFIG_DRM_PANEL_FEIYANG_FY07024DI26A30D) += panel-feiyang-fy07024di26a30d obj-$(CONFIG_DRM_PANEL_HIMAX_HX8279) += panel-himax-hx8279.o obj-$(CONFIG_DRM_PANEL_HIMAX_HX83102) += panel-himax-hx83102.o obj-$(CONFIG_DRM_PANEL_HIMAX_HX83112A) += panel-himax-hx83112a.o +obj-$(CONFIG_DRM_PANEL_HIMAX_HX83112B) += panel-himax-hx83112b.o obj-$(CONFIG_DRM_PANEL_HIMAX_HX8394) += panel-himax-hx8394.o obj-$(CONFIG_DRM_PANEL_ILITEK_IL9322) += panel-ilitek-ili9322.o obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9341) += panel-ilitek-ili9341.o diff --git a/drivers/gpu/drm/panel/panel-himax-hx83112b.c b/drivers/gpu/drm/panel/panel-himax-hx83112b.c new file mode 100644 index 0000000000000000000000000000000000000000..d9b37416a30a221fd956c7754e00108166f364ab --- /dev/null +++ b/drivers/gpu/drm/panel/panel-himax-hx83112b.c @@ -0,0 +1,430 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Generated with linux-mdss-dsi-panel-driver-generator from vendor device tree. + * Copyright (c) 2025 Luca Weiss + */ + +#include +#include +#include +#include +#include +#include + +#include