From nobody Mon Feb 9 20:50:48 2026 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 AD25AEB64DC for ; Mon, 3 Jul 2023 13:22:21 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231523AbjGCNWR (ORCPT ); Mon, 3 Jul 2023 09:22:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45920 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231214AbjGCNWE (ORCPT ); Mon, 3 Jul 2023 09:22:04 -0400 Received: from mail-lj1-x231.google.com (mail-lj1-x231.google.com [IPv6:2a00:1450:4864:20::231]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 53B3CDD for ; Mon, 3 Jul 2023 06:21:59 -0700 (PDT) Received: by mail-lj1-x231.google.com with SMTP id 38308e7fff4ca-2b6e7d7952eso15674261fa.3 for ; Mon, 03 Jul 2023 06:21:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1688390517; x=1690982517; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=oh+Efq7uoeS7oDxLohDO7/o66KJX1Di7FbXAmNRuVeE=; b=B24ppo59lf4kpTDu7z+birWtsCnWBhftXepIbWqCcBVoiJ/28KJuC6cEHkf2LhLr06 WYGyrDwzJnaT1af7c6hd6PhmERWqZylgzfiOkVOwozCWwsck9bIR6gWhzFB9CQpE9/eW SECgEmmwZo2LPscjPPBUhMvQj4bOP35shBfQFyL2Gt1ubSxdW6MHQaXsPRhnqEtt87TS ie3l4NqdaPG2DorseWDkwAUNBzOWyWdTo+lR9b2xs/okHe6rFFeks4ltF11pvDQQ8XMB wEsKMwDdv97D6uoq8/WCrFn9fNLVLKXBxhVUYG4I4d+s8d++ahc1sNlsgWZUyQYBUIdt VJOA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688390517; x=1690982517; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=oh+Efq7uoeS7oDxLohDO7/o66KJX1Di7FbXAmNRuVeE=; b=b8YSfrST65mb2QcXhat/CvnKsh1Km3/aM18HcUGuKa0gw+8yy0owbnJMPj9K5Nc9Ly kQLEg7NHY4P/EW0QK3R0lYEgoPvjEy7+Qdu4fpT2eGwhXYdF/nGFq5LCMs44SBPU4Yv/ P9/VTRQ3pM9gMGCH+0tVCuMOMxcxYLHD2cJgrymhsmZ0lEaThEWxjoLq3PcMD1z2ri7V ZQW5ESUtwGPAw+AsZiy0B93kiwrcCWlJJnt3yhX4hSJuA+jlPn1+reViBo5e8HbWfAWW SW9WFJSKFJnWYvcvPFfmuNOO7ftcgCs/IFip8hBjbeMeh1L41/sesgvr6lFWZINS6V/w dtyg== X-Gm-Message-State: ABy/qLZjeNeElhGx9aMICrTZdGf+v1F3JUKa4YHd+keqbIFCXE49sGbX S3eqoArtIAAp99o4FfWdXLuxrQ== X-Google-Smtp-Source: APBJJlFgtl+eOFJUcChOQ1SAIMgr3VhXz35NVP73ZqJjZ+jB1kc++l8yxNLDlXgHNSAesvGjDLNurA== X-Received: by 2002:a2e:7016:0:b0:2b6:a6e7:5afa with SMTP id l22-20020a2e7016000000b002b6a6e75afamr6193730ljc.12.1688390516636; Mon, 03 Jul 2023 06:21:56 -0700 (PDT) Received: from [127.0.1.1] ([85.235.12.238]) by smtp.gmail.com with ESMTPSA id u10-20020a2e9f0a000000b002b6b7a98c4bsm3535238ljk.77.2023.07.03.06.21.55 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 03 Jul 2023 06:21:56 -0700 (PDT) From: Linus Walleij Date: Mon, 03 Jul 2023 15:21:49 +0200 Subject: [PATCH v3 1/4] drm/panel: boe-tv101wum-nl6: Drop macros and open code sequences MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20230703-fix-boe-tv101wum-nl6-v3-1-bd6e9432c755@linaro.org> References: <20230703-fix-boe-tv101wum-nl6-v3-0-bd6e9432c755@linaro.org> In-Reply-To: <20230703-fix-boe-tv101wum-nl6-v3-0-bd6e9432c755@linaro.org> To: Ruihai Zhou , Stephen Boyd , Douglas Anderson , Cong Yang , Jitao Shi , Neil Armstrong , Sam Ravnborg , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Linus Walleij X-Mailer: b4 0.12.3 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The boe-tv101wum-nl6 is reinventing the mechanism to send command sequences that we usually nix during review, but I missed this one so fixing it up myself. Also use the explicit function calls to mipi_dsi_dcs_exit_sleep_mode() and mipi_dsi_dcs_set_display_on() instead of reimplementing them with homegrown sequences. Reviewed-by: Sam Ravnborg Signed-off-by: Linus Walleij --- ChangeLog v2->v3: - Convert the two newly added Starry displays as well. --- drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c | 3351 ++++++++++++--------= ---- 1 file changed, 1654 insertions(+), 1697 deletions(-) diff --git a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c b/drivers/gpu/d= rm/panel/panel-boe-tv101wum-nl6.c index 3cc9fb0d4f5d..6fd4c9507c88 100644 --- a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c +++ b/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c @@ -33,7 +33,7 @@ struct panel_desc { =20 unsigned long mode_flags; enum mipi_dsi_pixel_format format; - const struct panel_init_cmd *init_cmds; + int (*init)(struct mipi_dsi_device *dsi); unsigned int lanes; bool discharge_on_disable; bool lp11_before_reset; @@ -55,1706 +55,1661 @@ struct boe_panel { bool prepared; }; =20 -enum dsi_cmd_type { - INIT_DCS_CMD, - DELAY_CMD, -}; +static int boe_tv110c9m_init(struct mipi_dsi_device *dsi) +{ + int ret; =20 -struct panel_init_cmd { - enum dsi_cmd_type type; - size_t len; - const char *data; -}; + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0xD9); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x5A); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x63); + mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x91); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0x95, 0xE6); + mipi_dsi_dcs_write_seq(dsi, 0x96, 0xF0); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x6D, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0x75, 0xA2); + mipi_dsi_dcs_write_seq(dsi, 0x77, 0x3B); =20 -#define _INIT_DCS_CMD(...) { \ - .type =3D INIT_DCS_CMD, \ - .len =3D sizeof((char[]){__VA_ARGS__}), \ - .data =3D (char[]){__VA_ARGS__} } - -#define _INIT_DELAY_CMD(...) { \ - .type =3D DELAY_CMD,\ - .len =3D sizeof((char[]){__VA_ARGS__}), \ - .data =3D (char[]){__VA_ARGS__} } - -static const struct panel_init_cmd boe_tv110c9m_init_cmd[] =3D { - _INIT_DCS_CMD(0xFF, 0x20), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x05, 0xD9), - _INIT_DCS_CMD(0x07, 0x78), - _INIT_DCS_CMD(0x08, 0x5A), - _INIT_DCS_CMD(0x0D, 0x63), - _INIT_DCS_CMD(0x0E, 0x91), - _INIT_DCS_CMD(0x0F, 0x73), - _INIT_DCS_CMD(0x95, 0xE6), - _INIT_DCS_CMD(0x96, 0xF0), - _INIT_DCS_CMD(0x30, 0x00), - _INIT_DCS_CMD(0x6D, 0x66), - _INIT_DCS_CMD(0x75, 0xA2), - _INIT_DCS_CMD(0x77, 0x3B), + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x0= 0, 0x6D, 0x00, 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x0= 1, 0x7E, 0x01, 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x0= 3, 0x08, 0x03, 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x0= 3, 0xE7, 0x03, 0xFD, 0x03, 0xFF); =20 - _INIT_DCS_CMD(0xB0, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x00, 0x6D, 0x00,= 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9), - _INIT_DCS_CMD(0xB1, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x01, 0x7E, 0x01,= 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31), - _INIT_DCS_CMD(0xB2, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x03, 0x08, 0x03,= 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B), - _INIT_DCS_CMD(0xB3, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x03, 0xE7, 0x03,= 0xFD, 0x03, 0xFF), - - _INIT_DCS_CMD(0xB4, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x00, 0x6D, 0x00,= 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9), - _INIT_DCS_CMD(0xB5, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x01, 0x7E, 0x01,= 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31), - _INIT_DCS_CMD(0xB6, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x03, 0x08, 0x03,= 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B), - _INIT_DCS_CMD(0xB7, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x03, 0xE7, 0x03,= 0xFD, 0x03, 0xFF), - _INIT_DCS_CMD(0xB8, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x00, 0x6D, 0x00,= 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9), - _INIT_DCS_CMD(0xB9, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x01, 0x7E, 0x01,= 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31), - _INIT_DCS_CMD(0xBA, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x03, 0x08, 0x03,= 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B), - _INIT_DCS_CMD(0xBB, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x03, 0xE7, 0x03,= 0xFD, 0x03, 0xFF), - - _INIT_DCS_CMD(0xFF, 0x21), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0xB0, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x00, 0x65, 0x00,= 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1), - _INIT_DCS_CMD(0xB1, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x01, 0x76, 0x01,= 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29), - _INIT_DCS_CMD(0xB2, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x03, 0x00, 0x03,= 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73), - - _INIT_DCS_CMD(0xB3, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x03, 0xDF, 0x03,= 0xF5, 0x03, 0xE0), - _INIT_DCS_CMD(0xB4, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x00, 0x65, 0x00,= 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1), - _INIT_DCS_CMD(0xB5, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x01, 0x76, 0x01,= 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29), - _INIT_DCS_CMD(0xB6, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x03, 0x00, 0x03,= 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73), - _INIT_DCS_CMD(0xB7, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x03, 0xDF, 0x03,= 0xF5, 0x03, 0xE0), - - _INIT_DCS_CMD(0xB8, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x00, 0x65, 0x00,= 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1), - _INIT_DCS_CMD(0xB9, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x01, 0x76, 0x01,= 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29), - _INIT_DCS_CMD(0xBA, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x03, 0x00, 0x03,= 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73), - - _INIT_DCS_CMD(0xBB, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x03, 0xDF, 0x03,= 0xF5, 0x03, 0xE0), - _INIT_DCS_CMD(0xFF, 0x24), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x00, 0x00), - _INIT_DCS_CMD(0x01, 0x00), - - _INIT_DCS_CMD(0x02, 0x1C), - _INIT_DCS_CMD(0x03, 0x1C), - - _INIT_DCS_CMD(0x04, 0x1D), - _INIT_DCS_CMD(0x05, 0x1D), - - _INIT_DCS_CMD(0x06, 0x04), - _INIT_DCS_CMD(0x07, 0x04), - - _INIT_DCS_CMD(0x08, 0x0F), - _INIT_DCS_CMD(0x09, 0x0F), - - _INIT_DCS_CMD(0x0A, 0x0E), - _INIT_DCS_CMD(0x0B, 0x0E), - - _INIT_DCS_CMD(0x0C, 0x0D), - _INIT_DCS_CMD(0x0D, 0x0D), - - _INIT_DCS_CMD(0x0E, 0x0C), - _INIT_DCS_CMD(0x0F, 0x0C), - - _INIT_DCS_CMD(0x10, 0x08), - _INIT_DCS_CMD(0x11, 0x08), - - _INIT_DCS_CMD(0x12, 0x00), - _INIT_DCS_CMD(0x13, 0x00), - _INIT_DCS_CMD(0x14, 0x00), - _INIT_DCS_CMD(0x15, 0x00), - - _INIT_DCS_CMD(0x16, 0x00), - _INIT_DCS_CMD(0x17, 0x00), - - _INIT_DCS_CMD(0x18, 0x1C), - _INIT_DCS_CMD(0x19, 0x1C), - - _INIT_DCS_CMD(0x1A, 0x1D), - _INIT_DCS_CMD(0x1B, 0x1D), - - _INIT_DCS_CMD(0x1C, 0x04), - _INIT_DCS_CMD(0x1D, 0x04), - - _INIT_DCS_CMD(0x1E, 0x0F), - _INIT_DCS_CMD(0x1F, 0x0F), - - _INIT_DCS_CMD(0x20, 0x0E), - _INIT_DCS_CMD(0x21, 0x0E), - - _INIT_DCS_CMD(0x22, 0x0D), - _INIT_DCS_CMD(0x23, 0x0D), - - _INIT_DCS_CMD(0x24, 0x0C), - _INIT_DCS_CMD(0x25, 0x0C), - - _INIT_DCS_CMD(0x26, 0x08), - _INIT_DCS_CMD(0x27, 0x08), - - _INIT_DCS_CMD(0x28, 0x00), - _INIT_DCS_CMD(0x29, 0x00), - _INIT_DCS_CMD(0x2A, 0x00), - _INIT_DCS_CMD(0x2B, 0x00), - - _INIT_DCS_CMD(0x2D, 0x20), - _INIT_DCS_CMD(0x2F, 0x0A), - _INIT_DCS_CMD(0x30, 0x44), - _INIT_DCS_CMD(0x33, 0x0C), - _INIT_DCS_CMD(0x34, 0x32), - - _INIT_DCS_CMD(0x37, 0x44), - _INIT_DCS_CMD(0x38, 0x40), - _INIT_DCS_CMD(0x39, 0x00), - _INIT_DCS_CMD(0x3A, 0x5D), - _INIT_DCS_CMD(0x3B, 0x60), - _INIT_DCS_CMD(0x3D, 0x42), - _INIT_DCS_CMD(0x3F, 0x06), - _INIT_DCS_CMD(0x43, 0x06), - _INIT_DCS_CMD(0x47, 0x66), - _INIT_DCS_CMD(0x4A, 0x5D), - _INIT_DCS_CMD(0x4B, 0x60), - _INIT_DCS_CMD(0x4C, 0x91), - _INIT_DCS_CMD(0x4D, 0x21), - _INIT_DCS_CMD(0x4E, 0x43), - _INIT_DCS_CMD(0x51, 0x12), - _INIT_DCS_CMD(0x52, 0x34), - _INIT_DCS_CMD(0x55, 0x82, 0x02), - _INIT_DCS_CMD(0x56, 0x04), - _INIT_DCS_CMD(0x58, 0x21), - _INIT_DCS_CMD(0x59, 0x30), - _INIT_DCS_CMD(0x5A, 0x60), - _INIT_DCS_CMD(0x5B, 0x50), - _INIT_DCS_CMD(0x5E, 0x00, 0x06), - _INIT_DCS_CMD(0x5F, 0x00), - _INIT_DCS_CMD(0x65, 0x82), - _INIT_DCS_CMD(0x7E, 0x20), - _INIT_DCS_CMD(0x7F, 0x3C), - _INIT_DCS_CMD(0x82, 0x04), - _INIT_DCS_CMD(0x97, 0xC0), - - _INIT_DCS_CMD(0xB6, 0x05, 0x00, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05,= 0x05, 0x00, 0x00), - _INIT_DCS_CMD(0x91, 0x44), - _INIT_DCS_CMD(0x92, 0xA9), - _INIT_DCS_CMD(0x93, 0x1A), - _INIT_DCS_CMD(0x94, 0x96), - _INIT_DCS_CMD(0xD7, 0x55), - _INIT_DCS_CMD(0xDA, 0x0A), - _INIT_DCS_CMD(0xDE, 0x08), - _INIT_DCS_CMD(0xDB, 0x05), - _INIT_DCS_CMD(0xDC, 0xA9), - _INIT_DCS_CMD(0xDD, 0x22), - - _INIT_DCS_CMD(0xDF, 0x05), - _INIT_DCS_CMD(0xE0, 0xA9), - _INIT_DCS_CMD(0xE1, 0x05), - _INIT_DCS_CMD(0xE2, 0xA9), - _INIT_DCS_CMD(0xE3, 0x05), - _INIT_DCS_CMD(0xE4, 0xA9), - _INIT_DCS_CMD(0xE5, 0x05), - _INIT_DCS_CMD(0xE6, 0xA9), - _INIT_DCS_CMD(0x5C, 0x00), - _INIT_DCS_CMD(0x5D, 0x00), - _INIT_DCS_CMD(0x8D, 0x00), - _INIT_DCS_CMD(0x8E, 0x00), - _INIT_DCS_CMD(0xB5, 0x90), - _INIT_DCS_CMD(0xFF, 0x25), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x05, 0x00), - _INIT_DCS_CMD(0x19, 0x07), - _INIT_DCS_CMD(0x1F, 0x60), - _INIT_DCS_CMD(0x20, 0x50), - _INIT_DCS_CMD(0x26, 0x60), - _INIT_DCS_CMD(0x27, 0x50), - _INIT_DCS_CMD(0x33, 0x60), - _INIT_DCS_CMD(0x34, 0x50), - _INIT_DCS_CMD(0x3F, 0xE0), - _INIT_DCS_CMD(0x40, 0x00), - _INIT_DCS_CMD(0x44, 0x00), - _INIT_DCS_CMD(0x45, 0x40), - _INIT_DCS_CMD(0x48, 0x60), - _INIT_DCS_CMD(0x49, 0x50), - _INIT_DCS_CMD(0x5B, 0x00), - _INIT_DCS_CMD(0x5C, 0x00), - _INIT_DCS_CMD(0x5D, 0x00), - _INIT_DCS_CMD(0x5E, 0xD0), - _INIT_DCS_CMD(0x61, 0x60), - _INIT_DCS_CMD(0x62, 0x50), - _INIT_DCS_CMD(0xF1, 0x10), - _INIT_DCS_CMD(0xFF, 0x2A), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x64, 0x16), - _INIT_DCS_CMD(0x67, 0x16), - _INIT_DCS_CMD(0x6A, 0x16), - - _INIT_DCS_CMD(0x70, 0x30), - - _INIT_DCS_CMD(0xA2, 0xF3), - _INIT_DCS_CMD(0xA3, 0xFF), - _INIT_DCS_CMD(0xA4, 0xFF), - _INIT_DCS_CMD(0xA5, 0xFF), - - _INIT_DCS_CMD(0xD6, 0x08), - - _INIT_DCS_CMD(0xFF, 0x26), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x00, 0xA1), - - _INIT_DCS_CMD(0x02, 0x31), - _INIT_DCS_CMD(0x04, 0x28), - _INIT_DCS_CMD(0x06, 0x30), - _INIT_DCS_CMD(0x0C, 0x16), - _INIT_DCS_CMD(0x0D, 0x0D), - _INIT_DCS_CMD(0x0F, 0x00), - _INIT_DCS_CMD(0x11, 0x00), - _INIT_DCS_CMD(0x12, 0x50), - _INIT_DCS_CMD(0x13, 0x56), - _INIT_DCS_CMD(0x14, 0x57), - _INIT_DCS_CMD(0x15, 0x00), - _INIT_DCS_CMD(0x16, 0x10), - _INIT_DCS_CMD(0x17, 0xA0), - _INIT_DCS_CMD(0x18, 0x86), - _INIT_DCS_CMD(0x19, 0x0D), - _INIT_DCS_CMD(0x1A, 0x7F), - _INIT_DCS_CMD(0x1B, 0x0C), - _INIT_DCS_CMD(0x1C, 0xBF), - _INIT_DCS_CMD(0x22, 0x00), - _INIT_DCS_CMD(0x23, 0x00), - _INIT_DCS_CMD(0x2A, 0x0D), - _INIT_DCS_CMD(0x2B, 0x7F), - - _INIT_DCS_CMD(0x1D, 0x00), - _INIT_DCS_CMD(0x1E, 0x65), - _INIT_DCS_CMD(0x1F, 0x65), - _INIT_DCS_CMD(0x24, 0x00), - _INIT_DCS_CMD(0x25, 0x65), - _INIT_DCS_CMD(0x2F, 0x05), - _INIT_DCS_CMD(0x30, 0x65), - _INIT_DCS_CMD(0x31, 0x05), - _INIT_DCS_CMD(0x32, 0x7D), - _INIT_DCS_CMD(0x39, 0x00), - _INIT_DCS_CMD(0x3A, 0x65), - _INIT_DCS_CMD(0x20, 0x01), - _INIT_DCS_CMD(0x33, 0x11), - _INIT_DCS_CMD(0x34, 0x78), - _INIT_DCS_CMD(0x35, 0x16), - _INIT_DCS_CMD(0xC8, 0x04), - _INIT_DCS_CMD(0xC9, 0x9E), - _INIT_DCS_CMD(0xCA, 0x4E), - _INIT_DCS_CMD(0xCB, 0x00), - - _INIT_DCS_CMD(0xA9, 0x49), - _INIT_DCS_CMD(0xAA, 0x4B), - _INIT_DCS_CMD(0xAB, 0x48), - _INIT_DCS_CMD(0xAC, 0x43), - _INIT_DCS_CMD(0xAD, 0x40), - _INIT_DCS_CMD(0xAE, 0x50), - _INIT_DCS_CMD(0xAF, 0x44), - _INIT_DCS_CMD(0xB0, 0x54), - _INIT_DCS_CMD(0xB1, 0x4E), - _INIT_DCS_CMD(0xB2, 0x4D), - _INIT_DCS_CMD(0xB3, 0x4C), - _INIT_DCS_CMD(0xB4, 0x41), - _INIT_DCS_CMD(0xB5, 0x47), - _INIT_DCS_CMD(0xB6, 0x53), - _INIT_DCS_CMD(0xB7, 0x3E), - _INIT_DCS_CMD(0xB8, 0x51), - _INIT_DCS_CMD(0xB9, 0x3C), - _INIT_DCS_CMD(0xBA, 0x3B), - _INIT_DCS_CMD(0xBB, 0x46), - _INIT_DCS_CMD(0xBC, 0x45), - _INIT_DCS_CMD(0xBD, 0x55), - _INIT_DCS_CMD(0xBE, 0x3D), - _INIT_DCS_CMD(0xBF, 0x3F), - _INIT_DCS_CMD(0xC0, 0x52), - _INIT_DCS_CMD(0xC1, 0x4A), - _INIT_DCS_CMD(0xC2, 0x39), - _INIT_DCS_CMD(0xC3, 0x4F), - _INIT_DCS_CMD(0xC4, 0x3A), - _INIT_DCS_CMD(0xC5, 0x42), - _INIT_DCS_CMD(0xFF, 0x27), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x56, 0x06), - _INIT_DCS_CMD(0x58, 0x80), - _INIT_DCS_CMD(0x59, 0x75), - _INIT_DCS_CMD(0x5A, 0x00), - _INIT_DCS_CMD(0x5B, 0x02), - _INIT_DCS_CMD(0x5C, 0x00), - _INIT_DCS_CMD(0x5D, 0x00), - _INIT_DCS_CMD(0x5E, 0x20), - _INIT_DCS_CMD(0x5F, 0x10), - _INIT_DCS_CMD(0x60, 0x00), - _INIT_DCS_CMD(0x61, 0x2E), - _INIT_DCS_CMD(0x62, 0x00), - _INIT_DCS_CMD(0x63, 0x01), - _INIT_DCS_CMD(0x64, 0x43), - _INIT_DCS_CMD(0x65, 0x2D), - _INIT_DCS_CMD(0x66, 0x00), - _INIT_DCS_CMD(0x67, 0x01), - _INIT_DCS_CMD(0x68, 0x44), - - _INIT_DCS_CMD(0x00, 0x00), - _INIT_DCS_CMD(0x78, 0x00), - _INIT_DCS_CMD(0xC3, 0x00), - - _INIT_DCS_CMD(0xFF, 0x2A), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x22, 0x2F), - _INIT_DCS_CMD(0x23, 0x08), - - _INIT_DCS_CMD(0x24, 0x00), - _INIT_DCS_CMD(0x25, 0x65), - _INIT_DCS_CMD(0x26, 0xF8), - _INIT_DCS_CMD(0x27, 0x00), - _INIT_DCS_CMD(0x28, 0x1A), - _INIT_DCS_CMD(0x29, 0x00), - _INIT_DCS_CMD(0x2A, 0x1A), - _INIT_DCS_CMD(0x2B, 0x00), - _INIT_DCS_CMD(0x2D, 0x1A), - - _INIT_DCS_CMD(0xFF, 0x23), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x00, 0x80), - _INIT_DCS_CMD(0x07, 0x00), - - _INIT_DCS_CMD(0xFF, 0xE0), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x14, 0x60), - _INIT_DCS_CMD(0x16, 0xC0), - - _INIT_DCS_CMD(0xFF, 0xF0), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x3A, 0x08), - - _INIT_DCS_CMD(0xFF, 0x10), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0xB9, 0x01), - _INIT_DCS_CMD(0xFF, 0x20), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x18, 0x40), - - _INIT_DCS_CMD(0xFF, 0x10), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0xB9, 0x02), - _INIT_DCS_CMD(0x35, 0x00), - _INIT_DCS_CMD(0x51, 0x00, 0xFF), - _INIT_DCS_CMD(0x53, 0x24), - _INIT_DCS_CMD(0x55, 0x00), - _INIT_DCS_CMD(0xBB, 0x13), - _INIT_DCS_CMD(0x3B, 0x03, 0x96, 0x1A, 0x04, 0x04), - _INIT_DELAY_CMD(100), - _INIT_DCS_CMD(0x11), - _INIT_DELAY_CMD(200), - _INIT_DCS_CMD(0x29), - _INIT_DELAY_CMD(100), - {}, -}; + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x0= 0, 0x6D, 0x00, 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x0= 1, 0x7E, 0x01, 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x0= 3, 0x08, 0x03, 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x0= 3, 0xE7, 0x03, 0xFD, 0x03, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x0= 0, 0x6D, 0x00, 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x0= 1, 0x7E, 0x01, 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x0= 3, 0x08, 0x03, 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x0= 3, 0xE7, 0x03, 0xFD, 0x03, 0xFF); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x0= 0, 0x65, 0x00, 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x0= 1, 0x76, 0x01, 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x0= 3, 0x00, 0x03, 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73); + + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x0= 3, 0xDF, 0x03, 0xF5, 0x03, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x0= 0, 0x65, 0x00, 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x0= 1, 0x76, 0x01, 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x0= 3, 0x00, 0x03, 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x0= 3, 0xDF, 0x03, 0xF5, 0x03, 0xE0); + + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x0= 0, 0x65, 0x00, 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x0= 1, 0x76, 0x01, 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x0= 3, 0x00, 0x03, 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73); + + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x0= 3, 0xDF, 0x03, 0xF5, 0x03, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x01, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0x03, 0x1C); + + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x1D); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0x1D); + + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x04); + + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0x0F); + + mipi_dsi_dcs_write_seq(dsi, 0x0A, 0x0E); + mipi_dsi_dcs_write_seq(dsi, 0x0B, 0x0E); + + mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x0D); + + mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x0C); + + mipi_dsi_dcs_write_seq(dsi, 0x10, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x11, 0x08); + + mipi_dsi_dcs_write_seq(dsi, 0x12, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x13, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x15, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x16, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x17, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0x19, 0x1C); + + mipi_dsi_dcs_write_seq(dsi, 0x1A, 0x1D); + mipi_dsi_dcs_write_seq(dsi, 0x1B, 0x1D); + + mipi_dsi_dcs_write_seq(dsi, 0x1C, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x04); + + mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x0F); + + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x0E); + mipi_dsi_dcs_write_seq(dsi, 0x21, 0x0E); + + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x0D); + + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x0C); + + mipi_dsi_dcs_write_seq(dsi, 0x26, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x08); + + mipi_dsi_dcs_write_seq(dsi, 0x28, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x2D, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x32); + + mipi_dsi_dcs_write_seq(dsi, 0x37, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0x38, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x5D); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x42); + mipi_dsi_dcs_write_seq(dsi, 0x3F, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x43, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x47, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0x4A, 0x5D); + mipi_dsi_dcs_write_seq(dsi, 0x4B, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x4C, 0x91); + mipi_dsi_dcs_write_seq(dsi, 0x4D, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0x4E, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x51, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x52, 0x34); + mipi_dsi_dcs_write_seq(dsi, 0x55, 0x82, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x56, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x58, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0x59, 0x30); + mipi_dsi_dcs_write_seq(dsi, 0x5A, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x00, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x5F, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x65, 0x82); + mipi_dsi_dcs_write_seq(dsi, 0x7E, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0x7F, 0x3C); + mipi_dsi_dcs_write_seq(dsi, 0x82, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x97, 0xC0); + + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x05, 0x00, 0x05, 0x00, 0x00, 0x00, 0x0= 0, 0x00, 0x05, 0x05, 0x00, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x91, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0x92, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0x93, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x94, 0x96); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x55); + mipi_dsi_dcs_write_seq(dsi, 0xDA, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x22); + + mipi_dsi_dcs_write_seq(dsi, 0xDF, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0xE3, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x8D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x8E, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x90); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x25); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x19, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x3F, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0x40, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x44, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x45, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0x48, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x49, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0xD0); + mipi_dsi_dcs_write_seq(dsi, 0x61, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x62, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0xF1, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x64, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x67, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x6A, 0x16); + + mipi_dsi_dcs_write_seq(dsi, 0x70, 0x30); + + mipi_dsi_dcs_write_seq(dsi, 0xA2, 0xF3); + mipi_dsi_dcs_write_seq(dsi, 0xA3, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xA4, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xA5, 0xFF); + + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x08); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0xA1); + + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x28); + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x30); + mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x11, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x12, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x13, 0x56); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0x57); + mipi_dsi_dcs_write_seq(dsi, 0x15, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x16, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x17, 0xA0); + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x86); + mipi_dsi_dcs_write_seq(dsi, 0x19, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x1A, 0x7F); + mipi_dsi_dcs_write_seq(dsi, 0x1B, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x1C, 0xBF); + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x7F); + + mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x31, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x32, 0x7D); + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x9E); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x4E); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0xA9, 0x49); + mipi_dsi_dcs_write_seq(dsi, 0xAA, 0x4B); + mipi_dsi_dcs_write_seq(dsi, 0xAB, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xAC, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0xAD, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xAE, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0xAF, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x54); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x4E); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x4D); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x4C); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x41); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x47); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x53); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x3E); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x51); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x3C); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x3B); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x45); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x55); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0x3D); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x52); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x4A); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x3A); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x42); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x27); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x56, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x58, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x59, 0x75); + mipi_dsi_dcs_write_seq(dsi, 0x5A, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0x5F, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x60, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x61, 0x2E); + mipi_dsi_dcs_write_seq(dsi, 0x62, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x63, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x64, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x65, 0x2D); + mipi_dsi_dcs_write_seq(dsi, 0x66, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x67, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x68, 0x44); + + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x78, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x08); + + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0xF8); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x28, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2D, 0x1A); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x16, 0xC0); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0xF0); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x08); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x40); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x51, 0x00, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0x53, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0x55, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x03, 0x96, 0x1A, 0x04, 0x04); + msleep(100); + ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(200); + ret =3D mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(100); =20 -static const struct panel_init_cmd inx_hj110iz_init_cmd[] =3D { - _INIT_DCS_CMD(0xFF, 0x20), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x05, 0xD1), - _INIT_DCS_CMD(0x06, 0xC0), - _INIT_DCS_CMD(0x07, 0x87), - _INIT_DCS_CMD(0x08, 0x4B), - - _INIT_DCS_CMD(0x0D, 0x63), - _INIT_DCS_CMD(0x0E, 0x91), - _INIT_DCS_CMD(0x0F, 0x69), - _INIT_DCS_CMD(0x94, 0x00), - _INIT_DCS_CMD(0x95, 0xF5), - _INIT_DCS_CMD(0x96, 0xF5), - _INIT_DCS_CMD(0x9D, 0x00), - _INIT_DCS_CMD(0x9E, 0x00), - _INIT_DCS_CMD(0x69, 0x98), - _INIT_DCS_CMD(0x75, 0xA2), - _INIT_DCS_CMD(0x77, 0xB3), - - _INIT_DCS_CMD(0x58, 0x43), - _INIT_DCS_CMD(0xFF, 0x24), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x91, 0x44), - _INIT_DCS_CMD(0x92, 0x4C), - _INIT_DCS_CMD(0x94, 0x86), - _INIT_DCS_CMD(0x60, 0x96), - _INIT_DCS_CMD(0x61, 0xD0), - _INIT_DCS_CMD(0x63, 0x70), - _INIT_DCS_CMD(0xC2, 0xCA), - - _INIT_DCS_CMD(0x00, 0x03), - _INIT_DCS_CMD(0x01, 0x03), - _INIT_DCS_CMD(0x02, 0x03), - _INIT_DCS_CMD(0x03, 0x29), - _INIT_DCS_CMD(0x04, 0x22), - _INIT_DCS_CMD(0x05, 0x22), - _INIT_DCS_CMD(0x06, 0x0B), - _INIT_DCS_CMD(0x07, 0x1D), - _INIT_DCS_CMD(0x08, 0x1C), - _INIT_DCS_CMD(0x09, 0x05), - _INIT_DCS_CMD(0x0A, 0x08), - _INIT_DCS_CMD(0x0B, 0x09), - _INIT_DCS_CMD(0x0C, 0x0A), - _INIT_DCS_CMD(0x0D, 0x0C), - _INIT_DCS_CMD(0x0E, 0x0D), - _INIT_DCS_CMD(0x0F, 0x0E), - _INIT_DCS_CMD(0x10, 0x0F), - _INIT_DCS_CMD(0x11, 0x10), - _INIT_DCS_CMD(0x12, 0x11), - _INIT_DCS_CMD(0x13, 0x04), - _INIT_DCS_CMD(0x14, 0x00), - _INIT_DCS_CMD(0x15, 0x03), - _INIT_DCS_CMD(0x16, 0x03), - _INIT_DCS_CMD(0x17, 0x03), - _INIT_DCS_CMD(0x18, 0x03), - _INIT_DCS_CMD(0x19, 0x29), - _INIT_DCS_CMD(0x1A, 0x22), - _INIT_DCS_CMD(0x1B, 0x22), - _INIT_DCS_CMD(0x1C, 0x0B), - _INIT_DCS_CMD(0x1D, 0x1D), - _INIT_DCS_CMD(0x1E, 0x1C), - _INIT_DCS_CMD(0x1F, 0x05), - _INIT_DCS_CMD(0x20, 0x08), - _INIT_DCS_CMD(0x21, 0x09), - _INIT_DCS_CMD(0x22, 0x0A), - _INIT_DCS_CMD(0x23, 0x0C), - _INIT_DCS_CMD(0x24, 0x0D), - _INIT_DCS_CMD(0x25, 0x0E), - _INIT_DCS_CMD(0x26, 0x0F), - _INIT_DCS_CMD(0x27, 0x10), - _INIT_DCS_CMD(0x28, 0x11), - _INIT_DCS_CMD(0x29, 0x04), - _INIT_DCS_CMD(0x2A, 0x00), - _INIT_DCS_CMD(0x2B, 0x03), - - _INIT_DCS_CMD(0x2F, 0x0A), - _INIT_DCS_CMD(0x30, 0x35), - _INIT_DCS_CMD(0x37, 0xA7), - _INIT_DCS_CMD(0x39, 0x00), - _INIT_DCS_CMD(0x3A, 0x46), - _INIT_DCS_CMD(0x3B, 0x32), - _INIT_DCS_CMD(0x3D, 0x12), - - _INIT_DCS_CMD(0x3F, 0x33), - _INIT_DCS_CMD(0x40, 0x31), - _INIT_DCS_CMD(0x41, 0x40), - _INIT_DCS_CMD(0x42, 0x42), - _INIT_DCS_CMD(0x47, 0x77), - _INIT_DCS_CMD(0x48, 0x77), - _INIT_DCS_CMD(0x4A, 0x45), - _INIT_DCS_CMD(0x4B, 0x45), - _INIT_DCS_CMD(0x4C, 0x14), - - _INIT_DCS_CMD(0x4D, 0x21), - _INIT_DCS_CMD(0x4E, 0x43), - _INIT_DCS_CMD(0x4F, 0x65), - _INIT_DCS_CMD(0x55, 0x06), - _INIT_DCS_CMD(0x56, 0x06), - _INIT_DCS_CMD(0x58, 0x21), - _INIT_DCS_CMD(0x59, 0x70), - _INIT_DCS_CMD(0x5A, 0x46), - _INIT_DCS_CMD(0x5B, 0x32), - _INIT_DCS_CMD(0x5C, 0x88), - _INIT_DCS_CMD(0x5E, 0x00, 0x00), - _INIT_DCS_CMD(0x5F, 0x00), - - _INIT_DCS_CMD(0x7A, 0xFF), - _INIT_DCS_CMD(0x7B, 0xFF), - _INIT_DCS_CMD(0x7C, 0x00), - _INIT_DCS_CMD(0x7D, 0x00), - _INIT_DCS_CMD(0x7E, 0x20), - _INIT_DCS_CMD(0x7F, 0x3C), - _INIT_DCS_CMD(0x80, 0x00), - _INIT_DCS_CMD(0x81, 0x00), - _INIT_DCS_CMD(0x82, 0x08), - _INIT_DCS_CMD(0x97, 0x02), - _INIT_DCS_CMD(0xC5, 0x10), - - _INIT_DCS_CMD(0xD7, 0x55), - _INIT_DCS_CMD(0xD8, 0x55), - _INIT_DCS_CMD(0xD9, 0x23), - _INIT_DCS_CMD(0xDA, 0x05), - _INIT_DCS_CMD(0xDB, 0x01), - _INIT_DCS_CMD(0xDC, 0x65), - _INIT_DCS_CMD(0xDD, 0x55), - _INIT_DCS_CMD(0xDE, 0x27), - _INIT_DCS_CMD(0xDF, 0x01), - _INIT_DCS_CMD(0xE0, 0x65), - _INIT_DCS_CMD(0xE1, 0x01), - _INIT_DCS_CMD(0xE2, 0x65), - _INIT_DCS_CMD(0xE3, 0x01), - _INIT_DCS_CMD(0xE4, 0x65), - _INIT_DCS_CMD(0xE5, 0x01), - _INIT_DCS_CMD(0xE6, 0x65), - _INIT_DCS_CMD(0xE7, 0x00), - _INIT_DCS_CMD(0xE8, 0x00), - _INIT_DCS_CMD(0xE9, 0x01), - _INIT_DCS_CMD(0xEA, 0x65), - _INIT_DCS_CMD(0xEB, 0x01), - _INIT_DCS_CMD(0xEE, 0x65), - _INIT_DCS_CMD(0xEF, 0x01), - _INIT_DCS_CMD(0xF0, 0x65), - _INIT_DCS_CMD(0xB6, 0x05, 0x00, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05,= 0x05, 0x00, 0x00), - - _INIT_DCS_CMD(0xFF, 0x25), - - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x05, 0x00), - _INIT_DCS_CMD(0xF1, 0x10), - - _INIT_DCS_CMD(0x1E, 0x00), - _INIT_DCS_CMD(0x1F, 0x46), - _INIT_DCS_CMD(0x20, 0x32), - - _INIT_DCS_CMD(0x25, 0x00), - _INIT_DCS_CMD(0x26, 0x46), - _INIT_DCS_CMD(0x27, 0x32), - - _INIT_DCS_CMD(0x3F, 0x80), - _INIT_DCS_CMD(0x40, 0x00), - _INIT_DCS_CMD(0x43, 0x00), - - _INIT_DCS_CMD(0x44, 0x46), - _INIT_DCS_CMD(0x45, 0x46), - - _INIT_DCS_CMD(0x48, 0x46), - _INIT_DCS_CMD(0x49, 0x32), - - _INIT_DCS_CMD(0x5B, 0x80), - - _INIT_DCS_CMD(0x5C, 0x00), - _INIT_DCS_CMD(0x5D, 0x46), - _INIT_DCS_CMD(0x5E, 0x32), - - _INIT_DCS_CMD(0x5F, 0x46), - _INIT_DCS_CMD(0x60, 0x32), - - _INIT_DCS_CMD(0x61, 0x46), - _INIT_DCS_CMD(0x62, 0x32), - _INIT_DCS_CMD(0x68, 0x0C), - - _INIT_DCS_CMD(0x6C, 0x0D), - _INIT_DCS_CMD(0x6E, 0x0D), - _INIT_DCS_CMD(0x78, 0x00), - _INIT_DCS_CMD(0x79, 0xC5), - _INIT_DCS_CMD(0x7A, 0x0C), - _INIT_DCS_CMD(0x7B, 0xB0), - - _INIT_DCS_CMD(0xFF, 0x26), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x00, 0xA1), - _INIT_DCS_CMD(0x02, 0x31), - _INIT_DCS_CMD(0x0A, 0xF4), - _INIT_DCS_CMD(0x04, 0x50), - _INIT_DCS_CMD(0x06, 0x30), - _INIT_DCS_CMD(0x0C, 0x16), - _INIT_DCS_CMD(0x0D, 0x0D), - _INIT_DCS_CMD(0x0F, 0x00), - _INIT_DCS_CMD(0x11, 0x00), - _INIT_DCS_CMD(0x12, 0x50), - _INIT_DCS_CMD(0x13, 0x40), - _INIT_DCS_CMD(0x14, 0x58), - _INIT_DCS_CMD(0x15, 0x00), - _INIT_DCS_CMD(0x16, 0x10), - _INIT_DCS_CMD(0x17, 0xA0), - _INIT_DCS_CMD(0x18, 0x86), - _INIT_DCS_CMD(0x22, 0x00), - _INIT_DCS_CMD(0x23, 0x00), - - _INIT_DCS_CMD(0x19, 0x0E), - _INIT_DCS_CMD(0x1A, 0x31), - _INIT_DCS_CMD(0x1B, 0x0D), - _INIT_DCS_CMD(0x1C, 0x29), - _INIT_DCS_CMD(0x2A, 0x0E), - _INIT_DCS_CMD(0x2B, 0x31), - - _INIT_DCS_CMD(0x1D, 0x00), - _INIT_DCS_CMD(0x1E, 0x62), - _INIT_DCS_CMD(0x1F, 0x62), - - _INIT_DCS_CMD(0x2F, 0x06), - _INIT_DCS_CMD(0x30, 0x62), - _INIT_DCS_CMD(0x31, 0x06), - _INIT_DCS_CMD(0x32, 0x7F), - _INIT_DCS_CMD(0x33, 0x11), - _INIT_DCS_CMD(0x34, 0x89), - _INIT_DCS_CMD(0x35, 0x67), - - _INIT_DCS_CMD(0x39, 0x0B), - _INIT_DCS_CMD(0x3A, 0x62), - _INIT_DCS_CMD(0x3B, 0x06), - - _INIT_DCS_CMD(0xC8, 0x04), - _INIT_DCS_CMD(0xC9, 0x89), - _INIT_DCS_CMD(0xCA, 0x4E), - _INIT_DCS_CMD(0xCB, 0x00), - _INIT_DCS_CMD(0xA9, 0x3F), - _INIT_DCS_CMD(0xAA, 0x3E), - _INIT_DCS_CMD(0xAB, 0x3D), - _INIT_DCS_CMD(0xAC, 0x3C), - _INIT_DCS_CMD(0xAD, 0x3B), - _INIT_DCS_CMD(0xAE, 0x3A), - _INIT_DCS_CMD(0xAF, 0x39), - _INIT_DCS_CMD(0xB0, 0x38), - - _INIT_DCS_CMD(0xFF, 0x27), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0xD0, 0x11), - _INIT_DCS_CMD(0xD1, 0x54), - _INIT_DCS_CMD(0xDE, 0x43), - _INIT_DCS_CMD(0xDF, 0x02), - - _INIT_DCS_CMD(0xC0, 0x18), - _INIT_DCS_CMD(0xC1, 0x00), - _INIT_DCS_CMD(0xC2, 0x00), - _INIT_DCS_CMD(0x00, 0x00), - _INIT_DCS_CMD(0xC3, 0x00), - _INIT_DCS_CMD(0x56, 0x06), - - _INIT_DCS_CMD(0x58, 0x80), - _INIT_DCS_CMD(0x59, 0x78), - _INIT_DCS_CMD(0x5A, 0x00), - _INIT_DCS_CMD(0x5B, 0x18), - _INIT_DCS_CMD(0x5C, 0x00), - _INIT_DCS_CMD(0x5D, 0x01), - _INIT_DCS_CMD(0x5E, 0x20), - _INIT_DCS_CMD(0x5F, 0x10), - _INIT_DCS_CMD(0x60, 0x00), - _INIT_DCS_CMD(0x61, 0x1C), - _INIT_DCS_CMD(0x62, 0x00), - _INIT_DCS_CMD(0x63, 0x01), - _INIT_DCS_CMD(0x64, 0x44), - _INIT_DCS_CMD(0x65, 0x1B), - _INIT_DCS_CMD(0x66, 0x00), - _INIT_DCS_CMD(0x67, 0x01), - _INIT_DCS_CMD(0x68, 0x44), - - _INIT_DCS_CMD(0x98, 0x01), - _INIT_DCS_CMD(0xB4, 0x03), - _INIT_DCS_CMD(0x9B, 0xBE), - - _INIT_DCS_CMD(0xAB, 0x14), - _INIT_DCS_CMD(0xBC, 0x08), - _INIT_DCS_CMD(0xBD, 0x28), - - _INIT_DCS_CMD(0xFF, 0x2A), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x22, 0x2F), - _INIT_DCS_CMD(0x23, 0x08), - - _INIT_DCS_CMD(0x24, 0x00), - _INIT_DCS_CMD(0x25, 0x62), - _INIT_DCS_CMD(0x26, 0xF8), - _INIT_DCS_CMD(0x27, 0x00), - _INIT_DCS_CMD(0x28, 0x1A), - _INIT_DCS_CMD(0x29, 0x00), - _INIT_DCS_CMD(0x2A, 0x1A), - _INIT_DCS_CMD(0x2B, 0x00), - _INIT_DCS_CMD(0x2D, 0x1A), - - _INIT_DCS_CMD(0x64, 0x96), - _INIT_DCS_CMD(0x65, 0x10), - _INIT_DCS_CMD(0x66, 0x00), - _INIT_DCS_CMD(0x67, 0x96), - _INIT_DCS_CMD(0x68, 0x10), - _INIT_DCS_CMD(0x69, 0x00), - _INIT_DCS_CMD(0x6A, 0x96), - _INIT_DCS_CMD(0x6B, 0x10), - _INIT_DCS_CMD(0x6C, 0x00), - _INIT_DCS_CMD(0x70, 0x92), - _INIT_DCS_CMD(0x71, 0x10), - _INIT_DCS_CMD(0x72, 0x00), - _INIT_DCS_CMD(0x79, 0x96), - _INIT_DCS_CMD(0x7A, 0x10), - _INIT_DCS_CMD(0x88, 0x96), - _INIT_DCS_CMD(0x89, 0x10), - - _INIT_DCS_CMD(0xA2, 0x3F), - _INIT_DCS_CMD(0xA3, 0x30), - _INIT_DCS_CMD(0xA4, 0xC0), - _INIT_DCS_CMD(0xA5, 0x03), - - _INIT_DCS_CMD(0xE8, 0x00), - - _INIT_DCS_CMD(0x97, 0x3C), - _INIT_DCS_CMD(0x98, 0x02), - _INIT_DCS_CMD(0x99, 0x95), - _INIT_DCS_CMD(0x9A, 0x06), - _INIT_DCS_CMD(0x9B, 0x00), - _INIT_DCS_CMD(0x9C, 0x0B), - _INIT_DCS_CMD(0x9D, 0x0A), - _INIT_DCS_CMD(0x9E, 0x90), - - _INIT_DCS_CMD(0xFF, 0x25), - _INIT_DCS_CMD(0x13, 0x02), - _INIT_DCS_CMD(0x14, 0xD7), - _INIT_DCS_CMD(0xDB, 0x02), - _INIT_DCS_CMD(0xDC, 0xD7), - _INIT_DCS_CMD(0x17, 0xCF), - _INIT_DCS_CMD(0x19, 0x0F), - _INIT_DCS_CMD(0x1B, 0x5B), - - _INIT_DCS_CMD(0xFF, 0x20), - - _INIT_DCS_CMD(0xB0, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x24, 0x00, 0x38, 0x00,= 0x4C, 0x00, 0x5E, 0x00, 0x6F, 0x00, 0x7E), - _INIT_DCS_CMD(0xB1, 0x00, 0x8C, 0x00, 0xBE, 0x00, 0xE5, 0x01, 0x27, 0x01,= 0x58, 0x01, 0xA8, 0x01, 0xE8, 0x01, 0xEA), - _INIT_DCS_CMD(0xB2, 0x02, 0x28, 0x02, 0x71, 0x02, 0x9E, 0x02, 0xDA, 0x03,= 0x00, 0x03, 0x31, 0x03, 0x40, 0x03, 0x51), - _INIT_DCS_CMD(0xB3, 0x03, 0x62, 0x03, 0x75, 0x03, 0x89, 0x03, 0x9C, 0x03,= 0xAA, 0x03, 0xB2), - - _INIT_DCS_CMD(0xB4, 0x00, 0x00, 0x00, 0x0D, 0x00, 0x27, 0x00, 0x3D, 0x00,= 0x52, 0x00, 0x64, 0x00, 0x75, 0x00, 0x84), - _INIT_DCS_CMD(0xB5, 0x00, 0x93, 0x00, 0xC5, 0x00, 0xEC, 0x01, 0x2C, 0x01,= 0x5D, 0x01, 0xAC, 0x01, 0xEC, 0x01, 0xEE), - _INIT_DCS_CMD(0xB6, 0x02, 0x2B, 0x02, 0x73, 0x02, 0xA0, 0x02, 0xDB, 0x03,= 0x01, 0x03, 0x31, 0x03, 0x41, 0x03, 0x51), - _INIT_DCS_CMD(0xB7, 0x03, 0x63, 0x03, 0x75, 0x03, 0x89, 0x03, 0x9C, 0x03,= 0xAA, 0x03, 0xB2), - - _INIT_DCS_CMD(0xB8, 0x00, 0x00, 0x00, 0x0E, 0x00, 0x2A, 0x00, 0x40, 0x00,= 0x56, 0x00, 0x68, 0x00, 0x7A, 0x00, 0x89), - _INIT_DCS_CMD(0xB9, 0x00, 0x98, 0x00, 0xC9, 0x00, 0xF1, 0x01, 0x30, 0x01,= 0x61, 0x01, 0xB0, 0x01, 0xEF, 0x01, 0xF1), - _INIT_DCS_CMD(0xBA, 0x02, 0x2E, 0x02, 0x76, 0x02, 0xA3, 0x02, 0xDD, 0x03,= 0x02, 0x03, 0x32, 0x03, 0x42, 0x03, 0x53), - _INIT_DCS_CMD(0xBB, 0x03, 0x66, 0x03, 0x75, 0x03, 0x89, 0x03, 0x9C, 0x03,= 0xAA, 0x03, 0xB2), - - _INIT_DCS_CMD(0xFF, 0x21), - _INIT_DCS_CMD(0xB0, 0x00, 0x00, 0x00, 0x0C, 0x00, 0x24, 0x00, 0x38, 0x00,= 0x4C, 0x00, 0x5E, 0x00, 0x6F, 0x00, 0x7E), - _INIT_DCS_CMD(0xB1, 0x00, 0x8C, 0x00, 0xBE, 0x00, 0xE5, 0x01, 0x27, 0x01,= 0x58, 0x01, 0xA8, 0x01, 0xE8, 0x01, 0xEA), - _INIT_DCS_CMD(0xB2, 0x02, 0x28, 0x02, 0x71, 0x02, 0x9E, 0x02, 0xDA, 0x03,= 0x00, 0x03, 0x31, 0x03, 0x40, 0x03, 0x51), - _INIT_DCS_CMD(0xB3, 0x03, 0x62, 0x03, 0x77, 0x03, 0x90, 0x03, 0xAC, 0x03,= 0xCA, 0x03, 0xDA), - - _INIT_DCS_CMD(0xB4, 0x00, 0x00, 0x00, 0x0D, 0x00, 0x27, 0x00, 0x3D, 0x00,= 0x52, 0x00, 0x64, 0x00, 0x75, 0x00, 0x84), - _INIT_DCS_CMD(0xB5, 0x00, 0x93, 0x00, 0xC5, 0x00, 0xEC, 0x01, 0x2C, 0x01,= 0x5D, 0x01, 0xAC, 0x01, 0xEC, 0x01, 0xEE), - _INIT_DCS_CMD(0xB6, 0x02, 0x2B, 0x02, 0x73, 0x02, 0xA0, 0x02, 0xDB, 0x03,= 0x01, 0x03, 0x31, 0x03, 0x41, 0x03, 0x51), - _INIT_DCS_CMD(0xB7, 0x03, 0x63, 0x03, 0x77, 0x03, 0x90, 0x03, 0xAC, 0x03,= 0xCA, 0x03, 0xDA), - - _INIT_DCS_CMD(0xB8, 0x00, 0x00, 0x00, 0x0E, 0x00, 0x2A, 0x00, 0x40, 0x00,= 0x56, 0x00, 0x68, 0x00, 0x7A, 0x00, 0x89), - _INIT_DCS_CMD(0xB9, 0x00, 0x98, 0x00, 0xC9, 0x00, 0xF1, 0x01, 0x30, 0x01,= 0x61, 0x01, 0xB0, 0x01, 0xEF, 0x01, 0xF1), - _INIT_DCS_CMD(0xBA, 0x02, 0x2E, 0x02, 0x76, 0x02, 0xA3, 0x02, 0xDD, 0x03,= 0x02, 0x03, 0x32, 0x03, 0x42, 0x03, 0x53), - _INIT_DCS_CMD(0xBB, 0x03, 0x66, 0x03, 0x77, 0x03, 0x90, 0x03, 0xAC, 0x03,= 0xCA, 0x03, 0xDA), - - _INIT_DCS_CMD(0xFF, 0xF0), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x3A, 0x08), - - _INIT_DCS_CMD(0xFF, 0x10), - _INIT_DCS_CMD(0xB9, 0x01), - - _INIT_DCS_CMD(0xFF, 0x20), - - _INIT_DCS_CMD(0x18, 0x40), - _INIT_DCS_CMD(0xFF, 0x10), - - _INIT_DCS_CMD(0xB9, 0x02), - _INIT_DCS_CMD(0xFF, 0x10), - - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0xB0, 0x01), - _INIT_DCS_CMD(0x35, 0x00), - _INIT_DCS_CMD(0x3B, 0x03, 0xAE, 0x1A, 0x04, 0x04), - _INIT_DELAY_CMD(100), - _INIT_DCS_CMD(0x11), - _INIT_DELAY_CMD(200), - _INIT_DCS_CMD(0x29), - _INIT_DELAY_CMD(100), - {}, -}; + return 0; +} =20 -static const struct panel_init_cmd boe_init_cmd[] =3D { - _INIT_DCS_CMD(0xB0, 0x05), - _INIT_DCS_CMD(0xB1, 0xE5), - _INIT_DCS_CMD(0xB3, 0x52), - _INIT_DCS_CMD(0xB0, 0x00), - _INIT_DCS_CMD(0xB3, 0x88), - _INIT_DCS_CMD(0xB0, 0x04), - _INIT_DCS_CMD(0xB8, 0x00), - _INIT_DCS_CMD(0xB0, 0x00), - _INIT_DCS_CMD(0xB6, 0x03), - _INIT_DCS_CMD(0xBA, 0x8B), - _INIT_DCS_CMD(0xBF, 0x1A), - _INIT_DCS_CMD(0xC0, 0x0F), - _INIT_DCS_CMD(0xC2, 0x0C), - _INIT_DCS_CMD(0xC3, 0x02), - _INIT_DCS_CMD(0xC4, 0x0C), - _INIT_DCS_CMD(0xC5, 0x02), - _INIT_DCS_CMD(0xB0, 0x01), - _INIT_DCS_CMD(0xE0, 0x26), - _INIT_DCS_CMD(0xE1, 0x26), - _INIT_DCS_CMD(0xDC, 0x00), - _INIT_DCS_CMD(0xDD, 0x00), - _INIT_DCS_CMD(0xCC, 0x26), - _INIT_DCS_CMD(0xCD, 0x26), - _INIT_DCS_CMD(0xC8, 0x00), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xD2, 0x03), - _INIT_DCS_CMD(0xD3, 0x03), - _INIT_DCS_CMD(0xE6, 0x04), - _INIT_DCS_CMD(0xE7, 0x04), - _INIT_DCS_CMD(0xC4, 0x09), - _INIT_DCS_CMD(0xC5, 0x09), - _INIT_DCS_CMD(0xD8, 0x0A), - _INIT_DCS_CMD(0xD9, 0x0A), - _INIT_DCS_CMD(0xC2, 0x0B), - _INIT_DCS_CMD(0xC3, 0x0B), - _INIT_DCS_CMD(0xD6, 0x0C), - _INIT_DCS_CMD(0xD7, 0x0C), - _INIT_DCS_CMD(0xC0, 0x05), - _INIT_DCS_CMD(0xC1, 0x05), - _INIT_DCS_CMD(0xD4, 0x06), - _INIT_DCS_CMD(0xD5, 0x06), - _INIT_DCS_CMD(0xCA, 0x07), - _INIT_DCS_CMD(0xCB, 0x07), - _INIT_DCS_CMD(0xDE, 0x08), - _INIT_DCS_CMD(0xDF, 0x08), - _INIT_DCS_CMD(0xB0, 0x02), - _INIT_DCS_CMD(0xC0, 0x00), - _INIT_DCS_CMD(0xC1, 0x0D), - _INIT_DCS_CMD(0xC2, 0x17), - _INIT_DCS_CMD(0xC3, 0x26), - _INIT_DCS_CMD(0xC4, 0x31), - _INIT_DCS_CMD(0xC5, 0x1C), - _INIT_DCS_CMD(0xC6, 0x2C), - _INIT_DCS_CMD(0xC7, 0x33), - _INIT_DCS_CMD(0xC8, 0x31), - _INIT_DCS_CMD(0xC9, 0x37), - _INIT_DCS_CMD(0xCA, 0x37), - _INIT_DCS_CMD(0xCB, 0x37), - _INIT_DCS_CMD(0xCC, 0x39), - _INIT_DCS_CMD(0xCD, 0x2E), - _INIT_DCS_CMD(0xCE, 0x2F), - _INIT_DCS_CMD(0xCF, 0x2F), - _INIT_DCS_CMD(0xD0, 0x07), - _INIT_DCS_CMD(0xD2, 0x00), - _INIT_DCS_CMD(0xD3, 0x0D), - _INIT_DCS_CMD(0xD4, 0x17), - _INIT_DCS_CMD(0xD5, 0x26), - _INIT_DCS_CMD(0xD6, 0x31), - _INIT_DCS_CMD(0xD7, 0x3F), - _INIT_DCS_CMD(0xD8, 0x3F), - _INIT_DCS_CMD(0xD9, 0x3F), - _INIT_DCS_CMD(0xDA, 0x3F), - _INIT_DCS_CMD(0xDB, 0x37), - _INIT_DCS_CMD(0xDC, 0x37), - _INIT_DCS_CMD(0xDD, 0x37), - _INIT_DCS_CMD(0xDE, 0x39), - _INIT_DCS_CMD(0xDF, 0x2E), - _INIT_DCS_CMD(0xE0, 0x2F), - _INIT_DCS_CMD(0xE1, 0x2F), - _INIT_DCS_CMD(0xE2, 0x07), - _INIT_DCS_CMD(0xB0, 0x03), - _INIT_DCS_CMD(0xC8, 0x0B), - _INIT_DCS_CMD(0xC9, 0x07), - _INIT_DCS_CMD(0xC3, 0x00), - _INIT_DCS_CMD(0xE7, 0x00), - _INIT_DCS_CMD(0xC5, 0x2A), - _INIT_DCS_CMD(0xDE, 0x2A), - _INIT_DCS_CMD(0xCA, 0x43), - _INIT_DCS_CMD(0xC9, 0x07), - _INIT_DCS_CMD(0xE4, 0xC0), - _INIT_DCS_CMD(0xE5, 0x0D), - _INIT_DCS_CMD(0xCB, 0x00), - _INIT_DCS_CMD(0xB0, 0x06), - _INIT_DCS_CMD(0xB8, 0xA5), - _INIT_DCS_CMD(0xC0, 0xA5), - _INIT_DCS_CMD(0xC7, 0x0F), - _INIT_DCS_CMD(0xD5, 0x32), - _INIT_DCS_CMD(0xB8, 0x00), - _INIT_DCS_CMD(0xC0, 0x00), - _INIT_DCS_CMD(0xBC, 0x00), - _INIT_DCS_CMD(0xB0, 0x07), - _INIT_DCS_CMD(0xB1, 0x00), - _INIT_DCS_CMD(0xB2, 0x02), - _INIT_DCS_CMD(0xB3, 0x0F), - _INIT_DCS_CMD(0xB4, 0x25), - _INIT_DCS_CMD(0xB5, 0x39), - _INIT_DCS_CMD(0xB6, 0x4E), - _INIT_DCS_CMD(0xB7, 0x72), - _INIT_DCS_CMD(0xB8, 0x97), - _INIT_DCS_CMD(0xB9, 0xDC), - _INIT_DCS_CMD(0xBA, 0x22), - _INIT_DCS_CMD(0xBB, 0xA4), - _INIT_DCS_CMD(0xBC, 0x2B), - _INIT_DCS_CMD(0xBD, 0x2F), - _INIT_DCS_CMD(0xBE, 0xA9), - _INIT_DCS_CMD(0xBF, 0x25), - _INIT_DCS_CMD(0xC0, 0x61), - _INIT_DCS_CMD(0xC1, 0x97), - _INIT_DCS_CMD(0xC2, 0xB2), - _INIT_DCS_CMD(0xC3, 0xCD), - _INIT_DCS_CMD(0xC4, 0xD9), - _INIT_DCS_CMD(0xC5, 0xE7), - _INIT_DCS_CMD(0xC6, 0xF4), - _INIT_DCS_CMD(0xC7, 0xFA), - _INIT_DCS_CMD(0xC8, 0xFC), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xCA, 0x00), - _INIT_DCS_CMD(0xCB, 0x16), - _INIT_DCS_CMD(0xCC, 0xAF), - _INIT_DCS_CMD(0xCD, 0xFF), - _INIT_DCS_CMD(0xCE, 0xFF), - _INIT_DCS_CMD(0xB0, 0x08), - _INIT_DCS_CMD(0xB1, 0x04), - _INIT_DCS_CMD(0xB2, 0x05), - _INIT_DCS_CMD(0xB3, 0x11), - _INIT_DCS_CMD(0xB4, 0x24), - _INIT_DCS_CMD(0xB5, 0x39), - _INIT_DCS_CMD(0xB6, 0x4F), - _INIT_DCS_CMD(0xB7, 0x72), - _INIT_DCS_CMD(0xB8, 0x98), - _INIT_DCS_CMD(0xB9, 0xDC), - _INIT_DCS_CMD(0xBA, 0x23), - _INIT_DCS_CMD(0xBB, 0xA6), - _INIT_DCS_CMD(0xBC, 0x2C), - _INIT_DCS_CMD(0xBD, 0x30), - _INIT_DCS_CMD(0xBE, 0xAA), - _INIT_DCS_CMD(0xBF, 0x26), - _INIT_DCS_CMD(0xC0, 0x62), - _INIT_DCS_CMD(0xC1, 0x9B), - _INIT_DCS_CMD(0xC2, 0xB5), - _INIT_DCS_CMD(0xC3, 0xCF), - _INIT_DCS_CMD(0xC4, 0xDB), - _INIT_DCS_CMD(0xC5, 0xE8), - _INIT_DCS_CMD(0xC6, 0xF5), - _INIT_DCS_CMD(0xC7, 0xFA), - _INIT_DCS_CMD(0xC8, 0xFC), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xCA, 0x00), - _INIT_DCS_CMD(0xCB, 0x16), - _INIT_DCS_CMD(0xCC, 0xAF), - _INIT_DCS_CMD(0xCD, 0xFF), - _INIT_DCS_CMD(0xCE, 0xFF), - _INIT_DCS_CMD(0xB0, 0x09), - _INIT_DCS_CMD(0xB1, 0x04), - _INIT_DCS_CMD(0xB2, 0x02), - _INIT_DCS_CMD(0xB3, 0x16), - _INIT_DCS_CMD(0xB4, 0x24), - _INIT_DCS_CMD(0xB5, 0x3B), - _INIT_DCS_CMD(0xB6, 0x4F), - _INIT_DCS_CMD(0xB7, 0x73), - _INIT_DCS_CMD(0xB8, 0x99), - _INIT_DCS_CMD(0xB9, 0xE0), - _INIT_DCS_CMD(0xBA, 0x26), - _INIT_DCS_CMD(0xBB, 0xAD), - _INIT_DCS_CMD(0xBC, 0x36), - _INIT_DCS_CMD(0xBD, 0x3A), - _INIT_DCS_CMD(0xBE, 0xAE), - _INIT_DCS_CMD(0xBF, 0x2A), - _INIT_DCS_CMD(0xC0, 0x66), - _INIT_DCS_CMD(0xC1, 0x9E), - _INIT_DCS_CMD(0xC2, 0xB8), - _INIT_DCS_CMD(0xC3, 0xD1), - _INIT_DCS_CMD(0xC4, 0xDD), - _INIT_DCS_CMD(0xC5, 0xE9), - _INIT_DCS_CMD(0xC6, 0xF6), - _INIT_DCS_CMD(0xC7, 0xFA), - _INIT_DCS_CMD(0xC8, 0xFC), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xCA, 0x00), - _INIT_DCS_CMD(0xCB, 0x16), - _INIT_DCS_CMD(0xCC, 0xAF), - _INIT_DCS_CMD(0xCD, 0xFF), - _INIT_DCS_CMD(0xCE, 0xFF), - _INIT_DCS_CMD(0xB0, 0x0A), - _INIT_DCS_CMD(0xB1, 0x00), - _INIT_DCS_CMD(0xB2, 0x02), - _INIT_DCS_CMD(0xB3, 0x0F), - _INIT_DCS_CMD(0xB4, 0x25), - _INIT_DCS_CMD(0xB5, 0x39), - _INIT_DCS_CMD(0xB6, 0x4E), - _INIT_DCS_CMD(0xB7, 0x72), - _INIT_DCS_CMD(0xB8, 0x97), - _INIT_DCS_CMD(0xB9, 0xDC), - _INIT_DCS_CMD(0xBA, 0x22), - _INIT_DCS_CMD(0xBB, 0xA4), - _INIT_DCS_CMD(0xBC, 0x2B), - _INIT_DCS_CMD(0xBD, 0x2F), - _INIT_DCS_CMD(0xBE, 0xA9), - _INIT_DCS_CMD(0xBF, 0x25), - _INIT_DCS_CMD(0xC0, 0x61), - _INIT_DCS_CMD(0xC1, 0x97), - _INIT_DCS_CMD(0xC2, 0xB2), - _INIT_DCS_CMD(0xC3, 0xCD), - _INIT_DCS_CMD(0xC4, 0xD9), - _INIT_DCS_CMD(0xC5, 0xE7), - _INIT_DCS_CMD(0xC6, 0xF4), - _INIT_DCS_CMD(0xC7, 0xFA), - _INIT_DCS_CMD(0xC8, 0xFC), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xCA, 0x00), - _INIT_DCS_CMD(0xCB, 0x16), - _INIT_DCS_CMD(0xCC, 0xAF), - _INIT_DCS_CMD(0xCD, 0xFF), - _INIT_DCS_CMD(0xCE, 0xFF), - _INIT_DCS_CMD(0xB0, 0x0B), - _INIT_DCS_CMD(0xB1, 0x04), - _INIT_DCS_CMD(0xB2, 0x05), - _INIT_DCS_CMD(0xB3, 0x11), - _INIT_DCS_CMD(0xB4, 0x24), - _INIT_DCS_CMD(0xB5, 0x39), - _INIT_DCS_CMD(0xB6, 0x4F), - _INIT_DCS_CMD(0xB7, 0x72), - _INIT_DCS_CMD(0xB8, 0x98), - _INIT_DCS_CMD(0xB9, 0xDC), - _INIT_DCS_CMD(0xBA, 0x23), - _INIT_DCS_CMD(0xBB, 0xA6), - _INIT_DCS_CMD(0xBC, 0x2C), - _INIT_DCS_CMD(0xBD, 0x30), - _INIT_DCS_CMD(0xBE, 0xAA), - _INIT_DCS_CMD(0xBF, 0x26), - _INIT_DCS_CMD(0xC0, 0x62), - _INIT_DCS_CMD(0xC1, 0x9B), - _INIT_DCS_CMD(0xC2, 0xB5), - _INIT_DCS_CMD(0xC3, 0xCF), - _INIT_DCS_CMD(0xC4, 0xDB), - _INIT_DCS_CMD(0xC5, 0xE8), - _INIT_DCS_CMD(0xC6, 0xF5), - _INIT_DCS_CMD(0xC7, 0xFA), - _INIT_DCS_CMD(0xC8, 0xFC), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xCA, 0x00), - _INIT_DCS_CMD(0xCB, 0x16), - _INIT_DCS_CMD(0xCC, 0xAF), - _INIT_DCS_CMD(0xCD, 0xFF), - _INIT_DCS_CMD(0xCE, 0xFF), - _INIT_DCS_CMD(0xB0, 0x0C), - _INIT_DCS_CMD(0xB1, 0x04), - _INIT_DCS_CMD(0xB2, 0x02), - _INIT_DCS_CMD(0xB3, 0x16), - _INIT_DCS_CMD(0xB4, 0x24), - _INIT_DCS_CMD(0xB5, 0x3B), - _INIT_DCS_CMD(0xB6, 0x4F), - _INIT_DCS_CMD(0xB7, 0x73), - _INIT_DCS_CMD(0xB8, 0x99), - _INIT_DCS_CMD(0xB9, 0xE0), - _INIT_DCS_CMD(0xBA, 0x26), - _INIT_DCS_CMD(0xBB, 0xAD), - _INIT_DCS_CMD(0xBC, 0x36), - _INIT_DCS_CMD(0xBD, 0x3A), - _INIT_DCS_CMD(0xBE, 0xAE), - _INIT_DCS_CMD(0xBF, 0x2A), - _INIT_DCS_CMD(0xC0, 0x66), - _INIT_DCS_CMD(0xC1, 0x9E), - _INIT_DCS_CMD(0xC2, 0xB8), - _INIT_DCS_CMD(0xC3, 0xD1), - _INIT_DCS_CMD(0xC4, 0xDD), - _INIT_DCS_CMD(0xC5, 0xE9), - _INIT_DCS_CMD(0xC6, 0xF6), - _INIT_DCS_CMD(0xC7, 0xFA), - _INIT_DCS_CMD(0xC8, 0xFC), - _INIT_DCS_CMD(0xC9, 0x00), - _INIT_DCS_CMD(0xCA, 0x00), - _INIT_DCS_CMD(0xCB, 0x16), - _INIT_DCS_CMD(0xCC, 0xAF), - _INIT_DCS_CMD(0xCD, 0xFF), - _INIT_DCS_CMD(0xCE, 0xFF), - _INIT_DCS_CMD(0xB0, 0x00), - _INIT_DCS_CMD(0xB3, 0x08), - _INIT_DCS_CMD(0xB0, 0x04), - _INIT_DCS_CMD(0xB8, 0x68), - _INIT_DELAY_CMD(150), - {}, -}; +static int inx_hj110iz_init(struct mipi_dsi_device *dsi) +{ + int ret; =20 -static const struct panel_init_cmd auo_kd101n80_45na_init_cmd[] =3D { - _INIT_DELAY_CMD(24), - _INIT_DCS_CMD(0x11), - _INIT_DELAY_CMD(120), - _INIT_DCS_CMD(0x29), - _INIT_DELAY_CMD(120), - {}, -}; + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0xD1); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x63); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x8C); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x4B); + mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x91); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x69); + mipi_dsi_dcs_write_seq(dsi, 0x95, 0xF5); + mipi_dsi_dcs_write_seq(dsi, 0x96, 0xF5); + mipi_dsi_dcs_write_seq(dsi, 0x9D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x9E, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x69, 0x98); + mipi_dsi_dcs_write_seq(dsi, 0x75, 0xA2); + mipi_dsi_dcs_write_seq(dsi, 0x77, 0xB3); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x91, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0x92, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0x93, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x94, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0x9A, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x60, 0x96); + mipi_dsi_dcs_write_seq(dsi, 0x61, 0xD0); + mipi_dsi_dcs_write_seq(dsi, 0x63, 0x70); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xCF); + mipi_dsi_dcs_write_seq(dsi, 0x9B, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0x9A, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x01, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x03, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x22); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0x1D); + mipi_dsi_dcs_write_seq(dsi, 0x0A, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0x0B, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0x10, 0x0E); + mipi_dsi_dcs_write_seq(dsi, 0x11, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x12, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x13, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x15, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x16, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x17, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x19, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x1A, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x1B, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x1C, 0x22); + mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x1D); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0x21, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0x0E); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x28, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x03); + + mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x32); + mipi_dsi_dcs_write_seq(dsi, 0x31, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x32); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x37, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0x38, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x93); + mipi_dsi_dcs_write_seq(dsi, 0xAB, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0xAC, 0x40); + + mipi_dsi_dcs_write_seq(dsi, 0x4D, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0x4E, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x4F, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x50, 0x87); + mipi_dsi_dcs_write_seq(dsi, 0x51, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x52, 0x56); + mipi_dsi_dcs_write_seq(dsi, 0x53, 0x34); + mipi_dsi_dcs_write_seq(dsi, 0x54, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0x55, 0x83); + mipi_dsi_dcs_write_seq(dsi, 0x56, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x58, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0x59, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0x5A, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x00, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x5F, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x7A, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x7B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x7C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x7D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x7E, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0x7F, 0x3C); + mipi_dsi_dcs_write_seq(dsi, 0x80, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x81, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x82, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x97, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xDA, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x55); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x27); + mipi_dsi_dcs_write_seq(dsi, 0xDF, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xE3, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xE8, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xEA, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xEB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xEE, 0x7A); + mipi_dsi_dcs_write_seq(dsi, 0xEF, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xF0, 0x7A); + + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x05, 0x00, 0x05, 0x00, 0x00, 0x00, 0x0= 0, 0x00, 0x05, 0x05, 0x00, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x25); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x05, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x13, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0xDF); + mipi_dsi_dcs_write_seq(dsi, 0xF1, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0x3F, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x40, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x43, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x44, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0x45, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x48, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x49, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x61, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x62, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0x68, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x00, 0xA1); + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0x0A, 0xF2); + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x28); + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x30); + mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x11, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x12, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0x13, 0x56); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0x57); + mipi_dsi_dcs_write_seq(dsi, 0x15, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x16, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x17, 0xA0); + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x86); + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x19, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x1A, 0x7F); + mipi_dsi_dcs_write_seq(dsi, 0x1B, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x1C, 0xBF); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x7F); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x78); + + mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x11); + + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x78); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x06); + + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x84); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x4E); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0xA9, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0xAA, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xAB, 0x4D); + mipi_dsi_dcs_write_seq(dsi, 0xAC, 0x4A); + mipi_dsi_dcs_write_seq(dsi, 0xAD, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xAE, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x27); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x56, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x58, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x59, 0x75); + mipi_dsi_dcs_write_seq(dsi, 0x5A, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0x5F, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x60, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x61, 0x2E); + mipi_dsi_dcs_write_seq(dsi, 0x62, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x63, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x64, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x65, 0x2D); + mipi_dsi_dcs_write_seq(dsi, 0x66, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x67, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x68, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0x98, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x9B, 0xBD); + mipi_dsi_dcs_write_seq(dsi, 0xA0, 0x90); + mipi_dsi_dcs_write_seq(dsi, 0xAB, 0x1B); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x28); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x08); + + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0xF8); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x28, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x2D, 0x1A); + + mipi_dsi_dcs_write_seq(dsi, 0x64, 0x96); + mipi_dsi_dcs_write_seq(dsi, 0x65, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x66, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x6A, 0x96); + mipi_dsi_dcs_write_seq(dsi, 0x6B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x6C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x70, 0x92); + mipi_dsi_dcs_write_seq(dsi, 0x71, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x72, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xA2, 0x33); + mipi_dsi_dcs_write_seq(dsi, 0xA3, 0x30); + mipi_dsi_dcs_write_seq(dsi, 0xA4, 0xC0); + mipi_dsi_dcs_write_seq(dsi, 0xE8, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x97, 0x3C); + mipi_dsi_dcs_write_seq(dsi, 0x98, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x99, 0x95); + mipi_dsi_dcs_write_seq(dsi, 0x9A, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x9B, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x9C, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0x9D, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x9E, 0x90); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0xF0); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0xD0); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x33); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0xBF); + mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x33); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x88); + mipi_dsi_dcs_write_seq(dsi, 0x5D, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xFB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x03, 0x96, 0x1A, 0x04, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x51, 0x0F, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0x53, 0x24); + msleep(100); + ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(200); + ret =3D mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(100); =20 -static const struct panel_init_cmd auo_b101uan08_3_init_cmd[] =3D { - _INIT_DELAY_CMD(24), - _INIT_DCS_CMD(0xB0, 0x01), - _INIT_DCS_CMD(0xC0, 0x48), - _INIT_DCS_CMD(0xC1, 0x48), - _INIT_DCS_CMD(0xC2, 0x47), - _INIT_DCS_CMD(0xC3, 0x47), - _INIT_DCS_CMD(0xC4, 0x46), - _INIT_DCS_CMD(0xC5, 0x46), - _INIT_DCS_CMD(0xC6, 0x45), - _INIT_DCS_CMD(0xC7, 0x45), - _INIT_DCS_CMD(0xC8, 0x64), - _INIT_DCS_CMD(0xC9, 0x64), - _INIT_DCS_CMD(0xCA, 0x4F), - _INIT_DCS_CMD(0xCB, 0x4F), - _INIT_DCS_CMD(0xCC, 0x40), - _INIT_DCS_CMD(0xCD, 0x40), - _INIT_DCS_CMD(0xCE, 0x66), - _INIT_DCS_CMD(0xCF, 0x66), - _INIT_DCS_CMD(0xD0, 0x4F), - _INIT_DCS_CMD(0xD1, 0x4F), - _INIT_DCS_CMD(0xD2, 0x41), - _INIT_DCS_CMD(0xD3, 0x41), - _INIT_DCS_CMD(0xD4, 0x48), - _INIT_DCS_CMD(0xD5, 0x48), - _INIT_DCS_CMD(0xD6, 0x47), - _INIT_DCS_CMD(0xD7, 0x47), - _INIT_DCS_CMD(0xD8, 0x46), - _INIT_DCS_CMD(0xD9, 0x46), - _INIT_DCS_CMD(0xDA, 0x45), - _INIT_DCS_CMD(0xDB, 0x45), - _INIT_DCS_CMD(0xDC, 0x64), - _INIT_DCS_CMD(0xDD, 0x64), - _INIT_DCS_CMD(0xDE, 0x4F), - _INIT_DCS_CMD(0xDF, 0x4F), - _INIT_DCS_CMD(0xE0, 0x40), - _INIT_DCS_CMD(0xE1, 0x40), - _INIT_DCS_CMD(0xE2, 0x66), - _INIT_DCS_CMD(0xE3, 0x66), - _INIT_DCS_CMD(0xE4, 0x4F), - _INIT_DCS_CMD(0xE5, 0x4F), - _INIT_DCS_CMD(0xE6, 0x41), - _INIT_DCS_CMD(0xE7, 0x41), - _INIT_DELAY_CMD(150), - {}, -}; + return 0; +} =20 -static const struct panel_init_cmd starry_qfh032011_53g_init_cmd[] =3D { - _INIT_DCS_CMD(0xB0, 0x01), - _INIT_DCS_CMD(0xC3, 0x4F), - _INIT_DCS_CMD(0xC4, 0x40), - _INIT_DCS_CMD(0xC5, 0x40), - _INIT_DCS_CMD(0xC6, 0x40), - _INIT_DCS_CMD(0xC7, 0x40), - _INIT_DCS_CMD(0xC8, 0x4D), - _INIT_DCS_CMD(0xC9, 0x52), - _INIT_DCS_CMD(0xCA, 0x51), - _INIT_DCS_CMD(0xCD, 0x5D), - _INIT_DCS_CMD(0xCE, 0x5B), - _INIT_DCS_CMD(0xCF, 0x4B), - _INIT_DCS_CMD(0xD0, 0x49), - _INIT_DCS_CMD(0xD1, 0x47), - _INIT_DCS_CMD(0xD2, 0x45), - _INIT_DCS_CMD(0xD3, 0x41), - _INIT_DCS_CMD(0xD7, 0x50), - _INIT_DCS_CMD(0xD8, 0x40), - _INIT_DCS_CMD(0xD9, 0x40), - _INIT_DCS_CMD(0xDA, 0x40), - _INIT_DCS_CMD(0xDB, 0x40), - _INIT_DCS_CMD(0xDC, 0x4E), - _INIT_DCS_CMD(0xDD, 0x52), - _INIT_DCS_CMD(0xDE, 0x51), - _INIT_DCS_CMD(0xE1, 0x5E), - _INIT_DCS_CMD(0xE2, 0x5C), - _INIT_DCS_CMD(0xE3, 0x4C), - _INIT_DCS_CMD(0xE4, 0x4A), - _INIT_DCS_CMD(0xE5, 0x48), - _INIT_DCS_CMD(0xE6, 0x46), - _INIT_DCS_CMD(0xE7, 0x42), - _INIT_DCS_CMD(0xB0, 0x03), - _INIT_DCS_CMD(0xBE, 0x03), - _INIT_DCS_CMD(0xCC, 0x44), - _INIT_DCS_CMD(0xC8, 0x07), - _INIT_DCS_CMD(0xC9, 0x05), - _INIT_DCS_CMD(0xCA, 0x42), - _INIT_DCS_CMD(0xCD, 0x3E), - _INIT_DCS_CMD(0xCF, 0x60), - _INIT_DCS_CMD(0xD2, 0x04), - _INIT_DCS_CMD(0xD3, 0x04), - _INIT_DCS_CMD(0xD4, 0x01), - _INIT_DCS_CMD(0xD5, 0x00), - _INIT_DCS_CMD(0xD6, 0x03), - _INIT_DCS_CMD(0xD7, 0x04), - _INIT_DCS_CMD(0xD9, 0x01), - _INIT_DCS_CMD(0xDB, 0x01), - _INIT_DCS_CMD(0xE4, 0xF0), - _INIT_DCS_CMD(0xE5, 0x0A), - _INIT_DCS_CMD(0xB0, 0x00), - _INIT_DCS_CMD(0xCC, 0x08), - _INIT_DCS_CMD(0xC2, 0x08), - _INIT_DCS_CMD(0xC4, 0x10), - _INIT_DCS_CMD(0xB0, 0x02), - _INIT_DCS_CMD(0xC0, 0x00), - _INIT_DCS_CMD(0xC1, 0x0A), - _INIT_DCS_CMD(0xC2, 0x20), - _INIT_DCS_CMD(0xC3, 0x24), - _INIT_DCS_CMD(0xC4, 0x23), - _INIT_DCS_CMD(0xC5, 0x29), - _INIT_DCS_CMD(0xC6, 0x23), - _INIT_DCS_CMD(0xC7, 0x1C), - _INIT_DCS_CMD(0xC8, 0x19), - _INIT_DCS_CMD(0xC9, 0x17), - _INIT_DCS_CMD(0xCA, 0x17), - _INIT_DCS_CMD(0xCB, 0x18), - _INIT_DCS_CMD(0xCC, 0x1A), - _INIT_DCS_CMD(0xCD, 0x1E), - _INIT_DCS_CMD(0xCE, 0x20), - _INIT_DCS_CMD(0xCF, 0x23), - _INIT_DCS_CMD(0xD0, 0x07), - _INIT_DCS_CMD(0xD1, 0x00), - _INIT_DCS_CMD(0xD2, 0x00), - _INIT_DCS_CMD(0xD3, 0x0A), - _INIT_DCS_CMD(0xD4, 0x13), - _INIT_DCS_CMD(0xD5, 0x1C), - _INIT_DCS_CMD(0xD6, 0x1A), - _INIT_DCS_CMD(0xD7, 0x13), - _INIT_DCS_CMD(0xD8, 0x17), - _INIT_DCS_CMD(0xD9, 0x1C), - _INIT_DCS_CMD(0xDA, 0x19), - _INIT_DCS_CMD(0xDB, 0x17), - _INIT_DCS_CMD(0xDC, 0x17), - _INIT_DCS_CMD(0xDD, 0x18), - _INIT_DCS_CMD(0xDE, 0x1A), - _INIT_DCS_CMD(0xDF, 0x1E), - _INIT_DCS_CMD(0xE0, 0x20), - _INIT_DCS_CMD(0xE1, 0x23), - _INIT_DCS_CMD(0xE2, 0x07), - _INIT_DCS_CMD(0X11), - _INIT_DELAY_CMD(120), - _INIT_DCS_CMD(0X29), - _INIT_DELAY_CMD(80), - {}, -}; +static int boe_init(struct mipi_dsi_device *dsi) +{ + msleep(24); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0xE5); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x52); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x88); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x8B); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xD9, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xD4, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xDF, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0x33); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x37); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x37); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x37); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0x2E); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0xD4, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xD9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xDA, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x37); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x37); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x37); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xDF, 0x2E); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x43); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0xC0); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0xA5); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0xA5); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x32); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x25); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x4E); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x72); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0xDC); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x22); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0xA4); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x2B); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x25); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x61); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xB2); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xCD); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xD9); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xE7); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xF4); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xFC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0xAF); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x72); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x98); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0xDC); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0xA6); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x30); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xAA); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x62); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x9B); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xB5); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xCF); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xDB); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xE8); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xF5); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xFC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0xAF); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x3B); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x99); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0xAD); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x36); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x3A); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xAE); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x9E); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xB8); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xD1); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xDD); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xE9); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xF6); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xFC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0xAF); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x25); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x4E); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x72); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0xDC); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x22); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0xA4); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x2B); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x2F); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xA9); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x25); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x61); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xB2); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xCD); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xD9); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xE7); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xF4); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xFC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0xAF); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x39); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x72); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x98); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0xDC); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0xA6); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x2C); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x30); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xAA); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x62); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x9B); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xB5); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xCF); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xDB); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xE8); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xF5); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xFC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0xAF); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x3B); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x99); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x26); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0xAD); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x36); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x3A); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xAE); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0x2A); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x9E); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xB8); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xD1); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xDD); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xE9); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xF6); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xFC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0xAF); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x68); + msleep(150); =20 -static const struct panel_init_cmd starry_himax83102_j02_init_cmd[] =3D { - _INIT_DCS_CMD(0xB9, 0x83, 0x10, 0x21, 0x55, 0x00), - _INIT_DCS_CMD(0xB1, 0x2C, 0xB5, 0xB5, 0x31, 0xF1, 0x31, 0xD7, 0x2F, 0x36,= 0x36, 0x36, 0x36, 0x1A, 0x8B, 0x11, - 0x65, 0x00, 0x88, 0xFA, 0xFF, 0xFF, 0x8F, 0xFF, 0x08, 0x74, 0x33), - _INIT_DCS_CMD(0xB2, 0x00, 0x47, 0xB0, 0x80, 0x00, 0x12, 0x72, 0x3C, 0xA3,= 0x03, 0x03, 0x00, 0x00, 0x88, 0xF5), - _INIT_DCS_CMD(0xB4, 0x76, 0x76, 0x76, 0x76, 0x76, 0x76, 0x63, 0x5C, 0x63,= 0x5C, 0x01, 0x9E), - _INIT_DCS_CMD(0xE9, 0xCD), - _INIT_DCS_CMD(0xBA, 0x84), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xBC, 0x1B, 0x04), - _INIT_DCS_CMD(0xBE, 0x20), - _INIT_DCS_CMD(0xBF, 0xFC, 0xC4), - _INIT_DCS_CMD(0xC0, 0x36, 0x36, 0x22, 0x11, 0x22, 0xA0, 0x61, 0x08, 0xF5,= 0x03), - _INIT_DCS_CMD(0xE9, 0xCC), - _INIT_DCS_CMD(0xC7, 0x80), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xE9, 0xC6), - _INIT_DCS_CMD(0xC8, 0x97), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xC9, 0x00, 0x1E, 0x13, 0x88, 0x01), - _INIT_DCS_CMD(0xCB, 0x08, 0x13, 0x07, 0x00, 0x0F, 0x33), - _INIT_DCS_CMD(0xCC, 0x02), - _INIT_DCS_CMD(0xE9, 0xC4), - _INIT_DCS_CMD(0xD0, 0x03), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xD1, 0x37, 0x06, 0x00, 0x02, 0x04, 0x0C, 0xFF), - _INIT_DCS_CMD(0xD2, 0x1F, 0x11, 0x1F), - _INIT_DCS_CMD(0xD3, 0x06, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x08,= 0x37, 0x47, 0x34, 0x3B, 0x12, 0x12, 0x03, - 0x03, 0x32, 0x10, 0x10, 0x00, 0x10, 0x32, 0x10, 0x08, 0x00, 0x08, 0x32, = 0x17, 0x94, 0x07, 0x94, 0x00, 0x00), - _INIT_DCS_CMD(0xD5, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,= 0x18, 0x19, 0x19, 0x40, 0x40, 0x1A, 0x1A, - 0x1B, 0x1B, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x20, 0x21, = 0x28, 0x29, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x1= 8, 0x18, 0x18, 0x18), - _INIT_DCS_CMD(0xD6, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18,= 0x18, 0x40, 0x40, 0x19, 0x19, 0x1A, 0x1A, - 0x1B, 0x1B, 0x07, 0x06, 0x05, 0x04, 0x03, 0x02, 0x01, 0x00, 0x29, 0x28, = 0x21, 0x20, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x1= 8, 0x18, 0x18, 0x18), - _INIT_DCS_CMD(0xD8, 0xAA, 0xBA, 0xEA, 0xAA, 0xAA, 0xA0, 0xAA, 0xBA, 0xEA,= 0xAA, 0xAA, 0xA0, 0xAA, 0xBA, 0xEA, 0xAA, - 0xAA, 0xA0, 0xAA, 0xBA, 0xEA, 0xAA, 0xAA, 0xA0, 0xAA, 0xBA, 0xEA, 0xAA, = 0xAA, 0xA0, 0xAA, 0xBA, 0xEA, 0xAA, 0xAA, 0xA0), - _INIT_DCS_CMD(0xE0, 0x00, 0x09, 0x14, 0x1E, 0x26, 0x48, 0x61, 0x67, 0x6C,= 0x67, 0x7D, 0x7F, 0x80, 0x8B, 0x87, 0x8F, 0x98, 0xAB, - 0xAB, 0x55, 0x5C, 0x68, 0x73, 0x00, 0x09, 0x14, 0x1E, 0x26, 0x48, 0x61, = 0x67, 0x6C, 0x67, 0x7D, 0x7F, 0x80, 0x8B, 0x87, 0x8F, 0x98, 0xAB, 0xAB, 0x5= 5, 0x5C, 0x68, 0x73), - _INIT_DCS_CMD(0xE7, 0x0E, 0x10, 0x10, 0x21, 0x2B, 0x9A, 0x02, 0x54, 0x9A,= 0x14, 0x14, 0x00, 0x00, 0x00, 0x00, 0x12, 0x05, 0x02, 0x02, 0x10), - _INIT_DCS_CMD(0xBD, 0x01), - _INIT_DCS_CMD(0xB1, 0x01, 0xBF, 0x11), - _INIT_DCS_CMD(0xCB, 0x86), - _INIT_DCS_CMD(0xD2, 0x3C, 0xFA), - _INIT_DCS_CMD(0xE9, 0xC5), - _INIT_DCS_CMD(0xD3, 0x00, 0x00, 0x00, 0x00, 0x80, 0x0C, 0x01), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xE7, 0x02, 0x00, 0x28, 0x01, 0x7E, 0x0F, 0x7E, 0x10, 0xA0,= 0x00, 0x00, 0x20, 0x40, 0x50, 0x40), - _INIT_DCS_CMD(0xBD, 0x02), - _INIT_DCS_CMD(0xD8, 0xFF, 0xFF, 0xBF, 0xFE, 0xAA, 0xA0, 0xFF, 0xFF, 0xBF,= 0xFE, 0xAA, 0xA0), - _INIT_DCS_CMD(0xE7, 0xFE, 0x04, 0xFE, 0x04, 0xFE, 0x04, 0x03, 0x03, 0x03,= 0x26, 0x00, 0x26, 0x81, 0x02, 0x40, 0x00, 0x20, 0x9E, 0x04, 0x03, 0x02, 0x= 01, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00), - _INIT_DCS_CMD(0xBD, 0x03), - _INIT_DCS_CMD(0xE9, 0xC6), - _INIT_DCS_CMD(0xB4, 0x03, 0xFF, 0xF8), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xD8, 0x00, 0x2A, 0xAA, 0xA8, 0x00, 0x00, 0x00, 0x2A, 0xAA,= 0xA8, 0x00, 0x00, 0x00, 0x3F, 0xFF, 0xFC, 0x00, 0x00, 0x00, 0x3F, 0xFF, 0x= FC, 0x00, 0x00, 0x00, 0x2A, 0xAA, 0xA8, - 0x00, 0x00, 0x00, 0x2A, 0xAA, 0xA8, 0x00, 0x00), - _INIT_DCS_CMD(0xBD, 0x00), - _INIT_DCS_CMD(0xE9, 0xC4), - _INIT_DCS_CMD(0xBA, 0x96), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xBD, 0x01), - _INIT_DCS_CMD(0xE9, 0xC5), - _INIT_DCS_CMD(0xBA, 0x4F), - _INIT_DCS_CMD(0xE9, 0x3F), - _INIT_DCS_CMD(0xBD, 0x00), - _INIT_DCS_CMD(0x11), - _INIT_DELAY_CMD(120), - _INIT_DCS_CMD(0x29), - {}, -}; + return 0; +} =20 -static const struct panel_init_cmd starry_ili9882t_init_cmd[] =3D { - _INIT_DELAY_CMD(5), - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x01), - _INIT_DCS_CMD(0x00, 0x42), - _INIT_DCS_CMD(0x01, 0x11), - _INIT_DCS_CMD(0x02, 0x00), - _INIT_DCS_CMD(0x03, 0x00), - - _INIT_DCS_CMD(0x04, 0x01), - _INIT_DCS_CMD(0x05, 0x11), - _INIT_DCS_CMD(0x06, 0x00), - _INIT_DCS_CMD(0x07, 0x00), - - _INIT_DCS_CMD(0x08, 0x80), - _INIT_DCS_CMD(0x09, 0x81), - _INIT_DCS_CMD(0x0A, 0x71), - _INIT_DCS_CMD(0x0B, 0x00), - - _INIT_DCS_CMD(0x0C, 0x00), - _INIT_DCS_CMD(0x0E, 0x1A), - - _INIT_DCS_CMD(0x24, 0x00), - _INIT_DCS_CMD(0x25, 0x00), - _INIT_DCS_CMD(0x26, 0x00), - _INIT_DCS_CMD(0x27, 0x00), - - _INIT_DCS_CMD(0x2C, 0xD4), - _INIT_DCS_CMD(0xB9, 0x40), - - _INIT_DCS_CMD(0xB0, 0x11), - - _INIT_DCS_CMD(0xE6, 0x32), - _INIT_DCS_CMD(0xD1, 0x30), - - _INIT_DCS_CMD(0xD6, 0x55), - - _INIT_DCS_CMD(0xD0, 0x01), - _INIT_DCS_CMD(0xE3, 0x93), - _INIT_DCS_CMD(0xE4, 0x00), - _INIT_DCS_CMD(0xE5, 0x80), - - _INIT_DCS_CMD(0x31, 0x07), - _INIT_DCS_CMD(0x32, 0x07), - _INIT_DCS_CMD(0x33, 0x07), - _INIT_DCS_CMD(0x34, 0x07), - _INIT_DCS_CMD(0x35, 0x07), - _INIT_DCS_CMD(0x36, 0x01), - _INIT_DCS_CMD(0x37, 0x00), - _INIT_DCS_CMD(0x38, 0x28), - _INIT_DCS_CMD(0x39, 0x29), - _INIT_DCS_CMD(0x3A, 0x11), - _INIT_DCS_CMD(0x3B, 0x13), - _INIT_DCS_CMD(0x3C, 0x15), - _INIT_DCS_CMD(0x3D, 0x17), - _INIT_DCS_CMD(0x3E, 0x09), - _INIT_DCS_CMD(0x3F, 0x0D), - _INIT_DCS_CMD(0x40, 0x02), - _INIT_DCS_CMD(0x41, 0x02), - _INIT_DCS_CMD(0x42, 0x02), - _INIT_DCS_CMD(0x43, 0x02), - _INIT_DCS_CMD(0x44, 0x02), - _INIT_DCS_CMD(0x45, 0x02), - _INIT_DCS_CMD(0x46, 0x02), - - _INIT_DCS_CMD(0x47, 0x07), - _INIT_DCS_CMD(0x48, 0x07), - _INIT_DCS_CMD(0x49, 0x07), - _INIT_DCS_CMD(0x4A, 0x07), - _INIT_DCS_CMD(0x4B, 0x07), - _INIT_DCS_CMD(0x4C, 0x01), - _INIT_DCS_CMD(0x4D, 0x00), - _INIT_DCS_CMD(0x4E, 0x28), - _INIT_DCS_CMD(0x4F, 0x29), - _INIT_DCS_CMD(0x50, 0x10), - _INIT_DCS_CMD(0x51, 0x12), - _INIT_DCS_CMD(0x52, 0x14), - _INIT_DCS_CMD(0x53, 0x16), - _INIT_DCS_CMD(0x54, 0x08), - _INIT_DCS_CMD(0x55, 0x0C), - _INIT_DCS_CMD(0x56, 0x02), - _INIT_DCS_CMD(0x57, 0x02), - _INIT_DCS_CMD(0x58, 0x02), - _INIT_DCS_CMD(0x59, 0x02), - _INIT_DCS_CMD(0x5A, 0x02), - _INIT_DCS_CMD(0x5B, 0x02), - _INIT_DCS_CMD(0x5C, 0x02), - - _INIT_DCS_CMD(0x61, 0x07), - _INIT_DCS_CMD(0x62, 0x07), - _INIT_DCS_CMD(0x63, 0x07), - _INIT_DCS_CMD(0x64, 0x07), - _INIT_DCS_CMD(0x65, 0x07), - _INIT_DCS_CMD(0x66, 0x01), - _INIT_DCS_CMD(0x67, 0x00), - _INIT_DCS_CMD(0x68, 0x28), - _INIT_DCS_CMD(0x69, 0x29), - _INIT_DCS_CMD(0x6A, 0x16), - _INIT_DCS_CMD(0x6B, 0x14), - _INIT_DCS_CMD(0x6C, 0x12), - _INIT_DCS_CMD(0x6D, 0x10), - _INIT_DCS_CMD(0x6E, 0x0C), - _INIT_DCS_CMD(0x6F, 0x08), - _INIT_DCS_CMD(0x70, 0x02), - _INIT_DCS_CMD(0x71, 0x02), - _INIT_DCS_CMD(0x72, 0x02), - _INIT_DCS_CMD(0x73, 0x02), - _INIT_DCS_CMD(0x74, 0x02), - _INIT_DCS_CMD(0x75, 0x02), - _INIT_DCS_CMD(0x76, 0x02), - - _INIT_DCS_CMD(0x77, 0x07), - _INIT_DCS_CMD(0x78, 0x07), - _INIT_DCS_CMD(0x79, 0x07), - _INIT_DCS_CMD(0x7A, 0x07), - _INIT_DCS_CMD(0x7B, 0x07), - _INIT_DCS_CMD(0x7C, 0x01), - _INIT_DCS_CMD(0x7D, 0x00), - _INIT_DCS_CMD(0x7E, 0x28), - _INIT_DCS_CMD(0x7F, 0x29), - _INIT_DCS_CMD(0x80, 0x17), - _INIT_DCS_CMD(0x81, 0x15), - _INIT_DCS_CMD(0x82, 0x13), - _INIT_DCS_CMD(0x83, 0x11), - _INIT_DCS_CMD(0x84, 0x0D), - _INIT_DCS_CMD(0x85, 0x09), - _INIT_DCS_CMD(0x86, 0x02), - _INIT_DCS_CMD(0x87, 0x07), - _INIT_DCS_CMD(0x88, 0x07), - _INIT_DCS_CMD(0x89, 0x07), - _INIT_DCS_CMD(0x8A, 0x07), - _INIT_DCS_CMD(0x8B, 0x07), - _INIT_DCS_CMD(0x8C, 0x07), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x02), - _INIT_DCS_CMD(0x29, 0x3A), - _INIT_DCS_CMD(0x2A, 0x3B), - - _INIT_DCS_CMD(0x06, 0x01), - _INIT_DCS_CMD(0x07, 0x01), - _INIT_DCS_CMD(0x08, 0x0C), - _INIT_DCS_CMD(0x09, 0x44), - - _INIT_DCS_CMD(0x3C, 0x0A), - _INIT_DCS_CMD(0x39, 0x11), - _INIT_DCS_CMD(0x3D, 0x00), - _INIT_DCS_CMD(0x3A, 0x0C), - _INIT_DCS_CMD(0x3B, 0x44), - - _INIT_DCS_CMD(0x53, 0x1F), - _INIT_DCS_CMD(0x5E, 0x40), - _INIT_DCS_CMD(0x84, 0x00), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x03), - _INIT_DCS_CMD(0x20, 0x01), - _INIT_DCS_CMD(0x21, 0x3C), - _INIT_DCS_CMD(0x22, 0xFA), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x0A), - _INIT_DCS_CMD(0xE0, 0x01), - _INIT_DCS_CMD(0xE2, 0x01), - _INIT_DCS_CMD(0xE5, 0x91), - _INIT_DCS_CMD(0xE6, 0x3C), - _INIT_DCS_CMD(0xE7, 0x00), - _INIT_DCS_CMD(0xE8, 0xFA), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x12), - _INIT_DCS_CMD(0x87, 0x2C), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x05), - _INIT_DCS_CMD(0x73, 0xE5), - _INIT_DCS_CMD(0x7F, 0x6B), - _INIT_DCS_CMD(0x6D, 0xA4), - _INIT_DCS_CMD(0x79, 0x54), - _INIT_DCS_CMD(0x69, 0x97), - _INIT_DCS_CMD(0x6A, 0x97), - _INIT_DCS_CMD(0xA5, 0x3F), - _INIT_DCS_CMD(0x61, 0xDA), - _INIT_DCS_CMD(0xA7, 0xF1), - _INIT_DCS_CMD(0x5F, 0x01), - _INIT_DCS_CMD(0x62, 0x3F), - _INIT_DCS_CMD(0x1D, 0x90), - _INIT_DCS_CMD(0x86, 0x87), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x06), - _INIT_DCS_CMD(0xC0, 0x80), - _INIT_DCS_CMD(0xC1, 0x07), - _INIT_DCS_CMD(0xCA, 0x58), - _INIT_DCS_CMD(0xCB, 0x02), - _INIT_DCS_CMD(0xCE, 0x58), - _INIT_DCS_CMD(0xCF, 0x02), - _INIT_DCS_CMD(0x67, 0x60), - _INIT_DCS_CMD(0x10, 0x00), - _INIT_DCS_CMD(0x92, 0x22), - _INIT_DCS_CMD(0xD3, 0x08), - _INIT_DCS_CMD(0xD6, 0x55), - _INIT_DCS_CMD(0xDC, 0x38), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x08), - _INIT_DCS_CMD(0xE0, 0x00, 0x10, 0x2A, 0x4D, 0x61, 0x56, 0x6A, 0x6E, 0x79,= 0x76, 0x8F, 0x95, 0x98, 0xAE, 0xAA, 0xB2, 0xBB, 0xCE, 0xC6, 0xBD, 0xD5, 0x= E2, 0xE8), - _INIT_DCS_CMD(0xE1, 0x00, 0x10, 0x2A, 0x4D, 0x61, 0x56, 0x6A, 0x6E, 0x79,= 0x76, 0x8F, 0x95, 0x98, 0xAE, 0xAA, 0xB2, 0xBB, 0xCE, 0xC6, 0xBD, 0xD5, 0x= E2, 0xE8), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x04), - _INIT_DCS_CMD(0xBA, 0x81), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x0C), - _INIT_DCS_CMD(0x00, 0x02), - _INIT_DCS_CMD(0x01, 0x00), - _INIT_DCS_CMD(0x02, 0x03), - _INIT_DCS_CMD(0x03, 0x01), - _INIT_DCS_CMD(0x04, 0x03), - _INIT_DCS_CMD(0x05, 0x02), - _INIT_DCS_CMD(0x06, 0x04), - _INIT_DCS_CMD(0x07, 0x03), - _INIT_DCS_CMD(0x08, 0x03), - _INIT_DCS_CMD(0x09, 0x04), - _INIT_DCS_CMD(0x0A, 0x04), - _INIT_DCS_CMD(0x0B, 0x05), - _INIT_DCS_CMD(0x0C, 0x04), - _INIT_DCS_CMD(0x0D, 0x06), - _INIT_DCS_CMD(0x0E, 0x05), - _INIT_DCS_CMD(0x0F, 0x07), - _INIT_DCS_CMD(0x10, 0x04), - _INIT_DCS_CMD(0x11, 0x08), - _INIT_DCS_CMD(0x12, 0x05), - _INIT_DCS_CMD(0x13, 0x09), - _INIT_DCS_CMD(0x14, 0x05), - _INIT_DCS_CMD(0x15, 0x0A), - _INIT_DCS_CMD(0x16, 0x06), - _INIT_DCS_CMD(0x17, 0x0B), - _INIT_DCS_CMD(0x18, 0x05), - _INIT_DCS_CMD(0x19, 0x0C), - _INIT_DCS_CMD(0x1A, 0x06), - _INIT_DCS_CMD(0x1B, 0x0D), - _INIT_DCS_CMD(0x1C, 0x06), - _INIT_DCS_CMD(0x1D, 0x0E), - _INIT_DCS_CMD(0x1E, 0x07), - _INIT_DCS_CMD(0x1F, 0x0F), - _INIT_DCS_CMD(0x20, 0x06), - _INIT_DCS_CMD(0x21, 0x10), - _INIT_DCS_CMD(0x22, 0x07), - _INIT_DCS_CMD(0x23, 0x11), - _INIT_DCS_CMD(0x24, 0x07), - _INIT_DCS_CMD(0x25, 0x12), - _INIT_DCS_CMD(0x26, 0x08), - _INIT_DCS_CMD(0x27, 0x13), - _INIT_DCS_CMD(0x28, 0x07), - _INIT_DCS_CMD(0x29, 0x14), - _INIT_DCS_CMD(0x2A, 0x08), - _INIT_DCS_CMD(0x2B, 0x15), - _INIT_DCS_CMD(0x2C, 0x08), - _INIT_DCS_CMD(0x2D, 0x16), - _INIT_DCS_CMD(0x2E, 0x09), - _INIT_DCS_CMD(0x2F, 0x17), - _INIT_DCS_CMD(0x30, 0x08), - _INIT_DCS_CMD(0x31, 0x18), - _INIT_DCS_CMD(0x32, 0x09), - _INIT_DCS_CMD(0x33, 0x19), - _INIT_DCS_CMD(0x34, 0x09), - _INIT_DCS_CMD(0x35, 0x1A), - _INIT_DCS_CMD(0x36, 0x0A), - _INIT_DCS_CMD(0x37, 0x1B), - _INIT_DCS_CMD(0x38, 0x0A), - _INIT_DCS_CMD(0x39, 0x1C), - _INIT_DCS_CMD(0x3A, 0x0A), - _INIT_DCS_CMD(0x3B, 0x1D), - _INIT_DCS_CMD(0x3C, 0x0A), - _INIT_DCS_CMD(0x3D, 0x1E), - _INIT_DCS_CMD(0x3E, 0x0A), - _INIT_DCS_CMD(0x3F, 0x1F), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x04), - _INIT_DCS_CMD(0xBA, 0x01), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x0E), - _INIT_DCS_CMD(0x02, 0x0C), - _INIT_DCS_CMD(0x20, 0x10), - _INIT_DCS_CMD(0x25, 0x16), - _INIT_DCS_CMD(0x26, 0xE0), - _INIT_DCS_CMD(0x27, 0x00), - _INIT_DCS_CMD(0x29, 0x71), - _INIT_DCS_CMD(0x2A, 0x46), - _INIT_DCS_CMD(0x2B, 0x1F), - _INIT_DCS_CMD(0x2D, 0xC7), - _INIT_DCS_CMD(0x31, 0x02), - _INIT_DCS_CMD(0x32, 0xDF), - _INIT_DCS_CMD(0x33, 0x5A), - _INIT_DCS_CMD(0x34, 0xC0), - _INIT_DCS_CMD(0x35, 0x5A), - _INIT_DCS_CMD(0x36, 0xC0), - _INIT_DCS_CMD(0x38, 0x65), - _INIT_DCS_CMD(0x80, 0x3E), - _INIT_DCS_CMD(0x81, 0xA0), - _INIT_DCS_CMD(0xB0, 0x01), - _INIT_DCS_CMD(0xB1, 0xCC), - _INIT_DCS_CMD(0xC0, 0x12), - _INIT_DCS_CMD(0xC2, 0xCC), - _INIT_DCS_CMD(0xC3, 0xCC), - _INIT_DCS_CMD(0xC4, 0xCC), - _INIT_DCS_CMD(0xC5, 0xCC), - _INIT_DCS_CMD(0xC6, 0xCC), - _INIT_DCS_CMD(0xC7, 0xCC), - _INIT_DCS_CMD(0xC8, 0xCC), - _INIT_DCS_CMD(0xC9, 0xCC), - _INIT_DCS_CMD(0x30, 0x00), - _INIT_DCS_CMD(0x00, 0x81), - _INIT_DCS_CMD(0x08, 0x02), - _INIT_DCS_CMD(0x09, 0x00), - _INIT_DCS_CMD(0x07, 0x21), - _INIT_DCS_CMD(0x04, 0x10), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x1E), - _INIT_DCS_CMD(0x60, 0x00), - _INIT_DCS_CMD(0x64, 0x00), - _INIT_DCS_CMD(0x6D, 0x00), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x0B), - _INIT_DCS_CMD(0xA6, 0x44), - _INIT_DCS_CMD(0xA7, 0xB6), - _INIT_DCS_CMD(0xA8, 0x03), - _INIT_DCS_CMD(0xA9, 0x03), - _INIT_DCS_CMD(0xAA, 0x51), - _INIT_DCS_CMD(0xAB, 0x51), - _INIT_DCS_CMD(0xAC, 0x04), - _INIT_DCS_CMD(0xBD, 0x92), - _INIT_DCS_CMD(0xBE, 0xA1), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x05), - _INIT_DCS_CMD(0x86, 0x87), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x06), - _INIT_DCS_CMD(0x92, 0x22), - - _INIT_DCS_CMD(0xFF, 0x98, 0x82, 0x00), - _INIT_DCS_CMD(0x11), - _INIT_DELAY_CMD(120), - _INIT_DCS_CMD(0x29), - _INIT_DELAY_CMD(20), - {}, -}; +static int auo_kd101n80_45na_init(struct mipi_dsi_device *dsi) +{ + int ret; =20 -static inline struct boe_panel *to_boe_panel(struct drm_panel *panel) + msleep(24); + ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret =3D mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(120); + + return 0; +} + +static int auo_b101uan08_3_init(struct mipi_dsi_device *dsi) { - return container_of(panel, struct boe_panel, base); + msleep(24); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x47); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x47); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0x45); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0x45); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x64); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x64); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xD1, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x41); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x41); + mipi_dsi_dcs_write_seq(dsi, 0xD4, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x47); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x47); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xD9, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xDA, 0x45); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x45); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x64); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x64); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xDF, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0xE3, 0x66); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x41); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x41); + msleep(150); + + return 0; } =20 -static int boe_panel_init_dcs_cmd(struct boe_panel *boe) +static int starry_qfh032011_53g_init(struct mipi_dsi_device *dsi) { - struct mipi_dsi_device *dsi =3D boe->dsi; - struct drm_panel *panel =3D &boe->base; - int i, err =3D 0; - - if (boe->desc->init_cmds) { - const struct panel_init_cmd *init_cmds =3D boe->desc->init_cmds; - - for (i =3D 0; init_cmds[i].len !=3D 0; i++) { - const struct panel_init_cmd *cmd =3D &init_cmds[i]; - - switch (cmd->type) { - case DELAY_CMD: - msleep(cmd->data[0]); - err =3D 0; - break; - - case INIT_DCS_CMD: - err =3D mipi_dsi_dcs_write(dsi, cmd->data[0], - cmd->len <=3D 1 ? NULL : - &cmd->data[1], - cmd->len - 1); - break; - - default: - err =3D -EINVAL; - } - - if (err < 0) { - dev_err(panel->dev, - "failed to write command %u\n", i); - return err; - } - } - } + int ret; + + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x4D); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x52); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x51); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0x5D); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0x5B); + mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x4B); + mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x49); + mipi_dsi_dcs_write_seq(dsi, 0xD1, 0x47); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x45); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x41); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x50); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xD9, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xDA, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x4E); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x52); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x51); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x5E); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x5C); + mipi_dsi_dcs_write_seq(dsi, 0xE3, 0x4C); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0x4A); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x48); + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x42); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x42); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0x3E); + mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xD4, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xD9, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0xF0); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0x24); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x19); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0xCD, 0x1E); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xD1, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xD4, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0xD7, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xD9, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0xDA, 0x19); + mipi_dsi_dcs_write_seq(dsi, 0xDB, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0xDD, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0xDE, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0xDF, 0x1E); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x23); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x07); + + ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret =3D mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(80); + return 0; } =20 + +static int starry_himax83102_j02_init(struct mipi_dsi_device *dsi) +{ + int ret; + + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x83, 0x10, 0x21, 0x55, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x2C, 0xB5, 0xB5, 0x31, 0xF1, 0x31, 0xD= 7, 0x2F, 0x36, 0x36, + 0x36, 0x36, 0x1A, 0x8B, 0x11, 0x65, 0x00, 0x88, 0xFA, 0xFF, 0xFF= , 0x8F, + 0xFF, 0x08, 0x74, 0x33); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x00, 0x47, 0xB0, 0x80, 0x00, 0x12, 0x7= 2, 0x3C, 0xA3, 0x03, + 0x03, 0x00, 0x00, 0x88, 0xF5); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x76, 0x76, 0x76, 0x76, 0x76, 0x76, 0x6= 3, 0x5C, 0x63, 0x5C, + 0x01, 0x9E); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xCD); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x84); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xBC, 0x1B, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0x20); + mipi_dsi_dcs_write_seq(dsi, 0xBF, 0xFC, 0xC4); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x36, 0x36, 0x22, 0x11, 0x22, 0xA0, 0x6= 1, 0x08, 0xF5, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xC6); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0x00, 0x1E, 0x13, 0x88, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x08, 0x13, 0x07, 0x00, 0x0F, 0x33); + mipi_dsi_dcs_write_seq(dsi, 0xCC, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xC4); + mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xD1, 0x37, 0x06, 0x00, 0x02, 0x04, 0x0C, 0xF= F); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x1F, 0x11, 0x1F); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x06, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0= 8, 0x00, 0x08, + 0x37, 0x47, 0x34, 0x3B, 0x12, 0x12, 0x03, 0x03, 0x32, 0x10, 0x10, + 0x00, 0x10, 0x32, 0x10, 0x08, 0x00, 0x08, 0x32, 0x17, 0x94, 0x07, + 0x94, 0x00, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xD5, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x1= 8, 0x18, 0x18, + 0x18, 0x19, 0x19, 0x40, 0x40, 0x1A, 0x1A, 0x1B, 0x1B, 0x00, 0x01, + 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x20, 0x21, 0x28, 0x29, 0x18, + 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, + 0x18, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x1= 8, 0x18, 0x18, + 0x18, 0x40, 0x40, 0x19, 0x19, 0x1A, 0x1A, 0x1B, 0x1B, 0x07, 0x06, + 0x05, 0x04, 0x03, 0x02, 0x01, 0x00, 0x29, 0x28, 0x21, 0x20, 0x18, + 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, + 0x18, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0xAA, 0xBA, 0xEA, 0xAA, 0xAA, 0xA0, 0xA= A, 0xBA, 0xEA, + 0xAA, 0xAA, 0xA0, 0xAA, 0xBA, 0xEA, 0xAA, 0xAA, 0xA0, 0xAA, 0xBA, + 0xEA, 0xAA, 0xAA, 0xA0, 0xAA, 0xBA, 0xEA, 0xAA, 0xAA, 0xA0, 0xAA, + 0xBA, 0xEA, 0xAA, 0xAA, 0xA0); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x00, 0x09, 0x14, 0x1E, 0x26, 0x48, 0x6= 1, 0x67, 0x6C, + 0x67, 0x7D, 0x7F, 0x80, 0x8B, 0x87, 0x8F, 0x98, 0xAB, 0xAB, 0x55, + 0x5C, 0x68, 0x73, 0x00, 0x09, 0x14, 0x1E, 0x26, 0x48, 0x61, 0x67, + 0x6C, 0x67, 0x7D, 0x7F, 0x80, 0x8B, 0x87, 0x8F, 0x98, 0xAB, 0xAB, + 0x55, 0x5C, 0x68, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x0E, 0x10, 0x10, 0x21, 0x2B, 0x9A, 0x0= 2, 0x54, 0x9A, + 0x14, 0x14, 0x00, 0x00, 0x00, 0x00, 0x12, 0x05, 0x02, 0x02, 0x10= ); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x01, 0xBF, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x86); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x3C, 0xFA); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xC5); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x00, 0x00, 0x00, 0x00, 0x80, 0x0C, 0x0= 1); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x02, 0x00, 0x28, 0x01, 0x7E, 0x0F, 0x7= E, 0x10, 0xA0, + 0x00, 0x00, 0x20, 0x40, 0x50, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0xFF, 0xFF, 0xBF, 0xFE, 0xAA, 0xA0, 0xF= F, 0xFF, 0xBF, + 0xFE, 0xAA, 0xA0); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0xFE, 0x04, 0xFE, 0x04, 0xFE, 0x04, 0x0= 3, 0x03, 0x03, + 0x26, 0x00, 0x26, 0x81, 0x02, 0x40, 0x00, 0x20, 0x9E, 0x04, 0x03, + 0x02, 0x01, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xC6); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x03, 0xFF, 0xF8); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xD8, 0x00, 0x2A, 0xAA, 0xA8, 0x00, 0x00, 0x0= 0, 0x2A, 0xAA, + 0xA8, 0x00, 0x00, 0x00, 0x3F, 0xFF, 0xFC, 0x00, 0x00, 0x00, 0x3F, + 0xFF, 0xFC, 0x00, 0x00, 0x00, 0x2A, 0xAA, 0xA8, 0x00, 0x00, 0x00, + 0x2A, 0xAA, 0xA8, 0x00, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xC4); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x96); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0xC5); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x4F); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x00); + + + ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret =3D mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(80); + + return 0; +}; + + +static int starry_ili9882t_init(struct mipi_dsi_device *dsi) +{ + int ret; + + msleep(5); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x42); + mipi_dsi_dcs_write_seq(dsi, 0x01, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x03, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0x81); + mipi_dsi_dcs_write_seq(dsi, 0x0A, 0x71); + mipi_dsi_dcs_write_seq(dsi, 0x0B, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x1A); + + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0x2C, 0xD4); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x40); + + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x11); + + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x32); + mipi_dsi_dcs_write_seq(dsi, 0xD1, 0x30); + + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x55); + + mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE3, 0x93); + mipi_dsi_dcs_write_seq(dsi, 0xE4, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x80); + + mipi_dsi_dcs_write_seq(dsi, 0x31, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x32, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x36, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x37, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x38, 0x28); + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x3C, 0x15); + mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0x3E, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0x3F, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x40, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x41, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x42, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x43, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x44, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x45, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x46, 0x02); + + mipi_dsi_dcs_write_seq(dsi, 0x47, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x48, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x49, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x4A, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x4B, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x4C, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x4D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x4E, 0x28); + mipi_dsi_dcs_write_seq(dsi, 0x4F, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0x50, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x51, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x52, 0x14); + mipi_dsi_dcs_write_seq(dsi, 0x53, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x54, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x55, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x56, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x57, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x58, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x59, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x5A, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x02); + + mipi_dsi_dcs_write_seq(dsi, 0x61, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x62, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x63, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x64, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x65, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x66, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x67, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x68, 0x28); + mipi_dsi_dcs_write_seq(dsi, 0x69, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0x6A, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x6B, 0x14); + mipi_dsi_dcs_write_seq(dsi, 0x6C, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x6D, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x6E, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x6F, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x70, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x71, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x72, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x73, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x74, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x75, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x76, 0x02); + + mipi_dsi_dcs_write_seq(dsi, 0x77, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x78, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x79, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x7A, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x7B, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x7C, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x7D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x7E, 0x28); + mipi_dsi_dcs_write_seq(dsi, 0x7F, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0x80, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0x81, 0x15); + mipi_dsi_dcs_write_seq(dsi, 0x82, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x83, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x84, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x85, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0x86, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x87, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x88, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x89, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x8A, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x8B, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x8C, 0x07); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x3A); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x3B); + + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0x44); + + mipi_dsi_dcs_write_seq(dsi, 0x3C, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x44); + + mipi_dsi_dcs_write_seq(dsi, 0x53, 0x1F); + mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x40); + mipi_dsi_dcs_write_seq(dsi, 0x84, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x21, 0x3C); + mipi_dsi_dcs_write_seq(dsi, 0x22, 0xFA); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x91); + mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x3C); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0xE8, 0xFA); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x87, 0x2C); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x73, 0xE5); + mipi_dsi_dcs_write_seq(dsi, 0x7F, 0x6B); + mipi_dsi_dcs_write_seq(dsi, 0x6D, 0xA4); + mipi_dsi_dcs_write_seq(dsi, 0x79, 0x54); + mipi_dsi_dcs_write_seq(dsi, 0x69, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0x6A, 0x97); + mipi_dsi_dcs_write_seq(dsi, 0xA5, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0x61, 0xDA); + mipi_dsi_dcs_write_seq(dsi, 0xA7, 0xF1); + mipi_dsi_dcs_write_seq(dsi, 0x5F, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x62, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x90); + mipi_dsi_dcs_write_seq(dsi, 0x86, 0x87); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x80); + mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x58); + mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0xCE, 0x58); + mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x67, 0x60); + mipi_dsi_dcs_write_seq(dsi, 0x10, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x92, 0x22); + mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x55); + mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x38); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x00, 0x10, 0x2A, 0x4D, 0x61, 0x56, 0x6= A, 0x6E, 0x79, + 0x76, 0x8F, 0x95, 0x98, 0xAE, 0xAA, 0xB2, 0xBB, 0xCE, 0xC6, 0xBD, + 0xD5, 0xE2, 0xE8); + mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x00, 0x10, 0x2A, 0x4D, 0x61, 0x56, 0x6= A, 0x6E, 0x79, + 0x76, 0x8F, 0x95, 0x98, 0xAE, 0xAA, 0xB2, 0xBB, 0xCE, 0xC6, 0xBD, + 0xD5, 0xE2, 0xE8); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x81); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x01, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x03, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x05, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x06, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x0A, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x0B, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x10, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0x11, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x12, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x13, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0x14, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x15, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x16, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x17, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0x18, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x19, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x1A, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x1B, 0x0D); + mipi_dsi_dcs_write_seq(dsi, 0x1C, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x0E); + mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x0F); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x21, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x22, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x23, 0x11); + mipi_dsi_dcs_write_seq(dsi, 0x24, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x13); + mipi_dsi_dcs_write_seq(dsi, 0x28, 0x07); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x14); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x15); + mipi_dsi_dcs_write_seq(dsi, 0x2C, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x2D, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x2E, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x17); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x08); + mipi_dsi_dcs_write_seq(dsi, 0x31, 0x18); + mipi_dsi_dcs_write_seq(dsi, 0x32, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x19); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0x09); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x1A); + mipi_dsi_dcs_write_seq(dsi, 0x36, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x37, 0x1B); + mipi_dsi_dcs_write_seq(dsi, 0x38, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x39, 0x1C); + mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x1D); + mipi_dsi_dcs_write_seq(dsi, 0x3C, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x1E); + mipi_dsi_dcs_write_seq(dsi, 0x3E, 0x0A); + mipi_dsi_dcs_write_seq(dsi, 0x3F, 0x1F); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x01); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0E); + mipi_dsi_dcs_write_seq(dsi, 0x02, 0x0C); + mipi_dsi_dcs_write_seq(dsi, 0x20, 0x10); + mipi_dsi_dcs_write_seq(dsi, 0x25, 0x16); + mipi_dsi_dcs_write_seq(dsi, 0x26, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0x27, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x29, 0x71); + mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x46); + mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x1F); + mipi_dsi_dcs_write_seq(dsi, 0x2D, 0xC7); + mipi_dsi_dcs_write_seq(dsi, 0x31, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x32, 0xDF); + mipi_dsi_dcs_write_seq(dsi, 0x33, 0x5A); + mipi_dsi_dcs_write_seq(dsi, 0x34, 0xC0); + mipi_dsi_dcs_write_seq(dsi, 0x35, 0x5A); + mipi_dsi_dcs_write_seq(dsi, 0x36, 0xC0); + mipi_dsi_dcs_write_seq(dsi, 0x38, 0x65); + mipi_dsi_dcs_write_seq(dsi, 0x80, 0x3E); + mipi_dsi_dcs_write_seq(dsi, 0x81, 0xA0); + mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x12); + mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0xC9, 0xCC); + mipi_dsi_dcs_write_seq(dsi, 0x30, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x00, 0x81); + mipi_dsi_dcs_write_seq(dsi, 0x08, 0x02); + mipi_dsi_dcs_write_seq(dsi, 0x09, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x07, 0x21); + mipi_dsi_dcs_write_seq(dsi, 0x04, 0x10); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x1E); + mipi_dsi_dcs_write_seq(dsi, 0x60, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x64, 0x00); + mipi_dsi_dcs_write_seq(dsi, 0x6D, 0x00); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0B); + mipi_dsi_dcs_write_seq(dsi, 0xA6, 0x44); + mipi_dsi_dcs_write_seq(dsi, 0xA7, 0xB6); + mipi_dsi_dcs_write_seq(dsi, 0xA8, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xA9, 0x03); + mipi_dsi_dcs_write_seq(dsi, 0xAA, 0x51); + mipi_dsi_dcs_write_seq(dsi, 0xAB, 0x51); + mipi_dsi_dcs_write_seq(dsi, 0xAC, 0x04); + mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x92); + mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xA1); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x05); + mipi_dsi_dcs_write_seq(dsi, 0x86, 0x87); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x06); + mipi_dsi_dcs_write_seq(dsi, 0x92, 0x22); + + mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x00); + + ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret =3D mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(20); + + return 0; +}; + +static inline struct boe_panel *to_boe_panel(struct drm_panel *panel) +{ + return container_of(panel, struct boe_panel, base); +} + static int boe_panel_enter_sleep_mode(struct boe_panel *boe) { struct mipi_dsi_device *dsi =3D boe->dsi; @@ -1860,10 +1815,12 @@ static int boe_panel_prepare(struct drm_panel *pane= l) gpiod_set_value(boe->enable_gpio, 1); usleep_range(6000, 10000); =20 - ret =3D boe_panel_init_dcs_cmd(boe); - if (ret < 0) { - dev_err(panel->dev, "failed to init panel: %d\n", ret); - goto poweroff; + if (boe->desc->init) { + ret =3D boe->desc->init(boe->dsi); + if (ret < 0) { + dev_err(panel->dev, "failed to init panel: %d\n", ret); + goto poweroff; + } } =20 boe->prepared =3D true; @@ -1914,7 +1871,7 @@ static const struct panel_desc boe_tv110c9m_desc =3D { | MIPI_DSI_MODE_VIDEO_HSE | MIPI_DSI_CLOCK_NON_CONTINUOUS | MIPI_DSI_MODE_VIDEO_BURST, - .init_cmds =3D boe_tv110c9m_init_cmd, + .init =3D boe_tv110c9m_init, }; =20 static const struct drm_display_mode inx_hj110iz_default_mode =3D { @@ -1943,7 +1900,7 @@ static const struct panel_desc inx_hj110iz_desc =3D { | MIPI_DSI_MODE_VIDEO_HSE | MIPI_DSI_CLOCK_NON_CONTINUOUS | MIPI_DSI_MODE_VIDEO_BURST, - .init_cmds =3D inx_hj110iz_init_cmd, + .init =3D inx_hj110iz_init, }; =20 static const struct drm_display_mode boe_tv101wum_nl6_default_mode =3D { @@ -1969,7 +1926,7 @@ static const struct panel_desc boe_tv101wum_nl6_desc = =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D boe_init_cmd, + .init =3D boe_init, .discharge_on_disable =3D false, }; =20 @@ -1996,7 +1953,7 @@ static const struct panel_desc auo_kd101n80_45na_desc= =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D auo_kd101n80_45na_init_cmd, + .init =3D auo_kd101n80_45na_init, .discharge_on_disable =3D true, }; =20 @@ -2024,7 +1981,7 @@ static const struct panel_desc boe_tv101wum_n53_desc = =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D boe_init_cmd, + .init =3D boe_init, }; =20 static const struct drm_display_mode auo_b101uan08_3_default_mode =3D { @@ -2051,7 +2008,7 @@ static const struct panel_desc auo_b101uan08_3_desc = =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D auo_b101uan08_3_init_cmd, + .init =3D auo_b101uan08_3_init, }; =20 static const struct drm_display_mode boe_tv105wum_nw0_default_mode =3D { @@ -2078,7 +2035,7 @@ static const struct panel_desc boe_tv105wum_nw0_desc = =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D boe_init_cmd, + .init =3D boe_init, .lp11_before_reset =3D true, }; =20 @@ -2105,7 +2062,7 @@ static const struct panel_desc starry_qfh032011_53g_d= esc =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D starry_qfh032011_53g_init_cmd, + .init =3D starry_qfh032011_53g_init, }; =20 static const struct drm_display_mode starry_himax83102_j02_default_mode = =3D { @@ -2132,7 +2089,7 @@ static const struct panel_desc starry_himax83102_j02_= desc =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D starry_himax83102_j02_init_cmd, + .init =3D starry_himax83102_j02_init, .lp11_before_reset =3D true, }; =20 @@ -2160,7 +2117,7 @@ static const struct panel_desc starry_ili9882t_desc = =3D { .format =3D MIPI_DSI_FMT_RGB888, .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds =3D starry_ili9882t_init_cmd, + .init =3D starry_ili9882t_init, .lp11_before_reset =3D true, }; =20 --=20 2.34.1 From nobody Mon Feb 9 20:50:48 2026 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 B32A1EB64DC for ; Mon, 3 Jul 2023 13:22:08 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231438AbjGCNWH (ORCPT ); Mon, 3 Jul 2023 09:22:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45898 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229454AbjGCNWA (ORCPT ); Mon, 3 Jul 2023 09:22:00 -0400 Received: from mail-lj1-x229.google.com (mail-lj1-x229.google.com [IPv6:2a00:1450:4864:20::229]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 58C1DE3 for ; Mon, 3 Jul 2023 06:21:59 -0700 (PDT) Received: by mail-lj1-x229.google.com with SMTP id 38308e7fff4ca-2b6994a8ce3so65305441fa.1 for ; Mon, 03 Jul 2023 06:21:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1688390517; x=1690982517; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=Dmkv6C+3q0OhDNXDylTCb+3rSuoihy22b5khGTWPfYY=; b=x56IXe8RIxnYL1+6pw4NtYfv1qktWK03Hq4LtRYerU8753MlMMPlbfiYQu112xui2F Yat4bSpDBts7bX0CwkfuEbJTpa2E8QqxQrFYOdq43hC913JaII1dpWGPB+y+9exS0KoC XeLezG/yqBg/w1SzEhw69RYK7Az1UoFjzGVJkiyp669P2tn5iX99KvLDYM7vIECcswcP duATm8LgyLut7Yp1B9HJOb+yGUo24OVNgeLnh/U8b9CkRzmv4XLrjS7nacIM9fGBtOd1 PJdMHZg87m4VXTNWl5bNYOijkYnVOikgDKxRSofwGAwPyrjV2UyA5ZZ83VJRwLKPNdVG qyIw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688390517; x=1690982517; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=Dmkv6C+3q0OhDNXDylTCb+3rSuoihy22b5khGTWPfYY=; b=YXjh98d0dX3qqrcRBltWOfPW8kIHUYXDmMSttdXhBZHFOFqN1WRWIiu5acR1A4cz6f FPEz4nVTEOqXoLJrQM4PU1uKQRif8kzxvScpu8cDwBt18lK+qDtfbv6QkTYdYaFtlp4A tP3zcMgZ05okUxeZU4968TMDNu6YERUJ8dL9aESgtCrp24xqOkxiADFZ8YMNbHZ0IyQS KIVVSmeM871kYhWRDS2GkpvFBPtbjG5aGvDrd35hoOIb6m/5706zm4EpmrOhPjdt/iyq N1eAy4MNzKGPHsMgHAlg6lrIm7BRXp/z8TeF47GeSqiIfvBPSb0gshatoQ612PqEQ/vF +ySQ== X-Gm-Message-State: ABy/qLa5M+bYVb/l7GV0iEgVCcRGWpa/0d28UwLMkBLB9zbaDxAO7y2C RBE3GQJ9IeiGNmhPmsuJT9cZsw== X-Google-Smtp-Source: APBJJlEJ9liFnDdgt5zlbz3HnNnpx+fVn7iFxhT8RwbTd+Zf3sz9814lDIWRJDoGqZPUxu6XwYc2gQ== X-Received: by 2002:a2e:9f4d:0:b0:2b6:bd09:4d64 with SMTP id v13-20020a2e9f4d000000b002b6bd094d64mr6888676ljk.34.1688390517732; Mon, 03 Jul 2023 06:21:57 -0700 (PDT) Received: from [127.0.1.1] ([85.235.12.238]) by smtp.gmail.com with ESMTPSA id u10-20020a2e9f0a000000b002b6b7a98c4bsm3535238ljk.77.2023.07.03.06.21.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 03 Jul 2023 06:21:57 -0700 (PDT) From: Linus Walleij Date: Mon, 03 Jul 2023 15:21:50 +0200 Subject: [PATCH v3 2/4] drm/panel: boe-tv101wum-nl6: Drop surplus prepare tracking MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20230703-fix-boe-tv101wum-nl6-v3-2-bd6e9432c755@linaro.org> References: <20230703-fix-boe-tv101wum-nl6-v3-0-bd6e9432c755@linaro.org> In-Reply-To: <20230703-fix-boe-tv101wum-nl6-v3-0-bd6e9432c755@linaro.org> To: Ruihai Zhou , Stephen Boyd , Douglas Anderson , Cong Yang , Jitao Shi , Neil Armstrong , Sam Ravnborg , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Linus Walleij X-Mailer: b4 0.12.3 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The DRM panel core already keeps track of if the panel is already prepared so do not reimplement this. Reviewed-by: Sam Ravnborg Signed-off-by: Linus Walleij --- drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c b/drivers/gpu/d= rm/panel/panel-boe-tv101wum-nl6.c index 6fd4c9507c88..358918e0f03f 100644 --- a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c +++ b/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c @@ -51,8 +51,6 @@ struct boe_panel { struct regulator *avee; struct regulator *avdd; struct gpio_desc *enable_gpio; - - bool prepared; }; =20 static int boe_tv110c9m_init(struct mipi_dsi_device *dsi) @@ -1748,9 +1746,6 @@ static int boe_panel_unprepare(struct drm_panel *pane= l) { struct boe_panel *boe =3D to_boe_panel(panel); =20 - if (!boe->prepared) - return 0; - if (boe->desc->discharge_on_disable) { regulator_disable(boe->avee); regulator_disable(boe->avdd); @@ -1769,8 +1764,6 @@ static int boe_panel_unprepare(struct drm_panel *pane= l) regulator_disable(boe->pp3300); } =20 - boe->prepared =3D false; - return 0; } =20 @@ -1779,9 +1772,6 @@ static int boe_panel_prepare(struct drm_panel *panel) struct boe_panel *boe =3D to_boe_panel(panel); int ret; =20 - if (boe->prepared) - return 0; - gpiod_set_value(boe->enable_gpio, 0); usleep_range(1000, 1500); =20 @@ -1823,8 +1813,6 @@ static int boe_panel_prepare(struct drm_panel *panel) } } =20 - boe->prepared =3D true; - return 0; =20 poweroff: --=20 2.34.1 From nobody Mon Feb 9 20:50:48 2026 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 3FF49C001B1 for ; Mon, 3 Jul 2023 13:22:16 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231463AbjGCNWO (ORCPT ); Mon, 3 Jul 2023 09:22:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45926 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231435AbjGCNWF (ORCPT ); Mon, 3 Jul 2023 09:22:05 -0400 Received: from mail-lj1-x234.google.com (mail-lj1-x234.google.com [IPv6:2a00:1450:4864:20::234]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EC158E41 for ; Mon, 3 Jul 2023 06:22:00 -0700 (PDT) Received: by mail-lj1-x234.google.com with SMTP id 38308e7fff4ca-2b698937f85so73538751fa.2 for ; Mon, 03 Jul 2023 06:22:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1688390519; x=1690982519; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:from:to:cc:subject:date:message-id :reply-to; bh=707UFbgNApj3DBexaUCKZSnpItMYgFLYKkF++9NeOks=; b=HwRVImls49bjtL5KCqD6gZ9HjWqYbgmYGsVcL2gtSyU7NZAcxUdQbjaK+17h6WiazY jy8Z8ht1tfO2bg/kbm+Dm9hACbXTCjK/jlbqLE0ISxl801FgLOiEH+Ams0L+XcEIOQpb 7DxtBmO6pIZnNfAcbEGnBmkI4AQ+oFf3qSQ/2ruZXudz0zxWqcFSiH0pxukMqrvzrSON 12r+WMF1sdCN29rFgAsb54lAAxsl88qbU954qWhpmeVQuWNUpAi8J/3Q3zTdxSIU3Pjr DT/ZlimOTIgHc0NKqOIe4virQ4qrCNIy1lOiswKK7qmRzZLTeCn1m76BdzJXSN7BPESX 9taA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688390519; x=1690982519; h=cc:to:in-reply-to:references:message-id:content-transfer-encoding :mime-version:subject:date:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=707UFbgNApj3DBexaUCKZSnpItMYgFLYKkF++9NeOks=; b=LnePx/RyDJ2xTC3/RUONhD/vr9BG0tLiGFpIBcfLsqev5fLpNLuxfByoI9lpwHERKj 8okP9OGzlhPsOZy7t8x4EysEw2sAJ6+IBgf0oaIADPF1ekzLio1umlqX6VuLqWQDR2+1 3qylqOfUTAcx71w5yI7KihUFw655omiMfKIkD2E44Q8BFwtliGupknk/p4fzT2RPn3di GblJi0ozUlGBfA/SSv0qyGojvnSoLfLIrG1nx8QZaEPwbNo7YlJ2+Co34dF7EVlv3fBb AX0ZwFYaKZnwpFqNZfGz9pnNfUoHOrYUQl7uVj5rSKkxJchGq3iXrfhe5qhf4Lm98FlF qgGw== X-Gm-Message-State: ABy/qLYyGw407RnibwQ+OvQ8zYNfY0DX9yHF+NzO/u4e12DLR8Nilx3h dos6OeOfot0d+IlpnAgfTJaEbA== X-Google-Smtp-Source: APBJJlFo/gEuK8YYpFQnhqoIbkiyghJVEFwvE1Sf6MoUlO8Csy7JpVNoFizsZinWfxOPwqRTvw8BFQ== X-Received: by 2002:a2e:9899:0:b0:2b6:cff1:cd1c with SMTP id b25-20020a2e9899000000b002b6cff1cd1cmr6683795ljj.34.1688390518881; Mon, 03 Jul 2023 06:21:58 -0700 (PDT) Received: from [127.0.1.1] ([85.235.12.238]) by smtp.gmail.com with ESMTPSA id u10-20020a2e9f0a000000b002b6b7a98c4bsm3535238ljk.77.2023.07.03.06.21.57 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 03 Jul 2023 06:21:58 -0700 (PDT) From: Linus Walleij Date: Mon, 03 Jul 2023 15:21:51 +0200 Subject: [PATCH v3 3/4] drm/panel: ili9882t: Break out as separate driver MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20230703-fix-boe-tv101wum-nl6-v3-3-bd6e9432c755@linaro.org> References: <20230703-fix-boe-tv101wum-nl6-v3-0-bd6e9432c755@linaro.org> In-Reply-To: <20230703-fix-boe-tv101wum-nl6-v3-0-bd6e9432c755@linaro.org> To: Ruihai Zhou , Stephen Boyd , Douglas Anderson , Cong Yang , Jitao Shi , Neil Armstrong , Sam Ravnborg , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Linus Walleij X-Mailer: b4 0.12.3 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The Starry ILI9882t-based panel should never have been part of the boe tv101wum driver, it is clearly based on the Ilitek ILI9882t display controller and if you look at the custom command sequences for the panel these clearly contain the signature Ilitek page switch (0xff) commands. The hardware has nothing in common with the other panels supported by this driver. Break this out into a separate driver and config symbol instead. If the placement here is out of convenience for using similar code, we should consider creating a helper library instead. Signed-off-by: Linus Walleij --- drivers/gpu/drm/panel/Kconfig | 9 + drivers/gpu/drm/panel/Makefile | 1 + drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c | 386 ------------- drivers/gpu/drm/panel/panel-ilitek-ili9882t.c | 739 +++++++++++++++++++++= ++++ 4 files changed, 749 insertions(+), 386 deletions(-) diff --git a/drivers/gpu/drm/panel/Kconfig b/drivers/gpu/drm/panel/Kconfig index 1a0fd0754692..c39e949a26eb 100644 --- a/drivers/gpu/drm/panel/Kconfig +++ b/drivers/gpu/drm/panel/Kconfig @@ -203,6 +203,15 @@ config DRM_PANEL_ILITEK_ILI9881C Say Y if you want to enable support for panels based on the Ilitek ILI9881c controller. =20 +config DRM_PANEL_ILITEK_ILI9882T + tristate "Ilitek ILI9882t-based panels" + depends on OF + depends on DRM_MIPI_DSI + depends on BACKLIGHT_CLASS_DEVICE + help + Say Y if you want to enable support for panels based on the + Ilitek ILI9882t controller. + config DRM_PANEL_INNOLUX_EJ030NA tristate "Innolux EJ030NA 320x480 LCD panel" depends on OF && SPI diff --git a/drivers/gpu/drm/panel/Makefile b/drivers/gpu/drm/panel/Makefile index 499e38244253..75c2533d337e 100644 --- a/drivers/gpu/drm/panel/Makefile +++ b/drivers/gpu/drm/panel/Makefile @@ -18,6 +18,7 @@ obj-$(CONFIG_DRM_PANEL_HIMAX_HX8394) +=3D panel-himax-hx8= 394.o obj-$(CONFIG_DRM_PANEL_ILITEK_IL9322) +=3D panel-ilitek-ili9322.o obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9341) +=3D panel-ilitek-ili9341.o obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9881C) +=3D panel-ilitek-ili9881c.o +obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9882T) +=3D panel-ilitek-ili9882t.o obj-$(CONFIG_DRM_PANEL_INNOLUX_EJ030NA) +=3D panel-innolux-ej030na.o obj-$(CONFIG_DRM_PANEL_INNOLUX_P079ZCA) +=3D panel-innolux-p079zca.o obj-$(CONFIG_DRM_PANEL_JADARD_JD9365DA_H3) +=3D panel-jadard-jd9365da-h3.o diff --git a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c b/drivers/gpu/d= rm/panel/panel-boe-tv101wum-nl6.c index 358918e0f03f..14a0ee95a803 100644 --- a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c +++ b/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c @@ -1348,361 +1348,6 @@ static int starry_himax83102_j02_init(struct mipi_d= si_device *dsi) return 0; }; =20 - -static int starry_ili9882t_init(struct mipi_dsi_device *dsi) -{ - int ret; - - msleep(5); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x00, 0x42); - mipi_dsi_dcs_write_seq(dsi, 0x01, 0x11); - mipi_dsi_dcs_write_seq(dsi, 0x02, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x03, 0x00); - - mipi_dsi_dcs_write_seq(dsi, 0x04, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x05, 0x11); - mipi_dsi_dcs_write_seq(dsi, 0x06, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x07, 0x00); - - mipi_dsi_dcs_write_seq(dsi, 0x08, 0x80); - mipi_dsi_dcs_write_seq(dsi, 0x09, 0x81); - mipi_dsi_dcs_write_seq(dsi, 0x0A, 0x71); - mipi_dsi_dcs_write_seq(dsi, 0x0B, 0x00); - - mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x1A); - - mipi_dsi_dcs_write_seq(dsi, 0x24, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x25, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x26, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x27, 0x00); - - mipi_dsi_dcs_write_seq(dsi, 0x2C, 0xD4); - mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x40); - - mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x11); - - mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x32); - mipi_dsi_dcs_write_seq(dsi, 0xD1, 0x30); - - mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x55); - - mipi_dsi_dcs_write_seq(dsi, 0xD0, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0xE3, 0x93); - mipi_dsi_dcs_write_seq(dsi, 0xE4, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x80); - - mipi_dsi_dcs_write_seq(dsi, 0x31, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x32, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x33, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x34, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x35, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x36, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x37, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x38, 0x28); - mipi_dsi_dcs_write_seq(dsi, 0x39, 0x29); - mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x11); - mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x13); - mipi_dsi_dcs_write_seq(dsi, 0x3C, 0x15); - mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x17); - mipi_dsi_dcs_write_seq(dsi, 0x3E, 0x09); - mipi_dsi_dcs_write_seq(dsi, 0x3F, 0x0D); - mipi_dsi_dcs_write_seq(dsi, 0x40, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x41, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x42, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x43, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x44, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x45, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x46, 0x02); - - mipi_dsi_dcs_write_seq(dsi, 0x47, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x48, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x49, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x4A, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x4B, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x4C, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x4D, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x4E, 0x28); - mipi_dsi_dcs_write_seq(dsi, 0x4F, 0x29); - mipi_dsi_dcs_write_seq(dsi, 0x50, 0x10); - mipi_dsi_dcs_write_seq(dsi, 0x51, 0x12); - mipi_dsi_dcs_write_seq(dsi, 0x52, 0x14); - mipi_dsi_dcs_write_seq(dsi, 0x53, 0x16); - mipi_dsi_dcs_write_seq(dsi, 0x54, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x55, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x56, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x57, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x58, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x59, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x5A, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x5B, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x5C, 0x02); - - mipi_dsi_dcs_write_seq(dsi, 0x61, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x62, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x63, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x64, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x65, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x66, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x67, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x68, 0x28); - mipi_dsi_dcs_write_seq(dsi, 0x69, 0x29); - mipi_dsi_dcs_write_seq(dsi, 0x6A, 0x16); - mipi_dsi_dcs_write_seq(dsi, 0x6B, 0x14); - mipi_dsi_dcs_write_seq(dsi, 0x6C, 0x12); - mipi_dsi_dcs_write_seq(dsi, 0x6D, 0x10); - mipi_dsi_dcs_write_seq(dsi, 0x6E, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x6F, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x70, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x71, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x72, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x73, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x74, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x75, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x76, 0x02); - - mipi_dsi_dcs_write_seq(dsi, 0x77, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x78, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x79, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x7A, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x7B, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x7C, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x7D, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x7E, 0x28); - mipi_dsi_dcs_write_seq(dsi, 0x7F, 0x29); - mipi_dsi_dcs_write_seq(dsi, 0x80, 0x17); - mipi_dsi_dcs_write_seq(dsi, 0x81, 0x15); - mipi_dsi_dcs_write_seq(dsi, 0x82, 0x13); - mipi_dsi_dcs_write_seq(dsi, 0x83, 0x11); - mipi_dsi_dcs_write_seq(dsi, 0x84, 0x0D); - mipi_dsi_dcs_write_seq(dsi, 0x85, 0x09); - mipi_dsi_dcs_write_seq(dsi, 0x86, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x87, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x88, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x89, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x8A, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x8B, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x8C, 0x07); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x29, 0x3A); - mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x3B); - - mipi_dsi_dcs_write_seq(dsi, 0x06, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x07, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x08, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x09, 0x44); - - mipi_dsi_dcs_write_seq(dsi, 0x3C, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x39, 0x11); - mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x44); - - mipi_dsi_dcs_write_seq(dsi, 0x53, 0x1F); - mipi_dsi_dcs_write_seq(dsi, 0x5E, 0x40); - mipi_dsi_dcs_write_seq(dsi, 0x84, 0x00); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0x20, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x21, 0x3C); - mipi_dsi_dcs_write_seq(dsi, 0x22, 0xFA); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0xE2, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0xE5, 0x91); - mipi_dsi_dcs_write_seq(dsi, 0xE6, 0x3C); - mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0xE8, 0xFA); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x12); - mipi_dsi_dcs_write_seq(dsi, 0x87, 0x2C); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x73, 0xE5); - mipi_dsi_dcs_write_seq(dsi, 0x7F, 0x6B); - mipi_dsi_dcs_write_seq(dsi, 0x6D, 0xA4); - mipi_dsi_dcs_write_seq(dsi, 0x79, 0x54); - mipi_dsi_dcs_write_seq(dsi, 0x69, 0x97); - mipi_dsi_dcs_write_seq(dsi, 0x6A, 0x97); - mipi_dsi_dcs_write_seq(dsi, 0xA5, 0x3F); - mipi_dsi_dcs_write_seq(dsi, 0x61, 0xDA); - mipi_dsi_dcs_write_seq(dsi, 0xA7, 0xF1); - mipi_dsi_dcs_write_seq(dsi, 0x5F, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x62, 0x3F); - mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x90); - mipi_dsi_dcs_write_seq(dsi, 0x86, 0x87); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x80); - mipi_dsi_dcs_write_seq(dsi, 0xC1, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0xCA, 0x58); - mipi_dsi_dcs_write_seq(dsi, 0xCB, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0xCE, 0x58); - mipi_dsi_dcs_write_seq(dsi, 0xCF, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x67, 0x60); - mipi_dsi_dcs_write_seq(dsi, 0x10, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x92, 0x22); - mipi_dsi_dcs_write_seq(dsi, 0xD3, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0xD6, 0x55); - mipi_dsi_dcs_write_seq(dsi, 0xDC, 0x38); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0xE0, 0x00, 0x10, 0x2A, 0x4D, 0x61, 0x56, 0x6= A, 0x6E, 0x79, - 0x76, 0x8F, 0x95, 0x98, 0xAE, 0xAA, 0xB2, 0xBB, 0xCE, 0xC6, 0xBD, - 0xD5, 0xE2, 0xE8); - mipi_dsi_dcs_write_seq(dsi, 0xE1, 0x00, 0x10, 0x2A, 0x4D, 0x61, 0x56, 0x6= A, 0x6E, 0x79, - 0x76, 0x8F, 0x95, 0x98, 0xAE, 0xAA, 0xB2, 0xBB, 0xCE, 0xC6, 0xBD, - 0xD5, 0xE2, 0xE8); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x81); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x00, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x01, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x02, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0x03, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0x04, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0x05, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x06, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0x07, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0x08, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0x09, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0x0A, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0x0B, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x0C, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0x0D, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0x0E, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x0F, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x10, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0x11, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x12, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x13, 0x09); - mipi_dsi_dcs_write_seq(dsi, 0x14, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x15, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x16, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0x17, 0x0B); - mipi_dsi_dcs_write_seq(dsi, 0x18, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x19, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x1A, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0x1B, 0x0D); - mipi_dsi_dcs_write_seq(dsi, 0x1C, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0x1D, 0x0E); - mipi_dsi_dcs_write_seq(dsi, 0x1E, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x1F, 0x0F); - mipi_dsi_dcs_write_seq(dsi, 0x20, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0x21, 0x10); - mipi_dsi_dcs_write_seq(dsi, 0x22, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x23, 0x11); - mipi_dsi_dcs_write_seq(dsi, 0x24, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x25, 0x12); - mipi_dsi_dcs_write_seq(dsi, 0x26, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x27, 0x13); - mipi_dsi_dcs_write_seq(dsi, 0x28, 0x07); - mipi_dsi_dcs_write_seq(dsi, 0x29, 0x14); - mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x15); - mipi_dsi_dcs_write_seq(dsi, 0x2C, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x2D, 0x16); - mipi_dsi_dcs_write_seq(dsi, 0x2E, 0x09); - mipi_dsi_dcs_write_seq(dsi, 0x2F, 0x17); - mipi_dsi_dcs_write_seq(dsi, 0x30, 0x08); - mipi_dsi_dcs_write_seq(dsi, 0x31, 0x18); - mipi_dsi_dcs_write_seq(dsi, 0x32, 0x09); - mipi_dsi_dcs_write_seq(dsi, 0x33, 0x19); - mipi_dsi_dcs_write_seq(dsi, 0x34, 0x09); - mipi_dsi_dcs_write_seq(dsi, 0x35, 0x1A); - mipi_dsi_dcs_write_seq(dsi, 0x36, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x37, 0x1B); - mipi_dsi_dcs_write_seq(dsi, 0x38, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x39, 0x1C); - mipi_dsi_dcs_write_seq(dsi, 0x3A, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x3B, 0x1D); - mipi_dsi_dcs_write_seq(dsi, 0x3C, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x3D, 0x1E); - mipi_dsi_dcs_write_seq(dsi, 0x3E, 0x0A); - mipi_dsi_dcs_write_seq(dsi, 0x3F, 0x1F); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x01); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0E); - mipi_dsi_dcs_write_seq(dsi, 0x02, 0x0C); - mipi_dsi_dcs_write_seq(dsi, 0x20, 0x10); - mipi_dsi_dcs_write_seq(dsi, 0x25, 0x16); - mipi_dsi_dcs_write_seq(dsi, 0x26, 0xE0); - mipi_dsi_dcs_write_seq(dsi, 0x27, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x29, 0x71); - mipi_dsi_dcs_write_seq(dsi, 0x2A, 0x46); - mipi_dsi_dcs_write_seq(dsi, 0x2B, 0x1F); - mipi_dsi_dcs_write_seq(dsi, 0x2D, 0xC7); - mipi_dsi_dcs_write_seq(dsi, 0x31, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x32, 0xDF); - mipi_dsi_dcs_write_seq(dsi, 0x33, 0x5A); - mipi_dsi_dcs_write_seq(dsi, 0x34, 0xC0); - mipi_dsi_dcs_write_seq(dsi, 0x35, 0x5A); - mipi_dsi_dcs_write_seq(dsi, 0x36, 0xC0); - mipi_dsi_dcs_write_seq(dsi, 0x38, 0x65); - mipi_dsi_dcs_write_seq(dsi, 0x80, 0x3E); - mipi_dsi_dcs_write_seq(dsi, 0x81, 0xA0); - mipi_dsi_dcs_write_seq(dsi, 0xB0, 0x01); - mipi_dsi_dcs_write_seq(dsi, 0xB1, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC0, 0x12); - mipi_dsi_dcs_write_seq(dsi, 0xC2, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC3, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC4, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC5, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC6, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC7, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC8, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0xC9, 0xCC); - mipi_dsi_dcs_write_seq(dsi, 0x30, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x00, 0x81); - mipi_dsi_dcs_write_seq(dsi, 0x08, 0x02); - mipi_dsi_dcs_write_seq(dsi, 0x09, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x07, 0x21); - mipi_dsi_dcs_write_seq(dsi, 0x04, 0x10); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x1E); - mipi_dsi_dcs_write_seq(dsi, 0x60, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x64, 0x00); - mipi_dsi_dcs_write_seq(dsi, 0x6D, 0x00); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x0B); - mipi_dsi_dcs_write_seq(dsi, 0xA6, 0x44); - mipi_dsi_dcs_write_seq(dsi, 0xA7, 0xB6); - mipi_dsi_dcs_write_seq(dsi, 0xA8, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0xA9, 0x03); - mipi_dsi_dcs_write_seq(dsi, 0xAA, 0x51); - mipi_dsi_dcs_write_seq(dsi, 0xAB, 0x51); - mipi_dsi_dcs_write_seq(dsi, 0xAC, 0x04); - mipi_dsi_dcs_write_seq(dsi, 0xBD, 0x92); - mipi_dsi_dcs_write_seq(dsi, 0xBE, 0xA1); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x05); - mipi_dsi_dcs_write_seq(dsi, 0x86, 0x87); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x06); - mipi_dsi_dcs_write_seq(dsi, 0x92, 0x22); - - mipi_dsi_dcs_write_seq(dsi, 0xFF, 0x98, 0x82, 0x00); - - ret =3D mipi_dsi_dcs_exit_sleep_mode(dsi); - if (ret) - return ret; - msleep(120); - ret =3D mipi_dsi_dcs_set_display_on(dsi); - if (ret) - return ret; - msleep(20); - - return 0; -}; - static inline struct boe_panel *to_boe_panel(struct drm_panel *panel) { return container_of(panel, struct boe_panel, base); @@ -2081,34 +1726,6 @@ static const struct panel_desc starry_himax83102_j02= _desc =3D { .lp11_before_reset =3D true, }; =20 -static const struct drm_display_mode starry_ili9882t_default_mode =3D { - .clock =3D 165280, - .hdisplay =3D 1200, - .hsync_start =3D 1200 + 32, - .hsync_end =3D 1200 + 32 + 30, - .htotal =3D 1200 + 32 + 30 + 32, - .vdisplay =3D 1920, - .vsync_start =3D 1920 + 68, - .vsync_end =3D 1920 + 68 + 2, - .vtotal =3D 1920 + 68 + 2 + 10, - .type =3D DRM_MODE_TYPE_DRIVER | DRM_MODE_TYPE_PREFERRED, -}; - -static const struct panel_desc starry_ili9882t_desc =3D { - .modes =3D &starry_ili9882t_default_mode, - .bpc =3D 8, - .size =3D { - .width_mm =3D 141, - .height_mm =3D 226, - }, - .lanes =3D 4, - .format =3D MIPI_DSI_FMT_RGB888, - .mode_flags =3D MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | - MIPI_DSI_MODE_LPM, - .init =3D starry_ili9882t_init, - .lp11_before_reset =3D true, -}; - static int boe_panel_get_modes(struct drm_panel *panel, struct drm_connector *connector) { @@ -2285,9 +1902,6 @@ static const struct of_device_id boe_of_match[] =3D { { .compatible =3D "starry,himax83102-j02", .data =3D &starry_himax83102_j02_desc }, - { .compatible =3D "starry,ili9882t", - .data =3D &starry_ili9882t_desc - }, { /* sentinel */ } }; MODULE_DEVICE_TABLE(of, boe_of_match); diff --git a/drivers/gpu/drm/panel/panel-ilitek-ili9882t.c b/drivers/gpu/dr= m/panel/panel-ilitek-ili9882t.c new file mode 100644 index 000000000000..20f3cc37fa83 --- /dev/null +++ b/drivers/gpu/drm/panel/panel-ilitek-ili9882t.c @@ -0,0 +1,739 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Panels based on the Ilitek ILI9882T display controller. + */ +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include + +#include