From patchwork Mon Jul 3 13:21:49 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 13300057 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 gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 1C06AEB64DC for ; Mon, 3 Jul 2023 13:22:11 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 6FD78890BE; Mon, 3 Jul 2023 13:22:02 +0000 (UTC) Received: from mail-lj1-x236.google.com (mail-lj1-x236.google.com [IPv6:2a00:1450:4864:20::236]) by gabe.freedesktop.org (Postfix) with ESMTPS id C69AC890BE for ; Mon, 3 Jul 2023 13:21:59 +0000 (UTC) Received: by mail-lj1-x236.google.com with SMTP id 38308e7fff4ca-2b6a16254a4so65824081fa.0 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=J5b7cqIaDvpx0/cZoLXEQzT//ANHa2A5YGCamWysgsOEtxZ/FG3CDY1Pfi2u4yPX9K zDHcUlnP9wwgT0H57JQoYSv1ySRruR10A++VSv0zpgDkwSPiXPspZYQEk5wXhsZofxbY tTE6SvMKliW7/2+zrwwRFItfBM9jsaxXX/Ba/63bPndxOynJFiw8WYisrmigj/bzPdm2 UEKNwsXvTG5Mbv6ucXFdyx89srBN8aQ0h8Q8Vzoeiv1o9z4pjLEat89j6D9VrEaE0/PX rGPmB4LiXkKjyrtcVMH7hMTDwArzVyDFHLDhhPFFCWXns3YfcGZPNreFczJT4rHI6gG8 nj7w== X-Gm-Message-State: ABy/qLbePsPX+6qddCLdRHgNY2bOF5/X5CJVUfFwKQpV63Iv148lBQ5L FgYfIh3ekxm2qTE1h4mBf5uhqg== 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 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 X-Mailer: b4 0.12.3 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" 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/drm/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 { 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; }; -enum dsi_cmd_type { - INIT_DCS_CMD, - DELAY_CMD, -}; +static int boe_tv110c9m_init(struct mipi_dsi_device *dsi) +{ + int ret; -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); -#define _INIT_DCS_CMD(...) { \ - .type = INIT_DCS_CMD, \ - .len = sizeof((char[]){__VA_ARGS__}), \ - .data = (char[]){__VA_ARGS__} } - -#define _INIT_DELAY_CMD(...) { \ - .type = DELAY_CMD,\ - .len = sizeof((char[]){__VA_ARGS__}), \ - .data = (char[]){__VA_ARGS__} } - -static const struct panel_init_cmd boe_tv110c9m_init_cmd[] = { - _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, 0x00, 0x6D, 0x00, 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x01, 0x7E, 0x01, 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x03, 0x08, 0x03, 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B); + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x03, 0xE7, 0x03, 0xFD, 0x03, 0xFF); - _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, 0x00, 0x6D, 0x00, 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x01, 0x7E, 0x01, 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x03, 0x08, 0x03, 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x03, 0xE7, 0x03, 0xFD, 0x03, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x00, 0x08, 0x00, 0x23, 0x00, 0x4D, 0x00, 0x6D, 0x00, 0x89, 0x00, 0xA1, 0x00, 0xB6, 0x00, 0xC9); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x00, 0xDA, 0x01, 0x13, 0x01, 0x3C, 0x01, 0x7E, 0x01, 0xAB, 0x01, 0xF7, 0x02, 0x2F, 0x02, 0x31); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x02, 0x67, 0x02, 0xA6, 0x02, 0xD1, 0x03, 0x08, 0x03, 0x2E, 0x03, 0x5B, 0x03, 0x6B, 0x03, 0x7B); + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x03, 0x8E, 0x03, 0xA2, 0x03, 0xB7, 0x03, 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, 0x00, 0x65, 0x00, 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1); + mipi_dsi_dcs_write_seq(dsi, 0xB1, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x01, 0x76, 0x01, 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xB2, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x03, 0x00, 0x03, 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73); + + mipi_dsi_dcs_write_seq(dsi, 0xB3, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x03, 0xDF, 0x03, 0xF5, 0x03, 0xE0); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x00, 0x65, 0x00, 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1); + mipi_dsi_dcs_write_seq(dsi, 0xB5, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x01, 0x76, 0x01, 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xB6, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x03, 0x00, 0x03, 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0xB7, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x03, 0xDF, 0x03, 0xF5, 0x03, 0xE0); + + mipi_dsi_dcs_write_seq(dsi, 0xB8, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x45, 0x00, 0x65, 0x00, 0x81, 0x00, 0x99, 0x00, 0xAE, 0x00, 0xC1); + mipi_dsi_dcs_write_seq(dsi, 0xB9, 0x00, 0xD2, 0x01, 0x0B, 0x01, 0x34, 0x01, 0x76, 0x01, 0xA3, 0x01, 0xEF, 0x02, 0x27, 0x02, 0x29); + mipi_dsi_dcs_write_seq(dsi, 0xBA, 0x02, 0x5F, 0x02, 0x9E, 0x02, 0xC9, 0x03, 0x00, 0x03, 0x26, 0x03, 0x53, 0x03, 0x63, 0x03, 0x73); + + mipi_dsi_dcs_write_seq(dsi, 0xBB, 0x03, 0x86, 0x03, 0x9A, 0x03, 0xAF, 0x03, 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, 0x00, 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 = mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(200); + ret = mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(100); -static const struct panel_init_cmd inx_hj110iz_init_cmd[] = { - _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; +} -static const struct panel_init_cmd boe_init_cmd[] = { - _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; -static const struct panel_init_cmd auo_kd101n80_45na_init_cmd[] = { - _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, 0x00, 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 = mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(200); + ret = mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(100); -static const struct panel_init_cmd auo_b101uan08_3_init_cmd[] = { - _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; +} -static const struct panel_init_cmd starry_qfh032011_53g_init_cmd[] = { - _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); -static const struct panel_init_cmd starry_himax83102_j02_init_cmd[] = { - _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, 0x18, 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, 0x18, 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, 0x55, 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, 0x01, 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, 0xFC, 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; +} -static const struct panel_init_cmd starry_ili9882t_init_cmd[] = { - _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, 0xE2, 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, 0xE2, 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; -static inline struct boe_panel *to_boe_panel(struct drm_panel *panel) + msleep(24); + ret = mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret = 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; } -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 = boe->dsi; - struct drm_panel *panel = &boe->base; - int i, err = 0; - - if (boe->desc->init_cmds) { - const struct panel_init_cmd *init_cmds = boe->desc->init_cmds; - - for (i = 0; init_cmds[i].len != 0; i++) { - const struct panel_init_cmd *cmd = &init_cmds[i]; - - switch (cmd->type) { - case DELAY_CMD: - msleep(cmd->data[0]); - err = 0; - break; - - case INIT_DCS_CMD: - err = mipi_dsi_dcs_write(dsi, cmd->data[0], - cmd->len <= 1 ? NULL : - &cmd->data[1], - cmd->len - 1); - break; - - default: - err = -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 = mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret = mipi_dsi_dcs_set_display_on(dsi); + if (ret) + return ret; + msleep(80); + return 0; } + +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, 0xD7, 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, 0x72, 0x3C, 0xA3, 0x03, + 0x03, 0x00, 0x00, 0x88, 0xF5); + mipi_dsi_dcs_write_seq(dsi, 0xB4, 0x76, 0x76, 0x76, 0x76, 0x76, 0x76, 0x63, 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, 0x61, 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, 0xFF); + mipi_dsi_dcs_write_seq(dsi, 0xD2, 0x1F, 0x11, 0x1F); + mipi_dsi_dcs_write_seq(dsi, 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); + mipi_dsi_dcs_write_seq(dsi, 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, 0x18, 0x18, + 0x18, 0x18); + mipi_dsi_dcs_write_seq(dsi, 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, 0x18, 0x18, + 0x18, 0x18); + mipi_dsi_dcs_write_seq(dsi, 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); + mipi_dsi_dcs_write_seq(dsi, 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, + 0x55, 0x5C, 0x68, 0x73); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x0E, 0x10, 0x10, 0x21, 0x2B, 0x9A, 0x02, 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, 0x01); + mipi_dsi_dcs_write_seq(dsi, 0xE9, 0x3F); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0x02, 0x00, 0x28, 0x01, 0x7E, 0x0F, 0x7E, 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, 0xFF, 0xFF, 0xBF, + 0xFE, 0xAA, 0xA0); + mipi_dsi_dcs_write_seq(dsi, 0xE7, 0xFE, 0x04, 0xFE, 0x04, 0xFE, 0x04, 0x03, 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, 0x00, 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 = mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret = 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, 0x6A, 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, 0x6A, 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 = mipi_dsi_dcs_exit_sleep_mode(dsi); + if (ret) + return ret; + msleep(120); + ret = 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 = boe->dsi; @@ -1860,10 +1815,12 @@ static int boe_panel_prepare(struct drm_panel *panel) gpiod_set_value(boe->enable_gpio, 1); usleep_range(6000, 10000); - ret = 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 = boe->desc->init(boe->dsi); + if (ret < 0) { + dev_err(panel->dev, "failed to init panel: %d\n", ret); + goto poweroff; + } } boe->prepared = true; @@ -1914,7 +1871,7 @@ static const struct panel_desc boe_tv110c9m_desc = { | MIPI_DSI_MODE_VIDEO_HSE | MIPI_DSI_CLOCK_NON_CONTINUOUS | MIPI_DSI_MODE_VIDEO_BURST, - .init_cmds = boe_tv110c9m_init_cmd, + .init = boe_tv110c9m_init, }; static const struct drm_display_mode inx_hj110iz_default_mode = { @@ -1943,7 +1900,7 @@ static const struct panel_desc inx_hj110iz_desc = { | MIPI_DSI_MODE_VIDEO_HSE | MIPI_DSI_CLOCK_NON_CONTINUOUS | MIPI_DSI_MODE_VIDEO_BURST, - .init_cmds = inx_hj110iz_init_cmd, + .init = inx_hj110iz_init, }; static const struct drm_display_mode boe_tv101wum_nl6_default_mode = { @@ -1969,7 +1926,7 @@ static const struct panel_desc boe_tv101wum_nl6_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = boe_init_cmd, + .init = boe_init, .discharge_on_disable = false, }; @@ -1996,7 +1953,7 @@ static const struct panel_desc auo_kd101n80_45na_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = auo_kd101n80_45na_init_cmd, + .init = auo_kd101n80_45na_init, .discharge_on_disable = true, }; @@ -2024,7 +1981,7 @@ static const struct panel_desc boe_tv101wum_n53_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = boe_init_cmd, + .init = boe_init, }; static const struct drm_display_mode auo_b101uan08_3_default_mode = { @@ -2051,7 +2008,7 @@ static const struct panel_desc auo_b101uan08_3_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = auo_b101uan08_3_init_cmd, + .init = auo_b101uan08_3_init, }; static const struct drm_display_mode boe_tv105wum_nw0_default_mode = { @@ -2078,7 +2035,7 @@ static const struct panel_desc boe_tv105wum_nw0_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = boe_init_cmd, + .init = boe_init, .lp11_before_reset = true, }; @@ -2105,7 +2062,7 @@ static const struct panel_desc starry_qfh032011_53g_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = starry_qfh032011_53g_init_cmd, + .init = starry_qfh032011_53g_init, }; static const struct drm_display_mode starry_himax83102_j02_default_mode = { @@ -2132,7 +2089,7 @@ static const struct panel_desc starry_himax83102_j02_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = starry_himax83102_j02_init_cmd, + .init = starry_himax83102_j02_init, .lp11_before_reset = true, }; @@ -2160,7 +2117,7 @@ static const struct panel_desc starry_ili9882t_desc = { .format = MIPI_DSI_FMT_RGB888, .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | MIPI_DSI_MODE_LPM, - .init_cmds = starry_ili9882t_init_cmd, + .init = starry_ili9882t_init, .lp11_before_reset = true, }; From patchwork Mon Jul 3 13:21:50 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 13300055 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 gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 7272BEB64DD for ; Mon, 3 Jul 2023 13:22:07 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id B564610E0F3; Mon, 3 Jul 2023 13:22:01 +0000 (UTC) Received: from mail-lj1-x232.google.com (mail-lj1-x232.google.com [IPv6:2a00:1450:4864:20::232]) by gabe.freedesktop.org (Postfix) with ESMTPS id 58A64890BE for ; Mon, 3 Jul 2023 13:21:59 +0000 (UTC) Received: by mail-lj1-x232.google.com with SMTP id 38308e7fff4ca-2b6b98ac328so65738671fa.0 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=AJMcH47btnkg1LOWJ66XzBmQuWJJFCNFLnyhUYaIbMou+IAlSJsTV57VEPIr6Et9NU i661IhXxVDWGcENoqls7Yoc9+kgHCdnFPoGJzsUX6gNOdAvV8SLi/yb/VKaCjcGY17ex kjjtuIUYkyzlzEH4tFRIJWEh96+SJeajB4XTXQX4K4JAkkPy3wA5ig/mbG8ctoM4hJmg IhwHaA17yX5dIDv3x6aEavHSYNXs98vAC1Ceg0T+lnYC1cCpU3rD5+nQKvzlFZ0ZDbQA OvpCJFBulXGxl13ORCmUcNTeSEemsIXWYYHK1rQhbYABSvWbDAy/1NwaJ9PNw3VkAxhm pkjw== X-Gm-Message-State: ABy/qLZLbHNkniWMLxUrzAaYnQ/RE2arxhnFzobNJ9PZVaUPw4SI7BiB f2h4zMm2RkyDr9ExEmz/wgCJ3w== 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 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 X-Mailer: b4 0.12.3 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" 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/drm/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; }; static int boe_tv110c9m_init(struct mipi_dsi_device *dsi) @@ -1748,9 +1746,6 @@ static int boe_panel_unprepare(struct drm_panel *panel) { struct boe_panel *boe = to_boe_panel(panel); - 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 *panel) regulator_disable(boe->pp3300); } - boe->prepared = false; - return 0; } @@ -1779,9 +1772,6 @@ static int boe_panel_prepare(struct drm_panel *panel) struct boe_panel *boe = to_boe_panel(panel); int ret; - if (boe->prepared) - return 0; - gpiod_set_value(boe->enable_gpio, 0); usleep_range(1000, 1500); @@ -1823,8 +1813,6 @@ static int boe_panel_prepare(struct drm_panel *panel) } } - boe->prepared = true; - return 0; poweroff: From patchwork Mon Jul 3 13:21:51 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 13300058 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 gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id BA6C6C001B0 for ; Mon, 3 Jul 2023 13:22:16 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id AE0B810E217; Mon, 3 Jul 2023 13:22:05 +0000 (UTC) Received: from mail-lj1-x236.google.com (mail-lj1-x236.google.com [IPv6:2a00:1450:4864:20::236]) by gabe.freedesktop.org (Postfix) with ESMTPS id E4563890BE for ; Mon, 3 Jul 2023 13:22:00 +0000 (UTC) Received: by mail-lj1-x236.google.com with SMTP id 38308e7fff4ca-2b69f1570b2so73727181fa.0 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=EprYxW5pp5mGaxE9M1AR8r1ROS6RNLFdnwsaGxw0AB6rbMzFuy+4zbz7TWW60A4txz gCh0+itUzkiIcy83laFDtDe9Gbe2HBms3h3ywlU9ckZiryXCq+iHjawoh6PE0xAiXcXW cUzD03qy+rWC8Rl348zcQput/DJqYc9UDHI6ACfDQZdh3wLuA1s7bndXaT9yTZd2zPEc Mt9MOFAQXAXuT6/ztXC5/NwRz/usDgxeejwF5YafqZze92nsdgHD6DFvxIU/KyP8vHU/ rtzoQSA9Bmw4FAwfBdwf7QiuDBSftmT7WTGvmRVlmbO2S9zlTc4VD0oQSVkPNGuJaswT 5F9A== X-Gm-Message-State: ABy/qLZ7c6hmcydzxFqdvqnxVaC/CgBLPdPsAg/NDetKXOZsTME7aPEg 8+ahlUvM/fZUUrS/sFCw3DErLmSFpEXlfJuBpTE= 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 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 X-Mailer: b4 0.12.3 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" 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. +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) += panel-himax-hx8394.o obj-$(CONFIG_DRM_PANEL_ILITEK_IL9322) += panel-ilitek-ili9322.o obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9341) += panel-ilitek-ili9341.o obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9881C) += panel-ilitek-ili9881c.o +obj-$(CONFIG_DRM_PANEL_ILITEK_ILI9882T) += panel-ilitek-ili9882t.o obj-$(CONFIG_DRM_PANEL_INNOLUX_EJ030NA) += panel-innolux-ej030na.o obj-$(CONFIG_DRM_PANEL_INNOLUX_P079ZCA) += panel-innolux-p079zca.o obj-$(CONFIG_DRM_PANEL_JADARD_JD9365DA_H3) += panel-jadard-jd9365da-h3.o diff --git a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c b/drivers/gpu/drm/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_dsi_device *dsi) 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, 0x6A, 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, 0x6A, 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 = mipi_dsi_dcs_exit_sleep_mode(dsi); - if (ret) - return ret; - msleep(120); - ret = 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 = { .lp11_before_reset = true, }; -static const struct drm_display_mode starry_ili9882t_default_mode = { - .clock = 165280, - .hdisplay = 1200, - .hsync_start = 1200 + 32, - .hsync_end = 1200 + 32 + 30, - .htotal = 1200 + 32 + 30 + 32, - .vdisplay = 1920, - .vsync_start = 1920 + 68, - .vsync_end = 1920 + 68 + 2, - .vtotal = 1920 + 68 + 2 + 10, - .type = DRM_MODE_TYPE_DRIVER | DRM_MODE_TYPE_PREFERRED, -}; - -static const struct panel_desc starry_ili9882t_desc = { - .modes = &starry_ili9882t_default_mode, - .bpc = 8, - .size = { - .width_mm = 141, - .height_mm = 226, - }, - .lanes = 4, - .format = MIPI_DSI_FMT_RGB888, - .mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE | - MIPI_DSI_MODE_LPM, - .init = starry_ili9882t_init, - .lp11_before_reset = 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[] = { { .compatible = "starry,himax83102-j02", .data = &starry_himax83102_j02_desc }, - { .compatible = "starry,ili9882t", - .data = &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/drm/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