Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp846695ybg; Mon, 27 Jul 2020 00:45:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxe3RNy+COScrZ+NlwHKTaMe09r5LjE2xB4tm/c4cfeIx8ekRop8+xuuGGIN/4HhlO+Y9SZ X-Received: by 2002:a50:e803:: with SMTP id e3mr1776975edn.75.1595835908860; Mon, 27 Jul 2020 00:45:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595835908; cv=none; d=google.com; s=arc-20160816; b=g/tdr3uS6k+AOTZbtGQuUDbVTby7TlRm+Jy+mk8wqEFOKvUFgWDzT9DErni/jGjLbA H2yN3o7DBazcTOEhui7H+0iSA3Z2AZePt31GDeStSLoQiDkGoVn1/EEzO7KVakSaYDIc nc/jqQMzLKlJqQ4wIJQeWaHhHuMmbNOh4I/TjOh3yfy87wm/r7swYq4qS9PeDoJ0vtRX Sg/YVAb62vzcy1zJMDj/ck+DZn+67UplAXxIns8hKaaThcop/v7Hhing9ILX2a9Uz8V9 VN1uS3KIHT/B33dtd8IZcp+gv6Zt+W1HK4DUeU+pL+Z7NnStDz1TcMdjexuV3xSmAg3P 4GJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=P0AUpy2ZdCxQk1OnnLHB9v9HjjMoSPNb/b3Tq/gh12k=; b=PoEhMIjwA7sRYbXVrfAUmd4EeD6YR9dxgR9zAAWEPY604uuLejD9RoAzw9nxmncVSq myhlz04egglkGpDRA183lDati40i9RcMHyJKdOSzEh8j5dXUKTSrC9PV+J5mnaO3YJir WuLXgHgEBxleqpWKl0lIgFvHv4rhrPW9Hu4EM8YveK3EnNRwM3Ihjjz9BFdNhTvUMiW8 bqvkW5e/pW+3W9MG/IZqsxv8WIV/C1XGvfmhOqTCZr7VG0zR/PCv2fQxEOPQHApvpX96 phYxZsf2hTdgGMX4e7O34w7MkKJNVjBCVHXAYkf/IFQyxwlH0IZh7nLz8sNA+OckP2wr +S+A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="V3iN6l/h"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id fy21si1195508ejb.725.2020.07.27.00.44.47; Mon, 27 Jul 2020 00:45:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="V3iN6l/h"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727067AbgG0HoI (ORCPT + 99 others); Mon, 27 Jul 2020 03:44:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59732 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727060AbgG0HoI (ORCPT ); Mon, 27 Jul 2020 03:44:08 -0400 Received: from mail-pg1-x542.google.com (mail-pg1-x542.google.com [IPv6:2607:f8b0:4864:20::542]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F1DE4C0619D4 for ; Mon, 27 Jul 2020 00:44:07 -0700 (PDT) Received: by mail-pg1-x542.google.com with SMTP id d4so8972954pgk.4 for ; Mon, 27 Jul 2020 00:44:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=P0AUpy2ZdCxQk1OnnLHB9v9HjjMoSPNb/b3Tq/gh12k=; b=V3iN6l/harTN4h3DbAFsSaO+REmiLVeUw6BjAnWTdFO7CBkiNZ1TGrJ3p26vUN/+YN RVGJreFZ55oKdG7zS5b6IMeVc/Mhm+sLxgx8VKyNGz2HrmDsBtBcrfw24RqFON71yelU X+UG4LZpc8hZuhj+a9Tc2iCqIlTBZVdAG+QDSbyTzUw2Uv042Y1aqxNyryo6OeAUhE5/ IqAQq6ST91CVPAnYmoYrHaTFNLuQJWb1NHLhQSEiuLI9mhWWK2u7DQ2j/Hh70iPGuMBy YJDBuesSzQIL8HNTaouH1L5lkByNmXB/grQH0gjl6Qmv+Al/tjPwsvHKZ10I6mz9gnwF NjLQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=P0AUpy2ZdCxQk1OnnLHB9v9HjjMoSPNb/b3Tq/gh12k=; b=igC5F7UtmyOwBgtuQrU2H9RuEOkIbn+dNhubEQYo94JAQGncIGbNdXOBpFTH5jLhIt TmwLB5aqgRtO5yu5aCXH4jrKdYYDS8CbPWYB41sJn78L6QQ5gLFY875KJ9xjXqcQtOpD d7ux0UxVNmvkegIESrxZUHi0SqvyEEepl6AkNSQvBgcGnZJ5R7E5oiAhuHmfO/y/C0K7 VUVuORDaDmM/0bDI5yYquHMkRZqBY9iAzwvKkH2cQc+QmTu7Ry2etRiuup5WkEJkXUBt 5+Vzz37CUzFtWNvkL+5+qXz36RVC2Rz+2jQd6R4XH4IsIbzqWNxWhOBvgsUzXmtzxqdh InIg== X-Gm-Message-State: AOAM532Ndfvzuf1tXoBiXXsSmvjUYAvsuPPL2KwaSAmLrVhW8+GYtzd7 PHC8dVbu3PFQDhQvF1a+cA1jFw== X-Received: by 2002:aa7:8f2a:: with SMTP id y10mr18523587pfr.182.1595835847260; Mon, 27 Jul 2020 00:44:07 -0700 (PDT) Received: from nagraj.local ([49.206.21.239]) by smtp.gmail.com with ESMTPSA id n22sm13062152pjq.25.2020.07.27.00.44.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Jul 2020 00:44:06 -0700 (PDT) From: Sumit Semwal To: Thierry Reding , Sam Ravnborg , Rob Herring Cc: David Airlie , Daniel Vetter , Mauro Carvalho Chehab , "David S . Miller" , Rob Herring , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, Bjorn Andersson , Sumit Semwal , Benni Steini Subject: [PATCH v3 2/2] drm: panel: Add tianma nt36672a panel driver Date: Mon, 27 Jul 2020 13:13:48 +0530 Message-Id: <20200727074348.26116-3-sumit.semwal@linaro.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200727074348.26116-1-sumit.semwal@linaro.org> References: <20200727074348.26116-1-sumit.semwal@linaro.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some Poco F1 phones have an LCD panel from Tianma, model nt36672a, with a resolution of 1080x2246 that operates in DSI video mode. Add the drm panel driver for it. During testing, Benni Steini helped us fix the reset sequence timing (from 10ms to 20ms), to get the bootanimation to work on Android. With current AOSP, we need to increase it to 200ms - this seems to be a safe high value to avoid a white screen occasionally. Signed-off-by: Sumit Semwal Cc: Benni Steini --- v2: increase reset sequence timing to a safe 200ms --- MAINTAINERS | 7 + drivers/gpu/drm/panel/Kconfig | 11 + drivers/gpu/drm/panel/Makefile | 1 + drivers/gpu/drm/panel/panel-tianma-nt36672a.c | 859 ++++++++++++++++++ 4 files changed, 878 insertions(+) create mode 100644 drivers/gpu/drm/panel/panel-tianma-nt36672a.c diff --git a/MAINTAINERS b/MAINTAINERS index b4a43a9e7fbc..2d384e51353b 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -5544,6 +5544,13 @@ T: git git://anongit.freedesktop.org/drm/drm-misc F: Documentation/devicetree/bindings/display/ste,mcde.txt F: drivers/gpu/drm/mcde/ +DRM DRIVER FOR TIANMA NT36672A PANELS +M: Sumit Semwal +S: Maintained +T: git git://anongit.freedesktop.org/drm/drm-misc +F: Documentation/devicetree/bindings/display/panel/tianma,nt36672a-panel.yaml +F: drivers/gpu/drm/panel/panel-tianma-nt36672a.c + DRM DRIVER FOR TDFX VIDEO CARDS S: Orphan / Obsolete F: drivers/gpu/drm/tdfx/ diff --git a/drivers/gpu/drm/panel/Kconfig b/drivers/gpu/drm/panel/Kconfig index 39055c1f0e2f..da9d74c1ec91 100644 --- a/drivers/gpu/drm/panel/Kconfig +++ b/drivers/gpu/drm/panel/Kconfig @@ -437,6 +437,17 @@ config DRM_PANEL_TPO_TD043MTEA1 Say Y here if you want to enable support for TPO TD043MTEA1 800x480 4.3" panel (found on the OMAP3 Pandora board). +config DRM_PANEL_TIANMA_FHD_NT36672A + tristate "TIANMA NT36672A panel" + depends on OF + depends on DRM_MIPI_DSI + depends on BACKLIGHT_CLASS_DEVICE + help + Say Y here if you want to enable support for the Tianma NT36672A + panel. It is seen mostly in Xiaomi Poco F1 mobile phone. + The panel has a 1080x2246 resolution and uses 24 bit RGB per pixel. + It provides a MIPI DSI interface to the host. + config DRM_PANEL_TPO_TPG110 tristate "TPO TPG 800x400 panel" depends on OF && SPI && GPIOLIB diff --git a/drivers/gpu/drm/panel/Makefile b/drivers/gpu/drm/panel/Makefile index de74f282c433..303e44eb50fa 100644 --- a/drivers/gpu/drm/panel/Makefile +++ b/drivers/gpu/drm/panel/Makefile @@ -44,6 +44,7 @@ obj-$(CONFIG_DRM_PANEL_SITRONIX_ST7701) += panel-sitronix-st7701.o obj-$(CONFIG_DRM_PANEL_SITRONIX_ST7789V) += panel-sitronix-st7789v.o obj-$(CONFIG_DRM_PANEL_SONY_ACX424AKP) += panel-sony-acx424akp.o obj-$(CONFIG_DRM_PANEL_SONY_ACX565AKM) += panel-sony-acx565akm.o +obj-$(CONFIG_DRM_PANEL_TIANMA_FHD_NT36672A) += panel-tianma-nt36672a.o obj-$(CONFIG_DRM_PANEL_TPO_TD028TTEC1) += panel-tpo-td028ttec1.o obj-$(CONFIG_DRM_PANEL_TPO_TD043MTEA1) += panel-tpo-td043mtea1.o obj-$(CONFIG_DRM_PANEL_TPO_TPG110) += panel-tpo-tpg110.o diff --git a/drivers/gpu/drm/panel/panel-tianma-nt36672a.c b/drivers/gpu/drm/panel/panel-tianma-nt36672a.c new file mode 100644 index 000000000000..07e8461b8893 --- /dev/null +++ b/drivers/gpu/drm/panel/panel-tianma-nt36672a.c @@ -0,0 +1,859 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Copyright (C) 2020 Linaro Ltd + * Author: Sumit Semwal + */ + +#include +#include +#include +#include +#include + +#include +#include +#include + +#include +#include +#include +#include +#include + +#include