From mboxrd@z Thu Jan 1 00:00:00 1970 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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id EA8F7C77B7A for ; Wed, 7 Jun 2023 15:11:49 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241274AbjFGPLs (ORCPT ); Wed, 7 Jun 2023 11:11:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55664 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241286AbjFGPLp (ORCPT ); Wed, 7 Jun 2023 11:11:45 -0400 Received: from mail-ej1-x629.google.com (mail-ej1-x629.google.com [IPv6:2a00:1450:4864:20::629]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D4F271734; Wed, 7 Jun 2023 08:11:42 -0700 (PDT) Received: by mail-ej1-x629.google.com with SMTP id a640c23a62f3a-973f78329e3so1217625866b.3; Wed, 07 Jun 2023 08:11:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1686150701; x=1688742701; 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=gUBjVqJOJshn+aoB0YpUZ3QQ2c92NN/VgddOCuffR24=; b=kg0nRJ6hxH3iNtpDkwZ59eysu/Y1id9CkCDFoOD7lUp+9PqXFG+thoUna0VKW+B0IX MKdu6bEe7WbM8BoeE0L4n7GENyBfmP3hYqkZfSHZIhlGhPdJOje6zr2yWoXwZR5IZGy0 YswUlaqwJ+vL4BagrLgzBvcyh4tZkBylzQCrdA2eDtzPRsg8+hOU0C9P9oVhbhLoJAU/ 2pQG/irv9E+2Xab3clSZW9Lxfdd+6oK6pyHTJKcvu9mr0OQQb+Vx7V625IKxzSgBjjtQ zIPLZtzMiGti+U8ElnZQIiz6jFXQPMcwbYghRlV2mUf9xWFa+N8lhQjUONl49IfaXpGb aYdg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1686150701; x=1688742701; 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=gUBjVqJOJshn+aoB0YpUZ3QQ2c92NN/VgddOCuffR24=; b=EcYp8m6bsiETFOcSoz3Xqc1I01fkTO5vwqPBAE76BFyPm7KOODymdYQSmLeE4YTMD0 FBmmNGF8LL40h4hXDDwcIA1/6m5nbGjvEVgQC3FeMB2wmcA1l9GB/A8yvP6Y3pcpEkJQ PmtAHqvGvXMskEAazm7/KAvUaQx7onIZnGdZE6Nm9Cfr1z8RdAMulIOQgfvX01q84xGd FAKe2ppJLhBG845dKt+Zgx0izjG6xNsgZ9etRzUHKJLN4blttJ9/Zy/+qOOmgwZHsQIz eO1Qom1FG0sR9EdEb1mRBNUjFp/rARfErFuYMRRjBRP5R0fUD29UUN5iGSQcvSuSsFIc WOOQ== X-Gm-Message-State: AC+VfDzVWKNjWoaxeYSvDXcHKs+QHXsEo3/e5ANG9Ri8elfOpn7CwXsX J1M9KkIX4mnAJFHwQDKJblBd0zAwmYrh/wOP X-Google-Smtp-Source: ACHHUZ5bLiEa7rFIYyM1+A7BogDprhnpioIYQmfaZay9DRZzGaSjOcLF26buM1hrH7YLtHUk69662g== X-Received: by 2002:a17:907:6ea3:b0:966:2123:e0ca with SMTP id sh35-20020a1709076ea300b009662123e0camr7426493ejc.34.1686150700910; Wed, 07 Jun 2023 08:11:40 -0700 (PDT) Received: from fedora.. ([46.188.160.176]) by smtp.gmail.com with ESMTPSA id m19-20020a170906235300b00967a18df1easm7006222eja.117.2023.06.07.08.11.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 07 Jun 2023 08:11:40 -0700 (PDT) From: Paulo Pavacic To: neil.armstrong@linaro.org, sam@ravnborg.org, airlied@gmail.com, daniel@ffwll.ch, robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Paulo Pavacic Subject: [PATCH v4 3/3] drm/panel-fannal-c3004: Add fannal c3004 DSI panel Date: Wed, 7 Jun 2023 17:11:27 +0200 Message-Id: <20230607151127.1542024-4-pavacic.p@gmail.com> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20230607151127.1542024-1-pavacic.p@gmail.com> References: <20230607151127.1542024-1-pavacic.p@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Fannal C3004 is a 480x800 display made by fannal that requires DCS initialization sequences. Signed-off-by: Paulo Pavacic --- v4 changelog: - removal of blank lines, code wrapping changes - reset pin initialization handling changes v3 changelog: - formatting and style changes - remove BIT_NONEXCLUSIVE flag from reset pin - use dev_err_probe instead of dev_err v2 changelog: - using generic mipi_dsi_dcs_write_seq - removed success prints - removed some comments - simplified code/removed support for different panels - changed namespace from fann to fannal v1 changelog: - renamed from panel-mipi-dsi-bringup - only one MAINTAINER e-mail --- MAINTAINERS | 1 + drivers/gpu/drm/panel/Kconfig | 11 + drivers/gpu/drm/panel/Makefile | 1 + drivers/gpu/drm/panel/panel-fannal-c3004.c | 314 +++++++++++++++++++++ 4 files changed, 327 insertions(+) create mode 100644 drivers/gpu/drm/panel/panel-fannal-c3004.c diff --git a/MAINTAINERS b/MAINTAINERS index 978133f87c5e..7ad37ecd7e09 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -6431,6 +6431,7 @@ DRM DRIVER FOR FANNAL C3004373132019A M: Paulo Pavacic S: Maintained F: Documentation/devicetree/bindings/display/panel/panel-fannal,c3004.yaml +F: drivers/gpu/drm/panel/panel-fannal-c3004.c DRM DRIVER FOR FARADAY TVE200 TV ENCODER M: Linus Walleij diff --git a/drivers/gpu/drm/panel/Kconfig b/drivers/gpu/drm/panel/Kconfig index 2b9d6db7860b..a1041c1e6bf6 100644 --- a/drivers/gpu/drm/panel/Kconfig +++ b/drivers/gpu/drm/panel/Kconfig @@ -144,6 +144,17 @@ config DRM_PANEL_ELIDA_KD35T133 KD35T133 controller for 320x480 LCD panels with MIPI-DSI system interfaces. +config DRM_PANEL_FANNAL_C3004 + tristate "Fannal C3004 panel" + depends on OF + depends on DRM_MIPI_DSI + help + Say Y here if you want to enable support for the Fannal C3004 + 2-lane 480x800 MIPI DSI panel which requires initialization + sequence. + + If M is selected the module will be called panel-fannal-c3004. + config DRM_PANEL_FEIXIN_K101_IM2BA02 tristate "Feixin K101 IM2BA02 panel" depends on OF diff --git a/drivers/gpu/drm/panel/Makefile b/drivers/gpu/drm/panel/Makefile index ff169781e82d..13c0f00038b5 100644 --- a/drivers/gpu/drm/panel/Makefile +++ b/drivers/gpu/drm/panel/Makefile @@ -12,6 +12,7 @@ obj-$(CONFIG_DRM_PANEL_SIMPLE) += panel-simple.o obj-$(CONFIG_DRM_PANEL_EDP) += panel-edp.o obj-$(CONFIG_DRM_PANEL_EBBG_FT8719) += panel-ebbg-ft8719.o obj-$(CONFIG_DRM_PANEL_ELIDA_KD35T133) += panel-elida-kd35t133.o +obj-$(CONFIG_DRM_PANEL_FANNAL_C3004) += panel-fannal-c3004.o obj-$(CONFIG_DRM_PANEL_FEIXIN_K101_IM2BA02) += panel-feixin-k101-im2ba02.o obj-$(CONFIG_DRM_PANEL_FEIYANG_FY07024DI26A30D) += panel-feiyang-fy07024di26a30d.o obj-$(CONFIG_DRM_PANEL_HIMAX_HX8394) += panel-himax-hx8394.o diff --git a/drivers/gpu/drm/panel/panel-fannal-c3004.c b/drivers/gpu/drm/panel/panel-fannal-c3004.c new file mode 100644 index 000000000000..002c424f2486 --- /dev/null +++ b/drivers/gpu/drm/panel/panel-fannal-c3004.c @@ -0,0 +1,314 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * MIPI DSI driver for fannal C3004. + * Copyright (C) 2023, Zenitel + * Author: Paulo Pavacic + */ + +// ↓ include headers, static values, static functions ↓ +#include +#include +#include +#include +#include + +#include