Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp462829ybx; Wed, 6 Nov 2019 03:28:49 -0800 (PST) X-Google-Smtp-Source: APXvYqz7dJ4DoVTrYXLwVTOdoAH9iNmoT1CNn+PVqYi/nDvPQMcZYH2vfE1tdRWSdE5v8v3rvsTU X-Received: by 2002:a17:906:a388:: with SMTP id k8mr31284111ejz.223.1573039729523; Wed, 06 Nov 2019 03:28:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573039729; cv=none; d=google.com; s=arc-20160816; b=oSGXlOGCb5+R9KHz/Js4OE2Th6sMBokeIJM2OJ8F58Ifegm3LniCSlvvNDK/+5k80z 7/UV/uNxlzkoR6gNndvR+w6KX2JtkBCPDljRbtAFeT9l1RIcVTLcB0qhIAHrFJeAQaZL Gfi81DLv4TBMpd4/ODidyHhBz4sTW5YuxiZDKktaXyHswLtxFWoWbt7zZ1isjWtErjSl 0V8kRBot7S4h/cTgwU1jkujvVcZHPAU1gY/xDtAv/ztuYeOIMU3zLYC6liE6wE8TuQ7d RR/2umTaIXSTUn8JiDD2NkZdvrYU0Aagz+u2/kpRV6yWYXRXLMSXqlmVpusRLD7h+lTf 2kLg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=zeeCECcFHbJI7EzAMnlxUIMGYm4wnd3CYCv+bOns8dM=; b=OT86ZcMqxac8D5/9FS/pIHEY4zzM+M+9d/v5aLmIu+ykcgH9sxaY9URTqf08Y3ZMDV FEljg5yJHhetvc9zqgBZTReipD3uUhjTHiSFM775GpDh7zL8b5X3OXnCz7ZQ6tilIo3b MnRs488jc4dEkUglGcRPc+fONpficVagKquMx0jdZdBVJ9+nyeAP/bPy5AlneXgydEpq 99CAaA4zigKPDuwP5jQoWjyYBwesm2uVsHEwhrfofiUspeIOcKZdCYhcWAsfJlNgFkWy wgOFDRb/DFiNdp9xu7Zwjd/227nxAYvpBedrjIKkY/NGixLtzB7Jr1Fx3FbL30CXUbtu OtLg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v11si12499854edc.410.2019.11.06.03.28.26; Wed, 06 Nov 2019 03:28:49 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731684AbfKFL1Z (ORCPT + 99 others); Wed, 6 Nov 2019 06:27:25 -0500 Received: from gloria.sntech.de ([185.11.138.130]:53226 "EHLO gloria.sntech.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731154AbfKFL1W (ORCPT ); Wed, 6 Nov 2019 06:27:22 -0500 Received: from [94.134.91.181] (helo=phil.fritz.box) by gloria.sntech.de with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.89) (envelope-from ) id 1iSJSn-0004nK-1P; Wed, 06 Nov 2019 12:27:01 +0100 From: Heiko Stuebner To: dri-devel@lists.freedesktop.org, a.hajda@samsung.com Cc: hjc@rock-chips.com, robh+dt@kernel.org, mark.rutland@arm.com, narmstrong@baylibre.com, Laurent.pinchart@ideasonboard.com, jonas@kwiboo.se, jernej.skrabec@siol.net, philippe.cornu@st.com, yannick.fertre@st.com, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, heiko@sntech.de, christoph.muellner@theobroma-systems.com, Heiko Stuebner Subject: [PATCH 1/3] drm/bridge/synopsys: dsi: move phy_ops callbacks around panel enablement Date: Wed, 6 Nov 2019 12:26:48 +0100 Message-Id: <20191106112650.8365-1-heiko.stuebner@theobroma-systems.com> X-Mailer: git-send-email 2.23.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If implementation-specific phy_ops need to be defined they probably should be enabled before trying to talk to the panel and disabled only after the panel was disabled. Right now they are enabled last and disabled first, so might make it impossible to talk to some panels - example for this being the px30 with an external Innosilicon dphy that needs the phy to be enabled to transfer commands to the panel. So move the calls appropriately. Signed-off-by: Heiko Stuebner --- drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c b/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c index 675442bfc1bd..49f5600a1dea 100644 --- a/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c +++ b/drivers/gpu/drm/bridge/synopsys/dw-mipi-dsi.c @@ -797,9 +797,6 @@ static void dw_mipi_dsi_bridge_post_disable(struct drm_bridge *bridge) struct dw_mipi_dsi *dsi = bridge_to_dsi(bridge); const struct dw_mipi_dsi_phy_ops *phy_ops = dsi->plat_data->phy_ops; - if (phy_ops->power_off) - phy_ops->power_off(dsi->plat_data->priv_data); - /* * Switch to command mode before panel-bridge post_disable & * panel unprepare. @@ -816,6 +813,9 @@ static void dw_mipi_dsi_bridge_post_disable(struct drm_bridge *bridge) */ dsi->panel_bridge->funcs->post_disable(dsi->panel_bridge); + if (phy_ops->power_off) + phy_ops->power_off(dsi->plat_data->priv_data); + if (dsi->slave) { dw_mipi_dsi_disable(dsi->slave); clk_disable_unprepare(dsi->slave->pclk); @@ -882,6 +882,9 @@ static void dw_mipi_dsi_mode_set(struct dw_mipi_dsi *dsi, /* Switch to cmd mode for panel-bridge pre_enable & panel prepare */ dw_mipi_dsi_set_mode(dsi, 0); + + if (phy_ops->power_on) + phy_ops->power_on(dsi->plat_data->priv_data); } static void dw_mipi_dsi_bridge_mode_set(struct drm_bridge *bridge, @@ -898,15 +901,11 @@ static void dw_mipi_dsi_bridge_mode_set(struct drm_bridge *bridge, static void dw_mipi_dsi_bridge_enable(struct drm_bridge *bridge) { struct dw_mipi_dsi *dsi = bridge_to_dsi(bridge); - const struct dw_mipi_dsi_phy_ops *phy_ops = dsi->plat_data->phy_ops; /* Switch to video mode for panel-bridge enable & panel enable */ dw_mipi_dsi_set_mode(dsi, MIPI_DSI_MODE_VIDEO); if (dsi->slave) dw_mipi_dsi_set_mode(dsi->slave, MIPI_DSI_MODE_VIDEO); - - if (phy_ops->power_on) - phy_ops->power_on(dsi->plat_data->priv_data); } static enum drm_mode_status -- 2.23.0