Received: by 10.223.185.116 with SMTP id b49csp3114072wrg; Mon, 5 Mar 2018 14:29:16 -0800 (PST) X-Google-Smtp-Source: AG47ELtSCslRI6KM+o6LC1zQ3timNZ9I6Bs29u7qFrV5I4cFmmEpxGGngWhRnOGoek0UP//Q7Ck8 X-Received: by 2002:a17:902:b416:: with SMTP id x22-v6mr14363548plr.279.1520288956190; Mon, 05 Mar 2018 14:29:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520288956; cv=none; d=google.com; s=arc-20160816; b=v4Ti0nz5hGZEtyz4jXoG2xTuNmkeSDQClQFFoqhRcCZMsn8QeWqtFqZn+WA5yxHGVr b1wOAdukFvxWZ3H5mVvZA13DeW/annsOSSrv7mrLC3QWDoCui9gYlooF0xhnNVnhFYA8 1ADGz92P51M7yHp1SLaAgjKSHdxQ3UnX4SL0P6jcfbrwNVzdE5DmmlBjvBLMMqx5h8PK C1bGbpLtFj4Rs2q7VilYrs8WZ3KuFlNNpcm5ReNPhNGGYtgabdRmlyXVqrcdXg+/sq0N DPFkmRhFoToIbgIB3zk6+yCJULA9TZ86gcYdj7liZ9aJ/oqjomlh35fx62n+OMgZQJlh +jiQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=1PTpuKHS8SJGD0WdjDHP8DjzrnSYsyQKz35qX+sfwm0=; b=u7wCveY83/RCt6iWkcU9eLksBgG2Jb0tWGoqgyBDWTHcjzvLJWNrwiDWW9G7iH/cz7 Ymks2uoR6dBZP2M3c39aKvZprFFkj/ahbrQrEhDgjCxo+Tu0tZjDqwMoicXeSQlEr/EK YZG0K8TAEj3I4rdWycbABXF0jjgNKsK0nU4osTjDuHcPtXuesk+vaH+xgDgBSIQaU/QQ nXggiZycmmdkRwojXtb6VLNTX5dXfyGPrIpYJbsIUaw0ggtGsosZaUU7MvSv1Ca74U6/ I7mwo9ho77EatxSBB8M+hlDVRo8kQillLYXdwD0eE0Z2Q9m2PBdhG278WLXLc/x/LpBs Ji/A== 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 z10si6409037pgz.781.2018.03.05.14.29.02; Mon, 05 Mar 2018 14:29:16 -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 S1753798AbeCEW00 (ORCPT + 99 others); Mon, 5 Mar 2018 17:26:26 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:37690 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753573AbeCEWYr (ORCPT ); Mon, 5 Mar 2018 17:24:47 -0500 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 5F1F1278317 From: Enric Balletbo i Serra To: architt@codeaurora.org, inki.dae@samsung.com, thierry.reding@gmail.com, hjc@rock-chips.com, seanpaul@chromium.org, airlied@linux.ie, tfiga@chromium.org, heiko@sntech.de Cc: hshi@chromium.org, wzz@rock-chips.com, hl@rock-chips.com, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, dianders@chromium.org, linux-rockchip@lists.infradead.org, orjan.eide@arm.com, m.szyprowski@samsung.com, "Kristian H . Kristensen" , Enric Balletbo i Serra Subject: [PATCH v4 26/38] drm/bridge: analogix_dp: Reorder plat_data->power_off to happen sooner Date: Mon, 5 Mar 2018 23:23:18 +0100 Message-Id: <20180305222324.5872-27-enric.balletbo@collabora.com> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180305222324.5872-1-enric.balletbo@collabora.com> References: <20180305222324.5872-1-enric.balletbo@collabora.com> 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 Signed-off-by: Enric Balletbo i Serra --- 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 e0f96ad4c700..edaca650e6d2 100644 --- a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c +++ b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c @@ -1337,12 +1337,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.16.1