Received: by 10.223.176.5 with SMTP id f5csp352514wra; Tue, 30 Jan 2018 12:35:08 -0800 (PST) X-Google-Smtp-Source: AH8x227Gh/7y+SumG16i0snORtvCdxcfpmEYceqLupg4uvyw5ClXg0H86/9j/6VvQoY3D5VSRTTq X-Received: by 10.99.127.24 with SMTP id a24mr24681162pgd.225.1517344508792; Tue, 30 Jan 2018 12:35:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517344508; cv=none; d=google.com; s=arc-20160816; b=CdpCiYGu5wbqExC31T/2KiXxyriGpWVXL26AKzplL7uBMIGGVtafpIDzfQ+HfvoCIs egFKl3pgyd+91aS3Pmgd8QZez+Gipu8AzQuf0l18Q46YrikR6VcL6iyGkkvEfK/6pNOk d7CCC08YJzxtPtHjz/RCYJsbhOKgIbjwlMzJDvETn+tCWWsx7EP4YebgyLjd8GmeE2Wq Lqx1HNSECgqdcsXu8AJ2ljociPw+mXa7LOMcB0ZjoTGIooiDfx4f12w9u21RIuFD9pho 15/8j831Du52jFVkFWD7LZ4DdH2A7tV2baUlE9zP0+R84VYuyI23A9NaNPkNJW0Nz9hb NMNg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfert-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=5f2CmEgBZ8SIAYDaq/PnlWv9+h2aicfLQiRpxVldXwI=; b=RjK4PCitwrmej0j1acdv2VYc9BfOQlYlO0CD+Kzd2Pfi3nWM3nS4yYkBturRl7DGkS OWpyHaVF9FwSX2fUt8pfBeTkLOSgmzk79Dy3Zs230T+BetIKTkELy4kO7b4+c/cRHyB5 vg6uts34Jcd3HTcijwDqMaegKNTcoHq0LcAEMCcD4AncHi/QLs9x03ds/GWtqdOhR6LJ rmPtkZ7fIGXmqrVdL7nuCHev43FCtIiMAdsZSfodE+ZleD83Z0nrI7hB1vaQKPbXvpz2 jsrkoEi7BBVq4WMe6C3j+V5D9YdRCdkKSzPtamMXCdcSeBfTP5+8+3q8EeMwDRtSl2Hy gpPg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m21si2199024pgc.351.2018.01.30.12.34.54; Tue, 30 Jan 2018 12:35:08 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753373AbeA3Udw (ORCPT + 99 others); Tue, 30 Jan 2018 15:33:52 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:56444 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752820AbeA3U3y (ORCPT ); Tue, 30 Jan 2018 15:29:54 -0500 Received: from localhost.localdomain (unknown [IPv6:2a01:e35:8a7e:4790:1865:5d14:35de:d167]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: tescande) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id E842827418A; Tue, 30 Jan 2018 20:29:51 +0000 (GMT) From: Thierry Escande To: Archit Taneja , Inki Dae , Thierry Reding , Sandy Huang , Sean Paul , David Airlie , Tomasz Figa , Enric Balletbo i Serra Cc: Haixia Shi , =?UTF-8?q?=C3=98rjan=20Eide?= , Zain Wang , Yakir Yang , Lin Huang , Douglas Anderson , Mark Yao , linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, dri-devel@lists.freedesktop.org Subject: [PATCH v3 30/43] drm/bridge: analogix_dp: Reorder plat_data->power_off to happen sooner Date: Tue, 30 Jan 2018 21:29:00 +0100 Message-Id: <20180130202913.28724-31-thierry.escande@collabora.com> X-Mailer: git-send-email 2.14.1 In-Reply-To: <20180130202913.28724-1-thierry.escande@collabora.com> References: <20180130202913.28724-1-thierry.escande@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset = "utf-8" Content-Transfert-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Douglas Anderson The current user of the analogix power_off is "analogix_dp-rockchip". That driver does this: - deactivate PSR - turn off a clock Both of these things (especially deactive PSR) should be done before we turn the PHY power off and turn off analog power. Let's move the callback up. Note that without this patch (and with https://patchwork.kernel.org/patch/9553349/ [seanpaul: this patch was not applied, but it seems like the race can still occur]), I experienced an error in reboot testing where one thread was at: rockchip_drm_psr_deactivate rockchip_dp_powerdown analogix_dp_bridge_disable drm_bridge_disable ...and the other thread was at: analogix_dp_send_psr_spd analogix_dp_enable_psr analogix_dp_psr_set psr_flush_handler The flush handler thread was finding AUX channel errors and eventually reported "Failed to apply PSR", where I had a kgdb breakpoint. Presumably the device would have eventually given up and shut down anyway, but it seems better to fix the order to be more correct. Cc: Kristian H. Kristensen Signed-off-by: Douglas Anderson Signed-off-by: Sean Paul Signed-off-by: Thierry Escande Reviewed-by: Andrzej Hajda --- drivers/gpu/drm/bridge/analogix/analogix_dp_core.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c index f82e2a3d13bf..23404de7ffc9 100644 --- a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c +++ b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c @@ -1341,12 +1341,13 @@ static void analogix_dp_bridge_disable(struct drm_bridge *bridge) } disable_irq(dp->irq); - phy_power_off(dp->phy); - analogix_dp_set_analog_power_down(dp, POWER_ALL, 1); if (dp->plat_data->power_off) dp->plat_data->power_off(dp->plat_data); + phy_power_off(dp->phy); + analogix_dp_set_analog_power_down(dp, POWER_ALL, 1); + clk_disable_unprepare(dp->clock); pm_runtime_put_sync(dp->dev); -- 2.14.1