From patchwork Thu Jun 15 20:21:37 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 108706 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:994d:0:b0:3d9:f83d:47d9 with SMTP id k13csp900683vqr; Thu, 15 Jun 2023 13:34:46 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5YmYe6ZVlPI7Md34I+spcSfgA4/qsToGXTivmLYfOKSqv/huijpGOGdF7aEF4588R9L61l X-Received: by 2002:a92:4a09:0:b0:340:774d:cf79 with SMTP id m9-20020a924a09000000b00340774dcf79mr496825ilf.6.1686861286646; Thu, 15 Jun 2023 13:34:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686861286; cv=none; d=google.com; s=arc-20160816; b=j8DB8aiEjU+EzliudX5zwyr8RV3l+Q+AHDw1DSFZ2VJBSD47XWls5NvlxlOoVH4VKd MroKP2Z2CtOTVhu/R5Fq6jvKPTdjVYz5HbAEGa3P5ompq3CmUBILp08ThpIs69XETEFj nkUJMbg9DyJKZWfG3SYMPokHy1kvtAiD6InGNBFqA9qx0CJmHNHd2DW4uYY9pPIyI9aE A8hw2g6XmI3Now9r6sO7JKRT1vKncojsFMwHSGY2G+B/h6TEgx+ms37PLS/v7quTK3j1 tTf84t5bq2kek+yOR6YksAFwlecSto9HhDJ1GQYgOrHDPKqiYlkL02Xq+9rxdcPLgYQS Rfcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:in-reply-to:references:message-id :content-transfer-encoding:mime-version:subject:date:from :dkim-signature; bh=dHoPAMNqOS1ZNWUDNY15mSR/cUVldyviGs3PCrSbBs0=; b=cv+AnSoCmt2ckTbs7KQs46TnAUTzyDrXaeMcM+qn57lFt21pqTrs9xr/4d0UTpkB+t 3anVL58lZuOlIW0zcBsISdSWVEseDwnI0SfXnT8srHlbP4PHCb6EyRAmLn7UrhQhFSe5 GPhTuZLMCTtip5EtWzAB/+56icPlPq4/gD7ywXutuPtee1FPYYRlghBNqkP3LyOdDO4R vv7FWwCav5gnY51x9/qmJCrssXn+zLKCd0zbPPYS5bdaVrwrmKo22qXwfx9yRcyrxlGR ttH4nvRD9yyYxkn0CD9uL/BOU70d1aa+NuJQA+eXYanAz3/3S7VqH4IfWv0njXOjs2I+ LNWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=bdOjTL4v; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b184-20020a6334c1000000b0050bd4b86169si14089215pga.414.2023.06.15.13.34.33; Thu, 15 Jun 2023 13:34:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=bdOjTL4v; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237296AbjFOUVz (ORCPT + 99 others); Thu, 15 Jun 2023 16:21:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43148 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237085AbjFOUVx (ORCPT ); Thu, 15 Jun 2023 16:21:53 -0400 Received: from mail-lf1-x12d.google.com (mail-lf1-x12d.google.com [IPv6:2a00:1450:4864:20::12d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 07CDC212C for ; Thu, 15 Jun 2023 13:21:47 -0700 (PDT) Received: by mail-lf1-x12d.google.com with SMTP id 2adb3069b0e04-4f6195d2b3fso11361677e87.1 for ; Thu, 15 Jun 2023 13:21:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1686860505; x=1689452505; 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=dHoPAMNqOS1ZNWUDNY15mSR/cUVldyviGs3PCrSbBs0=; b=bdOjTL4vLtIAaM+dtc/n7KmQbKZkIxa6qb+14ybku1lapGxhHrOvk0dLRTiWkAAY0F oAKSHX9jcmlBxwzN2fWb7ZpZS5hgelT00oaPK1Kd6HJU0yA2EfHlVsspyu+RFpWAcezT z+KPO0hdaWhgXQlIV2eRihaKAahc94GPolx0w2xxrkCzepsgLrLxmYIsN1wmH7F2HXum 9Ld/SggPtI116X/LQKvPPibLtYfMpVGzAJ8HOicfV8QzasW1wKOrUTYtk+gPWxvErnup FtKLaKBhsKW92UFDa5sfkf2Zjjz3QidFTJfCLvveEfKFM3Hdui10R0KdmcjpAwmNEWir 0Rgw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1686860505; x=1689452505; 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=dHoPAMNqOS1ZNWUDNY15mSR/cUVldyviGs3PCrSbBs0=; b=XNrm5/+UAICk+SySPI1vIWsRipwA1AEt0hxHTPeXxWLB4aTWJD+Hf5gzswNTqtGYYd IAlBJspzayqbHP9a+UkvVflKbY0BKng1x3WiCDExmKI2F0iHn31aPHNpy3W0rIDjrrlO GvnCnt0wWv91tyxzfmuOL2VlS7Uz85hCFKe4wh7MsDb1JKTxM8qOCoVZvI3MRWMV2KdS ibN8duiAYOqjQsHHXpX/Lvnf87VXY8luw85B0PEGAtzwhDgKjxVzTZJTTe21sQd+RlWw o8TpmH2sDnb4cyqlZlXiJnSi4+6vzrTeaJM5JQp96Xr+6d+BI1N/xnpf0dweCY0SBU5i p1lw== X-Gm-Message-State: AC+VfDyCfXSknBZiAo8vordSE0IEAW4uAYyr+7T9/fAgOh1vh6EEDyux kGSzx5XSvCHZX7wZ6z+kouYl8Q== X-Received: by 2002:a05:6512:614:b0:4f4:aea9:2a2f with SMTP id b20-20020a056512061400b004f4aea92a2fmr13306816lfe.57.1686860504832; Thu, 15 Jun 2023 13:21:44 -0700 (PDT) Received: from [127.0.1.1] ([85.235.12.238]) by smtp.gmail.com with ESMTPSA id r14-20020ac252ae000000b004f3946030fasm2736470lfm.68.2023.06.15.13.21.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 15 Jun 2023 13:21:44 -0700 (PDT) From: Linus Walleij Date: Thu, 15 Jun 2023 22:21:37 +0200 Subject: [PATCH 1/2] drm/panel: boe-tv101wum-nl6: Drop macros and open code sequences MIME-Version: 1.0 Message-Id: <20230615-fix-boe-tv101wum-nl6-v1-1-8ac378405fb7@linaro.org> References: <20230615-fix-boe-tv101wum-nl6-v1-0-8ac378405fb7@linaro.org> In-Reply-To: <20230615-fix-boe-tv101wum-nl6-v1-0-8ac378405fb7@linaro.org> To: Ruihai Zhou , Stephen Boyd , yangcong , Jitao Shi , Neil Armstrong , Sam Ravnborg , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Linus Walleij X-Mailer: b4 0.12.1 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1768802260491769466?= X-GMAIL-MSGID: =?utf-8?q?1768802260491769466?= 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. Signed-off-by: Linus Walleij Reviewed-by: Sam Ravnborg --- drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c | 2408 ++++++++++++------------ 1 file changed, 1193 insertions(+), 1215 deletions(-) diff --git a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c b/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c index 783234ae0f57..d19d30e134dd 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; }; @@ -54,1224 +54,1200 @@ 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(0x0D, 0x63), - _INIT_DCS_CMD(0x07, 0x8C), - _INIT_DCS_CMD(0x08, 0x4B), - _INIT_DCS_CMD(0x0E, 0x91), - _INIT_DCS_CMD(0x0F, 0x69), - _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(0xFF, 0x24), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x91, 0x44), - _INIT_DCS_CMD(0x92, 0x7A), - _INIT_DCS_CMD(0x93, 0x1A), - _INIT_DCS_CMD(0x94, 0x40), - _INIT_DCS_CMD(0x9A, 0x08), - _INIT_DCS_CMD(0x60, 0x96), - _INIT_DCS_CMD(0x61, 0xD0), - _INIT_DCS_CMD(0x63, 0x70), - _INIT_DCS_CMD(0xC2, 0xCF), - _INIT_DCS_CMD(0x9B, 0x0F), - _INIT_DCS_CMD(0x9A, 0x08), - _INIT_DCS_CMD(0x00, 0x03), - _INIT_DCS_CMD(0x01, 0x03), - _INIT_DCS_CMD(0x02, 0x03), - _INIT_DCS_CMD(0x03, 0x03), - _INIT_DCS_CMD(0x04, 0x03), - _INIT_DCS_CMD(0x05, 0x03), - _INIT_DCS_CMD(0x06, 0x22), - _INIT_DCS_CMD(0x07, 0x06), - _INIT_DCS_CMD(0x08, 0x00), - _INIT_DCS_CMD(0x09, 0x1D), - _INIT_DCS_CMD(0x0A, 0x1C), - _INIT_DCS_CMD(0x0B, 0x13), - _INIT_DCS_CMD(0x0C, 0x12), - _INIT_DCS_CMD(0x0D, 0x11), - _INIT_DCS_CMD(0x0E, 0x10), - _INIT_DCS_CMD(0x0F, 0x0F), - _INIT_DCS_CMD(0x10, 0x0E), - _INIT_DCS_CMD(0x11, 0x0D), - _INIT_DCS_CMD(0x12, 0x0C), - _INIT_DCS_CMD(0x13, 0x04), - _INIT_DCS_CMD(0x14, 0x03), - _INIT_DCS_CMD(0x15, 0x03), - _INIT_DCS_CMD(0x16, 0x03), - _INIT_DCS_CMD(0x17, 0x03), - _INIT_DCS_CMD(0x18, 0x03), - _INIT_DCS_CMD(0x19, 0x03), - _INIT_DCS_CMD(0x1A, 0x03), - _INIT_DCS_CMD(0x1B, 0x03), - _INIT_DCS_CMD(0x1C, 0x22), - _INIT_DCS_CMD(0x1D, 0x06), - _INIT_DCS_CMD(0x1E, 0x00), - _INIT_DCS_CMD(0x1F, 0x1D), - _INIT_DCS_CMD(0x20, 0x1C), - _INIT_DCS_CMD(0x21, 0x13), - _INIT_DCS_CMD(0x22, 0x12), - _INIT_DCS_CMD(0x23, 0x11), - _INIT_DCS_CMD(0x24, 0x10), - _INIT_DCS_CMD(0x25, 0x0F), - _INIT_DCS_CMD(0x26, 0x0E), - _INIT_DCS_CMD(0x27, 0x0D), - _INIT_DCS_CMD(0x28, 0x0C), - _INIT_DCS_CMD(0x29, 0x04), - _INIT_DCS_CMD(0x2A, 0x03), - _INIT_DCS_CMD(0x2B, 0x03), - - _INIT_DCS_CMD(0x2F, 0x05), - _INIT_DCS_CMD(0x30, 0x32), - _INIT_DCS_CMD(0x31, 0x43), - _INIT_DCS_CMD(0x33, 0x05), - _INIT_DCS_CMD(0x34, 0x32), - _INIT_DCS_CMD(0x35, 0x43), - _INIT_DCS_CMD(0x37, 0x44), - _INIT_DCS_CMD(0x38, 0x40), - _INIT_DCS_CMD(0x39, 0x00), - _INIT_DCS_CMD(0x3A, 0x18), - _INIT_DCS_CMD(0x3B, 0x00), - _INIT_DCS_CMD(0x3D, 0x93), - _INIT_DCS_CMD(0xAB, 0x44), - _INIT_DCS_CMD(0xAC, 0x40), - - _INIT_DCS_CMD(0x4D, 0x21), - _INIT_DCS_CMD(0x4E, 0x43), - _INIT_DCS_CMD(0x4F, 0x65), - _INIT_DCS_CMD(0x50, 0x87), - _INIT_DCS_CMD(0x51, 0x78), - _INIT_DCS_CMD(0x52, 0x56), - _INIT_DCS_CMD(0x53, 0x34), - _INIT_DCS_CMD(0x54, 0x21), - _INIT_DCS_CMD(0x55, 0x83), - _INIT_DCS_CMD(0x56, 0x08), - _INIT_DCS_CMD(0x58, 0x21), - _INIT_DCS_CMD(0x59, 0x40), - _INIT_DCS_CMD(0x5A, 0x00), - _INIT_DCS_CMD(0x5B, 0x2C), - _INIT_DCS_CMD(0x5E, 0x00, 0x10), - _INIT_DCS_CMD(0x5F, 0x00), - - _INIT_DCS_CMD(0x7A, 0x00), - _INIT_DCS_CMD(0x7B, 0x00), - _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(0xDA, 0x05), - _INIT_DCS_CMD(0xDB, 0x01), - _INIT_DCS_CMD(0xDC, 0x7A), - _INIT_DCS_CMD(0xDD, 0x55), - _INIT_DCS_CMD(0xDE, 0x27), - _INIT_DCS_CMD(0xDF, 0x01), - _INIT_DCS_CMD(0xE0, 0x7A), - _INIT_DCS_CMD(0xE1, 0x01), - _INIT_DCS_CMD(0xE2, 0x7A), - _INIT_DCS_CMD(0xE3, 0x01), - _INIT_DCS_CMD(0xE4, 0x7A), - _INIT_DCS_CMD(0xE5, 0x01), - _INIT_DCS_CMD(0xE6, 0x7A), - _INIT_DCS_CMD(0xE7, 0x00), - _INIT_DCS_CMD(0xE8, 0x00), - _INIT_DCS_CMD(0xE9, 0x01), - _INIT_DCS_CMD(0xEA, 0x7A), - _INIT_DCS_CMD(0xEB, 0x01), - _INIT_DCS_CMD(0xEE, 0x7A), - _INIT_DCS_CMD(0xEF, 0x01), - _INIT_DCS_CMD(0xF0, 0x7A), - - _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(0x13, 0x02), - _INIT_DCS_CMD(0x14, 0xDF), - _INIT_DCS_CMD(0xF1, 0x10), - _INIT_DCS_CMD(0x1E, 0x00), - _INIT_DCS_CMD(0x1F, 0x00), - _INIT_DCS_CMD(0x20, 0x2C), - _INIT_DCS_CMD(0x25, 0x00), - _INIT_DCS_CMD(0x26, 0x00), - _INIT_DCS_CMD(0x27, 0x2C), - _INIT_DCS_CMD(0x3F, 0x80), - _INIT_DCS_CMD(0x40, 0x00), - _INIT_DCS_CMD(0x43, 0x00), - - _INIT_DCS_CMD(0x44, 0x18), - _INIT_DCS_CMD(0x45, 0x00), - - _INIT_DCS_CMD(0x48, 0x00), - _INIT_DCS_CMD(0x49, 0x2C), - _INIT_DCS_CMD(0x5B, 0x80), - _INIT_DCS_CMD(0x5C, 0x00), - _INIT_DCS_CMD(0x5D, 0x00), - _INIT_DCS_CMD(0x5E, 0x00), - _INIT_DCS_CMD(0x61, 0x00), - _INIT_DCS_CMD(0x62, 0x2C), - _INIT_DCS_CMD(0x68, 0x10), - _INIT_DCS_CMD(0xFF, 0x26), - _INIT_DCS_CMD(0xFB, 0x01), - - _INIT_DCS_CMD(0x00, 0xA1), - _INIT_DCS_CMD(0x02, 0x31), - _INIT_DCS_CMD(0x0A, 0xF2), - _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(0x22, 0x00), - _INIT_DCS_CMD(0x23, 0x00), - _INIT_DCS_CMD(0x19, 0x0D), - _INIT_DCS_CMD(0x1A, 0x7F), - _INIT_DCS_CMD(0x1B, 0x0C), - _INIT_DCS_CMD(0x1C, 0xBF), - _INIT_DCS_CMD(0x2A, 0x0D), - _INIT_DCS_CMD(0x2B, 0x7F), - _INIT_DCS_CMD(0x20, 0x00), - - _INIT_DCS_CMD(0x1D, 0x00), - _INIT_DCS_CMD(0x1E, 0x78), - _INIT_DCS_CMD(0x1F, 0x78), - - _INIT_DCS_CMD(0x2F, 0x03), - _INIT_DCS_CMD(0x30, 0x78), - _INIT_DCS_CMD(0x33, 0x78), - _INIT_DCS_CMD(0x34, 0x66), - _INIT_DCS_CMD(0x35, 0x11), - - _INIT_DCS_CMD(0x39, 0x10), - _INIT_DCS_CMD(0x3A, 0x78), - _INIT_DCS_CMD(0x3B, 0x06), - - _INIT_DCS_CMD(0xC8, 0x04), - _INIT_DCS_CMD(0xC9, 0x84), - _INIT_DCS_CMD(0xCA, 0x4E), - _INIT_DCS_CMD(0xCB, 0x00), - - _INIT_DCS_CMD(0xA9, 0x50), - _INIT_DCS_CMD(0xAA, 0x4F), - _INIT_DCS_CMD(0xAB, 0x4D), - _INIT_DCS_CMD(0xAC, 0x4A), - _INIT_DCS_CMD(0xAD, 0x48), - _INIT_DCS_CMD(0xAE, 0x46), - _INIT_DCS_CMD(0xFF, 0x27), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0xC0, 0x18), - _INIT_DCS_CMD(0xC1, 0x00), - _INIT_DCS_CMD(0xC2, 0x00), - _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, 0x43), - _INIT_DCS_CMD(0x98, 0x01), - _INIT_DCS_CMD(0xB4, 0x03), - _INIT_DCS_CMD(0x9B, 0xBD), - _INIT_DCS_CMD(0xA0, 0x90), - _INIT_DCS_CMD(0xAB, 0x1B), - _INIT_DCS_CMD(0xBC, 0x0C), - _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, 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(0x64, 0x96), - _INIT_DCS_CMD(0x65, 0x00), - _INIT_DCS_CMD(0x66, 0x00), - _INIT_DCS_CMD(0x6A, 0x96), - _INIT_DCS_CMD(0x6B, 0x00), - _INIT_DCS_CMD(0x6C, 0x00), - _INIT_DCS_CMD(0x70, 0x92), - _INIT_DCS_CMD(0x71, 0x00), - _INIT_DCS_CMD(0x72, 0x00), - _INIT_DCS_CMD(0xA2, 0x33), - _INIT_DCS_CMD(0xA3, 0x30), - _INIT_DCS_CMD(0xA4, 0xC0), - _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, 0xF0), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x3A, 0x08), - _INIT_DCS_CMD(0xFF, 0xD0), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x00, 0x33), - _INIT_DCS_CMD(0x08, 0x01), - _INIT_DCS_CMD(0x09, 0xBF), - _INIT_DCS_CMD(0x2F, 0x33), - _INIT_DCS_CMD(0xFF, 0x23), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x00, 0x80), - _INIT_DCS_CMD(0x07, 0x00), - _INIT_DCS_CMD(0xFF, 0x20), - _INIT_DCS_CMD(0xFB, 0x01), - _INIT_DCS_CMD(0x30, 0x00), - _INIT_DCS_CMD(0xFF, 0x24), - _INIT_DCS_CMD(0x5C, 0x88), - _INIT_DCS_CMD(0x5D, 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(0xBB, 0x13), - _INIT_DCS_CMD(0x3B, 0x03, 0x96, 0x1A, 0x04, 0x04), - _INIT_DCS_CMD(0x35, 0x00), - _INIT_DCS_CMD(0x51, 0x0F, 0xFF), - _INIT_DCS_CMD(0x53, 0x24), - _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_DELAY_CMD(24), - _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), - {}, -}; +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 inline struct boe_panel *to_boe_panel(struct drm_panel *panel) + return 0; +} + +static int auo_kd101n80_45na_init(struct mipi_dsi_device *dsi) { - return container_of(panel, struct boe_panel, base); + int ret; + + 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 boe_panel_init_dcs_cmd(struct boe_panel *boe) +static int auo_b101uan08_3_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; - } - } - } + 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 starry_qfh032011_53g_init(struct mipi_dsi_device *dsi) +{ + 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 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; @@ -1373,10 +1349,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; @@ -1427,7 +1405,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 = { @@ -1456,7 +1434,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 = { @@ -1482,7 +1460,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, }; @@ -1509,7 +1487,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, }; @@ -1537,7 +1515,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 = { @@ -1564,7 +1542,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 = { @@ -1591,7 +1569,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, }; static const struct drm_display_mode starry_qfh032011_53g_default_mode = { @@ -1617,7 +1595,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 int boe_panel_get_modes(struct drm_panel *panel, From patchwork Thu Jun 15 20:21:38 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Linus Walleij X-Patchwork-Id: 108709 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:994d:0:b0:3d9:f83d:47d9 with SMTP id k13csp902472vqr; Thu, 15 Jun 2023 13:38:43 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4TQa3fEbf6IN113m3QK+CJRvmKNAVt9Emqv/BbOBQmbnx14ek3G6OheJXntJB9Rhv6tsZb X-Received: by 2002:a17:90a:9f89:b0:259:3cc4:f978 with SMTP id o9-20020a17090a9f8900b002593cc4f978mr55744pjp.19.1686861523330; Thu, 15 Jun 2023 13:38:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686861523; cv=none; d=google.com; s=arc-20160816; b=Qar4zC5VNWBYVtDahhKQXblCqwD5wwFtx9/AOwQBdgZ/hxHm9KPkyoVuFwTdI8A88l gNJF7vWtq6axFzln9Nzcuvvi+OqNpGYRyXKXMK3toiwGUBIUfR4fZ6VrDSquKDo4lu1Z o9q/EueMrt/PjMeDlDP1K0nzKdMmj3Oel16e4ydERzK+D+vzuYu3tydy1JwI41b5YLUm RdlslG2kJHB/eYQDmjlvAbALgkfbiSk0XmiqC1xagUdQSjRqHmD4iGNZJSSqdn8Kw/cD 8I+SLnVKijLMiwNmaaMPE1ZmwBsxTFq6r4aUmyBZgAYHAOVXNOyE3XMhTImryPN/jXCN HvIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:in-reply-to:references:message-id :content-transfer-encoding:mime-version:subject:date:from :dkim-signature; bh=kKBaB/9E61orl2m+5DjkcFtTpmNkTOXhn6/2KzxDt8E=; b=G4i8GeXTKdjjiNn0U8LN2lzaN8SIIGw/5YM9vgNz69UNWinbq0GIJeDPBxBR1QLIxN oAPaOxwhoIiF7OpbMJNg+js/DInzA+yJgMm2b8BG8JRiKmE+FQL82fB6HeQQVZ2Vmtnk UtnTKQwcM9bxy6aAyNmEHP2LlPh62BSRE/54PFx30oLbb2OTR4xegQl3nV5zGu91vc1H z5EqODg/QPoRbr3LyXSUT1wYyHrnaUss7JqaX6+PQcM0jt7QQVEDEXS4UKk1M4KHQEHs 5Y30ctzqv2hN2QeUu0ZP/2WwJzAM553DX38xYhdCh9Oy/CKNSz+AUK7/sTUAkjoTSpE3 0eyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="ooRn7P/3"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id fz12-20020a17090b024c00b0025bae7f2b10si137049pjb.13.2023.06.15.13.38.30; Thu, 15 Jun 2023 13:38:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="ooRn7P/3"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236818AbjFOUVw (ORCPT + 99 others); Thu, 15 Jun 2023 16:21:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43140 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232018AbjFOUVt (ORCPT ); Thu, 15 Jun 2023 16:21:49 -0400 Received: from mail-lf1-x136.google.com (mail-lf1-x136.google.com [IPv6:2a00:1450:4864:20::136]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 852592101 for ; Thu, 15 Jun 2023 13:21:47 -0700 (PDT) Received: by mail-lf1-x136.google.com with SMTP id 2adb3069b0e04-4f640e48bc3so11057015e87.2 for ; Thu, 15 Jun 2023 13:21:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1686860506; x=1689452506; 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=kKBaB/9E61orl2m+5DjkcFtTpmNkTOXhn6/2KzxDt8E=; b=ooRn7P/3nfvzdMKi01LrsE9k9ILxzSQBhQFr5AUVnFXqvhXiQGOtXZnyTeH3yPqOlG ME3qSxWOTsVIor8/HBW4rznQBIyB6wKPBaRAaZTw3vHGkBZ/A26f7x/LZGhPfVo60s/V Mk+svDS0wfQNBNGXA2Tgx0iMiIlph0XLSVv8lkn/ihlQ0LW9SWyZFsYrnJp06DpDNHO/ LqQLqpftykWL54nwlWYqrtVOeEMC+EaNsnKvf/KfifPXTtNZ/zf9u511maK1NNRv1IaS MqFCQ42lvHld/nar7kFhmpUh8sOicw4NYlt/IKtGF0kGQiAYvTR9ZuQCUuV8VHQzLVqO 5rnw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1686860506; x=1689452506; 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=kKBaB/9E61orl2m+5DjkcFtTpmNkTOXhn6/2KzxDt8E=; b=gDeqz/RiH7uPUewh1Q9DzklGC08fV9XDfPMez4zvECjZKiLpQjA+UwBKnY4QOZNLrh 7ZGz+rfhUOJHPmdArrCgbtzG1MPkSIrcvlDsC8KkEjm4iBmfcvIEIhMs7/OdCV8nhP3/ in0Sgwd1qUkxVPifGGzVZOoh5kzLe9Ft3m7atocpNNxlRFSHq26EktNknrPzKxRHAeTS u5KizV6eX/mlzh8aVT4HgzFww8G9kRf+PbTl0WYtcK5iSNfvPTZD01k7vA6AynbjNPU9 OQ8OjE8PNUtbyVSJplmyfEsN4XmpzZdd0NnFIZsQscbvBhD4Wp+PYOfk8gzYBxx04oFt LGPA== X-Gm-Message-State: AC+VfDz7Ah4uy+buqH0/DWmDMKTHJfs6pmN1YgjT2QehSALtnmWcdXiQ e8yhuKBkxBye0KPOn7UrmLZyxg== X-Received: by 2002:ac2:4985:0:b0:4f3:a485:919a with SMTP id f5-20020ac24985000000b004f3a485919amr10251508lfl.57.1686860505791; Thu, 15 Jun 2023 13:21:45 -0700 (PDT) Received: from [127.0.1.1] ([85.235.12.238]) by smtp.gmail.com with ESMTPSA id r14-20020ac252ae000000b004f3946030fasm2736470lfm.68.2023.06.15.13.21.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 15 Jun 2023 13:21:45 -0700 (PDT) From: Linus Walleij Date: Thu, 15 Jun 2023 22:21:38 +0200 Subject: [PATCH 2/2] drm/panel: boe-tv101wum-nl6: Drop surplus prepare tracking MIME-Version: 1.0 Message-Id: <20230615-fix-boe-tv101wum-nl6-v1-2-8ac378405fb7@linaro.org> References: <20230615-fix-boe-tv101wum-nl6-v1-0-8ac378405fb7@linaro.org> In-Reply-To: <20230615-fix-boe-tv101wum-nl6-v1-0-8ac378405fb7@linaro.org> To: Ruihai Zhou , Stephen Boyd , yangcong , Jitao Shi , Neil Armstrong , Sam Ravnborg , David Airlie , Daniel Vetter Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Linus Walleij X-Mailer: b4 0.12.1 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1768802508365776850?= X-GMAIL-MSGID: =?utf-8?q?1768802508365776850?= The DRM panel core already keeps track of if the panel is already prepared so do not reimplement this. Signed-off-by: Linus Walleij Reviewed-by: Sam Ravnborg --- 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 d19d30e134dd..412d4d99aec6 100644 --- a/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c +++ b/drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c @@ -50,8 +50,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) @@ -1286,9 +1284,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); @@ -1307,8 +1302,6 @@ static int boe_panel_unprepare(struct drm_panel *panel) regulator_disable(boe->pp3300); } - boe->prepared = false; - return 0; } @@ -1317,9 +1310,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); @@ -1357,8 +1347,6 @@ static int boe_panel_prepare(struct drm_panel *panel) } } - boe->prepared = true; - return 0; poweroff: