Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp9287670pxu; Mon, 28 Dec 2020 11:28:00 -0800 (PST) X-Google-Smtp-Source: ABdhPJwk17ZblTeRVgNzW94p1/yVxygXp1JD3Y7JvUocD5IiHC57ZgY14N9GpwpnRG2MqwgBOUzA X-Received: by 2002:a05:6402:746:: with SMTP id p6mr43768414edy.313.1609183679800; Mon, 28 Dec 2020 11:27:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609183679; cv=none; d=google.com; s=arc-20160816; b=n8HKmHRVPzooiJWT3K4/W9sZKggRBCj7iBl2Wm6CjlmaMm5e36QXtCVkIXthhDnukW Fgc0kjYBfy8ue7EjNGjsgWyhtlS2dtXr3C+Laie1sNJarOWDKEQSuWnfmzfDinclUkuN SfNKW6u0cHA4dvn7S8rwD2Vp/9jphYp41JChrFo+bzA7aNjpZBWbDni/qW6dhw4y0qoI dWDXvdIdwQ3/t+KmyZEjtCLgpZeH9SoZx5GwXpKS2NzBiZNiWyOEai7dFKqv07KuOb9A XRDbfxn8zumeINHKAcbbAGUOMPbfP8e+Q47eXp9x49WjGdOzikjZnzO1uCr+jYeCzAIP YNMQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=/VMSZDguD6sqMTHBsud5Gdu8EozxCyVrec7ldK7ZYNc=; b=yY3uGT5X89hZ7ZtDSBWwi+n7eKyN2UaUyVaGZlNRYZaYpERRUEXYCbpHeUz2Typu6G m8XdhXqZroLuCFCCvKtzyOZAh1XF/LJxcmfGJS0H61HoB9lRmC1u1WY8nqTxdsDHHsXz DWNEpLMI3R3GPoALGeFLfaC4U91wHSpnnyA+FWBMNQ1PfsjaVeVuxHphTfECkoSm8hrv p9xvy3s9rQnuZFQ2tXs7KiR1ifLhtRIFETqf1tRhg6Ol1TSR6zZ+2tz8D6eORZeyqOzd NSnf+F96pvDflUFTBhLTDcMZcAy/au23BDl8h5c3eepTWwVqjRL1ba4OVUp2T21bJQvI r4EA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=D8Os9tqn; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f14si19065435ejb.79.2020.12.28.11.27.37; Mon, 28 Dec 2020 11:27:59 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=D8Os9tqn; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2436979AbgL1OCq (ORCPT + 99 others); Mon, 28 Dec 2020 09:02:46 -0500 Received: from mail.kernel.org ([198.145.29.99]:35908 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2436926AbgL1OCj (ORCPT ); Mon, 28 Dec 2020 09:02:39 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id ABB4C20799; Mon, 28 Dec 2020 14:02:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1609164144; bh=DKwu98r1K7Z9QKiOI5WH4uYFgtW/cWIUVQjOIqVzCQ8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=D8Os9tqnkQimS/Z2WWEerK/u4fGb7T4Or4gJaTKSRAwYEcTvfrQSRfIxPfylijxyJ f0a/G8PXJnTXpCJwYwZyGHKH4FCTFoOKFLHtD25uVZebSIPs+gAH2Ls/F+wvOX1vyn ruw9UP7RWWape6UvvkLRzOMRqmHKx8cdmLVYBtZM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tanmay Shah , Stephen Boyd , Rob Clark , Sasha Levin Subject: [PATCH 5.10 046/717] drm/msm/dp: DisplayPort PHY compliance tests fixup Date: Mon, 28 Dec 2020 13:40:44 +0100 Message-Id: <20201228125023.195997830@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201228125020.963311703@linuxfoundation.org> References: <20201228125020.963311703@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tanmay Shah [ Upstream commit 6625e2637d93d2f52ef0d17656f21bfa2cb4983a ] Bandwidth code was being used as test link rate. Fix this by converting bandwidth code to test link rate Do not reset voltage and pre-emphasis level during IRQ HPD attention interrupt. Also fix pre-emphasis parsing during test link status process Signed-off-by: Tanmay Shah Fixes: 8ede2ecc3e5e ("drm/msm/dp: Add DP compliance tests on Snapdragon Chipsets") Reviewed-by: Stephen Boyd Signed-off-by: Rob Clark Signed-off-by: Sasha Levin --- drivers/gpu/drm/msm/dp/dp_ctrl.c | 3 --- drivers/gpu/drm/msm/dp/dp_display.c | 1 + drivers/gpu/drm/msm/dp/dp_link.c | 12 +++++++++++- drivers/gpu/drm/msm/dp/dp_link.h | 1 + 4 files changed, 13 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/msm/dp/dp_ctrl.c b/drivers/gpu/drm/msm/dp/dp_ctrl.c index 2e3e1917351f0..872b12689e317 100644 --- a/drivers/gpu/drm/msm/dp/dp_ctrl.c +++ b/drivers/gpu/drm/msm/dp/dp_ctrl.c @@ -1643,9 +1643,6 @@ int dp_ctrl_on_link(struct dp_ctrl *dp_ctrl) if (rc) return rc; - ctrl->link->phy_params.p_level = 0; - ctrl->link->phy_params.v_level = 0; - while (--link_train_max_retries && !atomic_read(&ctrl->dp_ctrl.aborted)) { rc = dp_ctrl_reinitialize_mainlink(ctrl); diff --git a/drivers/gpu/drm/msm/dp/dp_display.c b/drivers/gpu/drm/msm/dp/dp_display.c index e175aa3fd3a93..ae9989ece73f4 100644 --- a/drivers/gpu/drm/msm/dp/dp_display.c +++ b/drivers/gpu/drm/msm/dp/dp_display.c @@ -335,6 +335,7 @@ static int dp_display_process_hpd_high(struct dp_display_private *dp) dp->dp_display.max_pclk_khz = DP_MAX_PIXEL_CLK_KHZ; dp->dp_display.max_dp_lanes = dp->parser->max_dp_lanes; + dp_link_reset_phy_params_vx_px(dp->link); rc = dp_ctrl_on_link(dp->ctrl); if (rc) { DRM_ERROR("failed to complete DP link training\n"); diff --git a/drivers/gpu/drm/msm/dp/dp_link.c b/drivers/gpu/drm/msm/dp/dp_link.c index c811da515fb3b..49d7fad36fc4e 100644 --- a/drivers/gpu/drm/msm/dp/dp_link.c +++ b/drivers/gpu/drm/msm/dp/dp_link.c @@ -869,6 +869,9 @@ static int dp_link_parse_vx_px(struct dp_link_private *link) drm_dp_get_adjust_request_voltage(link->link_status, 0); link->dp_link.phy_params.p_level = drm_dp_get_adjust_request_pre_emphasis(link->link_status, 0); + + link->dp_link.phy_params.p_level >>= DP_TRAIN_PRE_EMPHASIS_SHIFT; + DRM_DEBUG_DP("Requested: v_level = 0x%x, p_level = 0x%x\n", link->dp_link.phy_params.v_level, link->dp_link.phy_params.p_level); @@ -911,7 +914,8 @@ static int dp_link_process_phy_test_pattern_request( link->request.test_lane_count); link->dp_link.link_params.num_lanes = link->request.test_lane_count; - link->dp_link.link_params.rate = link->request.test_link_rate; + link->dp_link.link_params.rate = + drm_dp_bw_code_to_link_rate(link->request.test_link_rate); ret = dp_link_parse_vx_px(link); @@ -1156,6 +1160,12 @@ int dp_link_adjust_levels(struct dp_link *dp_link, u8 *link_status) return 0; } +void dp_link_reset_phy_params_vx_px(struct dp_link *dp_link) +{ + dp_link->phy_params.v_level = 0; + dp_link->phy_params.p_level = 0; +} + u32 dp_link_get_test_bits_depth(struct dp_link *dp_link, u32 bpp) { u32 tbd; diff --git a/drivers/gpu/drm/msm/dp/dp_link.h b/drivers/gpu/drm/msm/dp/dp_link.h index 49811b6221e53..9dd4dd9265304 100644 --- a/drivers/gpu/drm/msm/dp/dp_link.h +++ b/drivers/gpu/drm/msm/dp/dp_link.h @@ -135,6 +135,7 @@ static inline u32 dp_link_bit_depth_to_bpc(u32 tbd) } } +void dp_link_reset_phy_params_vx_px(struct dp_link *dp_link); u32 dp_link_get_test_bits_depth(struct dp_link *dp_link, u32 bpp); int dp_link_process_request(struct dp_link *dp_link); int dp_link_get_colorimetry_config(struct dp_link *dp_link); -- 2.27.0