Received: by 10.223.176.5 with SMTP id f5csp356142wra; Tue, 30 Jan 2018 12:39:07 -0800 (PST) X-Google-Smtp-Source: AH8x224QlQmWWCo9j6jAWFAtLEIVAtBxps0S30AI6wVV4Aktz8OTvs62HHxLMvZ3SXSRySUQQO1q X-Received: by 10.99.102.193 with SMTP id a184mr8203237pgc.141.1517344747151; Tue, 30 Jan 2018 12:39:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517344747; cv=none; d=google.com; s=arc-20160816; b=sGAPNFsL4pTjLQbJ4o4XO7Uj1zwDxDtOBQ6dJ9YrQ3s/7+KNsuX93705k83UeYhMrX HtS5togJ1p3AdGTyZDIT+6otIqL+bboSoNPGn+jep78wozd9R4Ye2/TeY3mVXvN1AANF BtkipqApVhPYB3d4Zyx5OcbcB6/PiNLeHy9x3tex4rcWvK0Ot2E9A2fZalo41Q2KDd5v oGQj7koZQ7P7x3Gr2zSYCdugq3KA/C8+CPt6diSY9czwYbRGICRfDiGtHW0+o4jqGItQ gOHcUYCwR8hoKY4sHWlFxutjt7V1YbNHLk+MnNBDZXBJcQqXK2rCoDn+bv80+Vys5sI4 9aFQ== 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 :content-transfert-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:arc-authentication-results; bh=BE3fsTcj0fej6MN9VGYXudT/3NzUGT+LkSv1KJfiJuo=; b=org8AqT8ElThaI/gzgksiiNYzV6DoELT8zg+blAz9EIa3HwMwpUr7tVJcvw13DXQg4 E9Ln0221DlJAMVZ88hUYjWTm5ZBjxciq4m2EZk5WaZy6gl0HeyLVyQqXkyJA2Hnzk5c4 zoARkReqJbjKdAetfwTNBQxD/Z+kv1LtNOmbZ+CxyQH55R3dEsmzeAKbiyE2/jtfI79w 3M7AJFOV56n531ZlPUyWnOpwVvLH107IT3BRuxZwOwPkqAi7te8HIH6yhsjUAyrF0wNm qu/bIYX1c8QNCGQKyZxy/LQQRRPzJNycwrImaoNq1m2xzKGZSeNmvc4g9JGrWVGuWiNq Gjsg== 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 e3-v6si287040plk.542.2018.01.30.12.38.44; Tue, 30 Jan 2018 12:39:07 -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 S1753369AbeA3Uhm (ORCPT + 99 others); Tue, 30 Jan 2018 15:37:42 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:56168 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752450AbeA3U3k (ORCPT ); Tue, 30 Jan 2018 15:29:40 -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 6ABDA273E49; Tue, 30 Jan 2018 20:29:38 +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 15/43] drm/bridge: analogix_dp: Don't use fast link training when panel just powered up Date: Tue, 30 Jan 2018 21:28:45 +0100 Message-Id: <20180130202913.28724-16-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-Type: text/plain; charset = "utf-8" Content-Transfert-Encoding: 8bit Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: zain wang Panel would reset its setting when it powers down. It would forget the last succeeded link training setting. So we can't use the last successful link training setting to do fast link training. Let's reset fast_train_enable in analogix_dp_bridge_disable(); Cc: Stéphane Marchesin Signed-off-by: zain wang Signed-off-by: Sean Paul Signed-off-by: Thierry Escande --- drivers/gpu/drm/bridge/analogix/analogix_dp_core.c | 9 +++++---- drivers/gpu/drm/bridge/analogix/analogix_dp_core.h | 2 +- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c index 8ef9e31c6713..179c2106b8a2 100644 --- a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c +++ b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c @@ -579,14 +579,14 @@ static int analogix_dp_process_equalizer_training(struct analogix_dp_device *dp) if (retval != 1) { dev_err(dp->dev, "failed to read downspread %d\n", retval); - dp->fast_train_support = false; + dp->fast_train_enable = false; } else { - dp->fast_train_support = + dp->fast_train_enable = (spread & DP_NO_AUX_HANDSHAKE_LINK_TRAINING) ? true : false; } dev_dbg(dp->dev, "fast link training %s\n", - dp->fast_train_support ? "supported" : "unsupported"); + dp->fast_train_enable ? "supported" : "unsupported"); /* set enhanced mode if available */ analogix_dp_set_enhanced_mode(dp); @@ -793,7 +793,7 @@ static int analogix_dp_fast_link_train(struct analogix_dp_device *dp) static int analogix_dp_train_link(struct analogix_dp_device *dp) { - if (dp->fast_train_support) + if (dp->fast_train_enable) return analogix_dp_fast_link_train(dp); return analogix_dp_full_link_train(dp, dp->video_info.max_lane_count, @@ -1198,6 +1198,7 @@ static void analogix_dp_bridge_disable(struct drm_bridge *bridge) DRM_ERROR("failed to setup the panel ret = %d\n", ret); dp->psr_enable = false; + dp->fast_train_enable = false; dp->dpms_mode = DRM_MODE_DPMS_OFF; } diff --git a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.h b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.h index 6a96ef7e6934..403ff853464b 100644 --- a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.h +++ b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.h @@ -173,7 +173,7 @@ struct analogix_dp_device { int hpd_gpio; bool force_hpd; bool psr_enable; - bool fast_train_support; + bool fast_train_enable; struct mutex panel_lock; bool panel_is_modeset; -- 2.14.1