From patchwork Thu Nov 11 15:22:57 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Michael Nazzareno Trimarchi X-Patchwork-Id: 1750 Return-Path: X-Original-To: linux-amarula@patchwork.amarulasolutions.com Delivered-To: linux-amarula@patchwork.amarulasolutions.com Received: from mail-wm1-f71.google.com (mail-wm1-f71.google.com [209.85.128.71]) by ganimede.amarulasolutions.com (Postfix) with ESMTPS id A9B2C3F07B for ; Thu, 11 Nov 2021 16:23:16 +0100 (CET) Received: by mail-wm1-f71.google.com with SMTP id g80-20020a1c2053000000b003331a764709sf4952874wmg.2 for ; Thu, 11 Nov 2021 07:23:16 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1636644196; cv=pass; d=google.com; s=arc-20160816; b=TRr4S58xKPAXw1BhJtj48UjTZ8S6BHe1kCLcFvVW8sy2gFtwvjk9Lf6m0H8IOXRjci dDu5Bke0UpmW7B9y9txJJ3eCg4BziQR7wZp7U7BlN8xUStTseVKrJocGuJr/HnOm/HPF SGyMhdsP7GuZN+JBOgCxXbGvGWNglEuuux3wiah6ROa+rzXmKgfzMuavMu634vqaqgK1 YXOVSWz6r1rJJ9AuTVFadownu2OF6N3EYpB7xs6BEEp8/VMS5Otw4Qmji2sJ+D40rDcZ 7UkLT42NZif3EZKdUaBRt3mfbHI6WrphXvCOgJZCEMuWC3Oe4aY9DH58zSu76pb4aYx5 SNMg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-unsubscribe:list-archive:list-help:list-post:list-id :mailing-list:precedence:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=Z5VDwdZxVAlUSKI6RfcWvJNQqDf9I4WzCxIDyYJx6kc=; b=AV5e9IoAdKtW05LAfkHJyHFehj5DRVV71W8Q5Mt+//CAA/2LK0tRjnEKPApMbumJHK FMSEPgnn/eNOgi57V1gTbhZc2CsWSN6WdQE4X0VP5SlFuloGBgdJL7ps7V4HITvZm3Ri R5CptXvURxFVn9RDBD8k6oYWzZ4SYaw2xVTXBVoSp2NubXd4P7lDzIuawKKjEiXZvdCp Ezf/Jnva7YcnFuToCnxeXHTkSur0Z45bhItQOW/4ohq4WYf/lD5UhRjiDlwtAk46Y9En K4RcJrtCMxB9Sin6nkVD3d6ZV0LFa9ac29fPvL2+5ZEXHP89xHoArc7VAyqTU71A5lT+ yM0Q== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=qfQ17jFi; spf=pass (google.com: domain of michael@amarulasolutions.com designates 209.85.220.41 as permitted sender) smtp.mailfrom=michael@amarulasolutions.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amarulasolutions.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:x-original-sender:x-original-authentication-results :precedence:mailing-list:list-id:list-post:list-help:list-archive :list-unsubscribe; bh=Z5VDwdZxVAlUSKI6RfcWvJNQqDf9I4WzCxIDyYJx6kc=; b=icidLOopSSEk9RTD4RlI6groKD4qbo5J/yrKe/pB23NSAp197o7Qbxn8g3UkrVPJGA QkhMkPREq72ha1DvoFmPMKEwx9RSS+sQC4knCI5z2RnDsv9i5JUM2FBn8XjzkmvOAqsP oGPWwVuDw3IkpAOV0Tp62iZk1ZA4rN9AjaSjo= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:x-original-sender :x-original-authentication-results:precedence:mailing-list:list-id :x-spam-checked-in-group:list-post:list-help:list-archive :list-unsubscribe; bh=Z5VDwdZxVAlUSKI6RfcWvJNQqDf9I4WzCxIDyYJx6kc=; b=tc4UW9s2V8Kh/8eECsokHykjkpjXHruYWXt5r7Kfb6BRf9Yv08o2r6lXRD/Brq3MhC yKSWi1nHPRHxUk+N7vG+Ybpv00cKGefTQ2RfxLzO0q1QV9yzh0+Gkf7ypvRQonUOZzCn VrZCJIC86E6AcDiTAVpPAN8edjT3CAhmGSo6VcKATIwv7lhCVfZIWXwNIsdBp6UE3TB4 UOaluU5Fc2iNVvlbenYKGouoskyp9elGUdztPZWK1UwyfMiO8bTxT3Suuk523YU4PJPm YJR4imXtBR+AFrdhFm/YbcnoW4Lfqmovt5c7qN/wFE+TVqNZAekwkhevfuKA/uAorILT zemQ== X-Gm-Message-State: AOAM532YZyYo/eW7+HSHyjctOfoFaG1Kd0lyPwBzT+t7/nfJa6zXfZuZ UFaQGexOMnTHJK96BxVDY2a73zDs X-Google-Smtp-Source: ABdhPJz88LdwjH/c9ZpnAQA9gBpPB4ouBoTiRcymwt2yDFvPlad5RMNt8XjOTxFGIStF+cUHXoksVw== X-Received: by 2002:a5d:58f9:: with SMTP id f25mr10070359wrd.206.1636644196490; Thu, 11 Nov 2021 07:23:16 -0800 (PST) X-BeenThere: linux-amarula@amarulasolutions.com Received: by 2002:a1c:7e16:: with SMTP id z22ls24940wmc.2.canary-gmail; Thu, 11 Nov 2021 07:23:15 -0800 (PST) X-Received: by 2002:a05:600c:4f87:: with SMTP id n7mr8907470wmq.168.1636644195435; Thu, 11 Nov 2021 07:23:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636644195; cv=none; d=google.com; s=arc-20160816; b=xzu+LTl/J4IBGz4bJRf2IRX05BZ7SyYhH4NfGayhdJaSotBh1j2F1t/+XOqNvZek10 It4qvcAmy9wZIFL/QgE1srIWQGEDu3gOzDWJW4G+7gkErnh+fbC/P37TInfkM+MncX9X L5HlbsYOxX7u3TrTKdaiz8kbtziYt9TVrDQ/mmZpA5KpgYyvzxPGGrB657pUhGfc5HNB Ls9IrxuYz7vnNbJvgIB7AiNGDMHeitgUpXv2jz3SY1r+NFpp2Y49ZnghCKJbExn2Npk5 eTRo8fDtu24QWAfp0bjvDbnggm5yhWmu+V9No05xdhmxb0wQiLoSA3pup+M7v7n/llmZ M2Xw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=AAadtenMmUI33uESSkUgejM355OFi5Vz4VY8fOW/aC8=; b=C4ks/yA8x+UgJa1pR/7BqxJhRKo+o2ZZwCZfjxluN5JvADEeyIRrk1mRkLKl8ccDoY AWJoD36Y95a8u6QNPLA+6xNVKbpUiAe8gfuEyPu5Zm9buWq33FT8V1ptGKSWkpWOsew+ usoxuWPSulrM2SGqJ70Td6m5jE2ePROLYEu5wZY8R9rGgpjDav6fLZqqd0wTtYDs6AOO jsHI3im3dIXiuIEtvz4n6OsFpkxq6w7GTmOrr9jG4BJGhcIeVUEbZEOfbm30urU0qPxM 2ZYGS0jq6adgPSaM9iO46JcsSw1ZQQwQrUEqyNqB75136AgEVk49dGZY6K2q4cEfDMcu 04EA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=qfQ17jFi; spf=pass (google.com: domain of michael@amarulasolutions.com designates 209.85.220.41 as permitted sender) smtp.mailfrom=michael@amarulasolutions.com Received: from mail-sor-f41.google.com (mail-sor-f41.google.com. [209.85.220.41]) by mx.google.com with SMTPS id p1sor2267730wrr.41.2021.11.11.07.23.15 for (Google Transport Security); Thu, 11 Nov 2021 07:23:15 -0800 (PST) Received-SPF: pass (google.com: domain of michael@amarulasolutions.com designates 209.85.220.41 as permitted sender) client-ip=209.85.220.41; X-Received: by 2002:adf:b604:: with SMTP id f4mr10014488wre.111.1636644195109; Thu, 11 Nov 2021 07:23:15 -0800 (PST) Received: from panicking.pdxnet.pdxeng.ch ([5.171.215.77]) by smtp.gmail.com with ESMTPSA id f3sm8973683wmb.12.2021.11.11.07.23.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 11 Nov 2021 07:23:14 -0800 (PST) From: Michael Trimarchi To: Ariel D'Alessandro Cc: linux-amarula@amarulasolutions.com, Anthony Brandon Subject: [PATCH 10/11] drm/panel: ilitek-ili9805: add support for Tianma TM041XDHG01 panel Date: Thu, 11 Nov 2021 16:22:57 +0100 Message-Id: <20211111152258.26131-10-michael@amarulasolutions.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20211111152258.26131-1-michael@amarulasolutions.com> References: <20211111152258.26131-1-michael@amarulasolutions.com> MIME-Version: 1.0 X-Original-Sender: michael@amarulasolutions.com X-Original-Authentication-Results: mx.google.com; dkim=pass header.i=@amarulasolutions.com header.s=google header.b=qfQ17jFi; spf=pass (google.com: domain of michael@amarulasolutions.com designates 209.85.220.41 as permitted sender) smtp.mailfrom=michael@amarulasolutions.com Content-Type: text/plain; charset="UTF-8" Precedence: list Mailing-list: list linux-amarula@amarulasolutions.com; contact linux-amarula+owners@amarulasolutions.com List-ID: X-Spam-Checked-In-Group: linux-amarula@amarulasolutions.com X-Google-Group-Id: 476853432473 List-Post: , List-Help: , List-Archive: List-Unsubscribe: , Tianma TM041XDHG01 utilizes the Ilitek ILI9805 controller. Add this panel's initialzation sequence and timing to ILI9805 driver. Signed-off-by: Michael Trimarchi --- drivers/gpu/drm/panel/panel-ilitek-ili9805.c | 53 ++++++++++++++++++++ 1 file changed, 53 insertions(+) diff --git a/drivers/gpu/drm/panel/panel-ilitek-ili9805.c b/drivers/gpu/drm/panel/panel-ilitek-ili9805.c index 2cf10f5c17d4..db6f325d0f48 100644 --- a/drivers/gpu/drm/panel/panel-ilitek-ili9805.c +++ b/drivers/gpu/drm/panel/panel-ilitek-ili9805.c @@ -86,6 +86,36 @@ static const struct ili9805_instr gpm1780a0_init[] = { ILI9805_INSTR(0, 0xB9, 0x02, 0x00), }; +static const struct ili9805_instr tm041xdhg01_init[] = { + ILI9805_INSTR(100, ILI9805_EXTCMD_CMD_SET_ENABLE_REG, ILI9805_SETEXTC_PARAMETER1, + ILI9805_SETEXTC_PARAMETER2, ILI9805_SETEXTC_PARAMETER3), + ILI9805_INSTR(100, 0xFD, 0x0F, 0x13, 0x44, 0x00), + ILI9805_INSTR(0, 0xf8, 0x18, 0x02, 0x02, 0x18, 0x02, 0x02, 0x30, 0x01, + 0x01, 0x30, 0x01, 0x01, 0x30, 0x01, 0x01), + ILI9805_INSTR(0, 0xB8, 0x74), + ILI9805_INSTR(0, 0xF1, 0x00), + ILI9805_INSTR(0, 0xF2, 0x00, 0x58, 0x40), + ILI9805_INSTR(0, 0xFC, 0x04, 0x0F, 0x01), + ILI9805_INSTR(0, 0xEB, 0x08, 0x0F), + ILI9805_INSTR(0, 0xe0, 0x01, 0x0d, 0x15, 0x0e, 0x0f, 0x0f, 0x0b, 0x08, 0x04, + 0x07, 0x0a, 0x0d, 0x0c, 0x15, 0x0f, 0x08), + ILI9805_INSTR(0, 0xe1, 0x01, 0x0d, 0x15, 0x0e, 0x0f, 0x0f, 0x0b, 0x08, 0x04, + 0x07, 0x0a, 0x0d, 0x0c, 0x15, 0x0f, 0x08), + ILI9805_INSTR(10, 0xc1, 0x15, 0x03, 0x03, 0x31), + ILI9805_INSTR(10, 0xB1, 0x00, 0x12, 0x14), + ILI9805_INSTR(10, 0xB4, 0x02), + ILI9805_INSTR(0, 0xBB, 0x14, 0x55), + ILI9805_INSTR(0, MIPI_DCS_SET_ADDRESS_MODE, 0x0a), + ILI9805_INSTR(0, MIPI_DCS_SET_PIXEL_FORMAT, 0x77), + ILI9805_INSTR(0, 0x20), + ILI9805_INSTR(0, 0xB0, 0x00), + ILI9805_INSTR(0, 0xB6, 0x01), + ILI9805_INSTR(0, 0xc2, 0x11), + ILI9805_INSTR(0, 0x51, 0xFF), + ILI9805_INSTR(0, 0x53, 0x24), + ILI9805_INSTR(0, 0x55, 0x00), +}; + static inline struct ili9805 *panel_to_ili9805(struct drm_panel *panel) { return container_of(panel, struct ili9805, panel); @@ -170,6 +200,20 @@ static const struct drm_display_mode gpm1780a0_timing = { .vtotal = 480 + 2 + 4 + 10, }; +static const struct drm_display_mode tm041xdhg01_timing = { + .clock = 26227, + + .hdisplay = 480, + .hsync_start = 480 + 10, + .hsync_end = 480 + 10 + 2, + .htotal = 480 + 10 + 2 + 36, + + .vdisplay = 768, + .vsync_start = 768 + 2, + .vsync_end = 768 + 10 + 4, + .vtotal = 768 + 2 + 4 + 10, +}; + static int ili9805_get_modes(struct drm_panel *panel, struct drm_connector *connector) { @@ -264,8 +308,17 @@ static const struct ili9805_desc gpm1780a0_desc = { .height_mm = 65, }; +static const struct ili9805_desc tm041xdhg01_desc = { + .init = tm041xdhg01_init, + .init_length = ARRAY_SIZE(tm041xdhg01_init), + .mode = &tm041xdhg01_timing, + .width_mm = 42, + .height_mm = 96, +}; + static const struct of_device_id ili9805_of_match[] = { { .compatible = "giantplus,gpm1790a0", .data = &gpm1780a0_desc }, + { .compatible = "tianma,tm041xdhg01", .data = &tm041xdhg01_desc }, { } }; MODULE_DEVICE_TABLE(of, ili9805_of_match);