Received: by 10.223.185.111 with SMTP id b44csp823151wrg; Fri, 9 Mar 2018 14:33:55 -0800 (PST) X-Google-Smtp-Source: AG47ELtCUWxrdRrpQrPToLX4KPV+rw7lRTmUl3eMrDNnqdLAl82nojXuYJsxqOHuKPNKob20PAyY X-Received: by 10.101.99.18 with SMTP id g18mr57987pgv.436.1520634835626; Fri, 09 Mar 2018 14:33:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520634835; cv=none; d=google.com; s=arc-20160816; b=MO/rWI5MTVU4FON/5NtJUFl4VHnhI7RfnWxAzVYBa3/4RqSiiJqJzmUK3Za3CsXiSY e7o0ZYE9ST74IValE8SKoVt5gplcCUYjcNxfxKzDq8bKcRHpyOi30xFOvp2kT5dTotTw dk3RhCs0SmXRhcSgQ+TmOXP3L5wWoLKaRbCUZj2IjxxwmNKXfTmnfhJtvQxQ6VSS0YZb AyppsAxhStd44FOBVIqWjVnbC8+RONDvJEhSV5bBio0Hyt0klNNRHZ8gnS4bwlafGLUM OqrYcmdXdceyOtzPu9AiLXFDBr6tbj0CahjkWagjUemIHQ10uu3FJV+AohFsUZmwwmfv XMvA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=lSD8ervQK5Cy6caamjmFTSwZE3uXpZxUMi0ky9/s5Es=; b=zbpls95Ncx0Fk+dYDHvb96tgSHbwQRHYYZxmGyVYIr16SpVCWlvfh/ZXypKgLuu86Y 0pwjAriSJpxpXpHAulKzxvWlkIiSKm/oVLvnZ6FW5/aOywhz8PA3/uwp6AhBRZcVLDy4 4GTMv+2dtnVUa+buKbawPnUu/6O74cju00DgOry7tjxowV5+0cPELq5pVp8POjDhw6YK SuW0LLa5gfeGjr/s30cBI/SWY3RCO92E1z6V4QazhqaNovC2Mhd4+2ICReMJsSKJNKkv DyMf4vuB42Jdn2PS8fykkztYN766hiYZ5BZImFHK8UFli5Gq7GWBNNS4KDEAhCc5Yhxg T2bA== 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 u5-v6si1582445plz.165.2018.03.09.14.33.41; Fri, 09 Mar 2018 14:33:55 -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 S932942AbeCIWcx (ORCPT + 99 others); Fri, 9 Mar 2018 17:32:53 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:42426 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932859AbeCIWYI (ORCPT ); Fri, 9 Mar 2018 17:24:08 -0500 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 5ADDE275618 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: dri-devel@lists.freedesktop.org, dianders@chromium.org, a.hajda@samsung.com, ykk@rock-chips.com, kernel@collabora.com, m.szyprowski@samsung.com, linux-samsung-soc@vger.kernel.org, jy0922.shim@samsung.com, rydberg@bitmath.org, krzk@kernel.org, linux-rockchip@lists.infradead.org, kgene@kernel.org, linux-input@vger.kernel.org, orjan.eide@arm.com, wxt@rock-chips.com, jeffy.chen@rock-chips.com, linux-arm-kernel@lists.infradead.org, mark.yao@rock-chips.com, wzz@rock-chips.com, hl@rock-chips.com, jingoohan1@gmail.com, sw0312.kim@samsung.com, linux-kernel@vger.kernel.org, kyungmin.park@samsung.com, Laurent.pinchart@ideasonboard.com, kuankuan.y@gmail.com, hshi@chromium.org, =?UTF-8?q?St=C3=A9phane=20Marchesin?= , Enric Balletbo i Serra Subject: [PATCH v5 09/36] drm/bridge: analogix_dp: Don't use fast link training when panel just powered up Date: Fri, 9 Mar 2018 23:23:00 +0100 Message-Id: <20180309222327.18689-10-enric.balletbo@collabora.com> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180309222327.18689-1-enric.balletbo@collabora.com> References: <20180309222327.18689-1-enric.balletbo@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 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 Signed-off-by: Enric Balletbo i Serra Tested-by: Marek Szyprowski --- 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 f9661b410cb9..ea7a80a989c6 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, @@ -1197,6 +1197,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.16.1