Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2976614imu; Mon, 19 Nov 2018 08:52:56 -0800 (PST) X-Google-Smtp-Source: AJdET5e7jA1mQXF6sOkl4fpthdZQOgw8B2ONplNJYbDxguhwGd3+bfJc73VjpE8B2SgrmZtS8Bf5 X-Received: by 2002:a65:4904:: with SMTP id p4mr20945432pgs.384.1542646376018; Mon, 19 Nov 2018 08:52:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542646375; cv=none; d=google.com; s=arc-20160816; b=VooRUuEKhebgavbPuOTLVyoZ01Q75CuyXfSLFCltWGmvku1NWWwNP/0J9TAUlFqIEl OliihYKhHUdQv0U2nowAlr6xpn25t6GWi6auKTl7BP2HEH0gX1QnlnzLnwmHtXzPk4c+ 1URkQoyCHn+6qHmJ9QJP7zoBb5jE2ivE4TxE5rJ/pdLGFs3AC+fkzCJ66hA3iV9ApsE9 5PWzB7/qo79BRLFURDdE0PDe1ag3wlL9sgZZp3dzxhWbLrL6K4J69KM3cfMU1s2fQAwA akylb/5EYLIvtV8J74LQZG+npHh+jkYJYnzdUWPy8T94nn0qufp8s+Y4i+wf2J3bnZQ+ +g/w== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=a1tvUpJRuwPhR6CiTKxkZe3qYoMKrXWtuz3NWTRIa1A=; b=f7yBIydfCgo4Q/1nVge1o9oTyCJgzIcLPrSWve6ZUvNExiknhX85y5jPgvFoi/bvqK krOG5bBPF+9AC4W33WwZJauJd9Ii114Pd5xMpjzZaCyGDh57pwsvp9tpRUbyrC6XtLDf g79y7j99ABaJKmcL3lQqAfKVT9RxYBgJY5+MS8aJA8LQHJlW/5chHdqA8zWWLGo+ovXv s5Ewdsiy9mjmUw8fmayQBOrLXkCqRNx2gU/UcQ3LPbZVPZqVIpjpIuB/1YgPwepXQ7/k raoJgbTCXuspKqwNUl2U9O+YHJ4Xyf6XiYVkUSs9SMJ3tY1io5mM/11zpLvWIvsDX7c0 bbYA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s5fPi5xa; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d12si30006929pln.340.2018.11.19.08.52.41; Mon, 19 Nov 2018 08:52: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; dkim=pass header.i=@kernel.org header.s=default header.b=s5fPi5xa; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390398AbeKTDP7 (ORCPT + 99 others); Mon, 19 Nov 2018 22:15:59 -0500 Received: from mail.kernel.org ([198.145.29.99]:53760 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389340AbeKTDP7 (ORCPT ); Mon, 19 Nov 2018 22:15:59 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0B6FE208E3; Mon, 19 Nov 2018 16:51:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542646305; bh=zDfXCrV9N5MfZYEtgZMBxN+xafpQb8Fk61xMMwv1W/g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=s5fPi5xaFt273HYr3YpMIAsZKsC2Q2dx5ic0ebXNF+D59KTyvNnZyX00clGSr53zy 3LyeFTU6gieov89SX92nGRurNM/xC8HyhA46d86XyQfi+ZqIT0bnR8u5CPH08Cby2h 93M8HxE92td5Kc8a6H07raig7RWVjF6ay4qKiyo0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lyude Paul , Daniel Vetter , Rodrigo Vivi Subject: [PATCH 4.14 113/124] drm/i915: Dont unset intel_connector->mst_port Date: Mon, 19 Nov 2018 17:29:27 +0100 Message-Id: <20181119162632.963867312@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162612.951907286@linuxfoundation.org> References: <20181119162612.951907286@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review 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 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Lyude Paul commit 80c188695a77eddaa6e8885510ff4ef59fd478c3 upstream. Currently we set intel_connector->mst_port to NULL to signify that the MST port has been removed from the system so that we can prevent further action on the port such as connector probes, mode probing, etc. However, we're going to need access to intel_connector->mst_port in order to fixup ->best_encoder() so that it can always return the correct encoder for an MST port to prevent legacy DPMS prop changes from failing. This should be safe, so instead keep intel_connector->mst_port always set and instead just check the status of drm_connector->regustered to signify whether or not the connector has disappeared from the system. Changes since v2: - Add a comment to mst_port_gone (Jani Nikula) - Change mst_port_gone to a u8 instead of a bool, per the kernel bot. Apparently bool is discouraged in structs these days Changes since v4: - Don't use mst_port_gone at all! Just check if the connector is registered or not - Daniel Vetter Signed-off-by: Lyude Paul Reviewed-by: Daniel Vetter Cc: stable@vger.kernel.org Link: https://patchwork.freedesktop.org/patch/msgid/20181008232437.5571-4-lyude@redhat.com (cherry picked from commit 6ed5bb1fbad34382c8cfe9a9bf737e9a43053df5) Signed-off-by: Rodrigo Vivi Signed-off-by: Greg Kroah-Hartman --- drivers/gpu/drm/i915/intel_dp_mst.c | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) --- a/drivers/gpu/drm/i915/intel_dp_mst.c +++ b/drivers/gpu/drm/i915/intel_dp_mst.c @@ -311,9 +311,8 @@ static int intel_dp_mst_get_ddc_modes(st struct edid *edid; int ret; - if (!intel_dp) { + if (!READ_ONCE(connector->registered)) return intel_connector_update_modes(connector, NULL); - } edid = drm_dp_mst_get_edid(connector, &intel_dp->mst_mgr, intel_connector->port); ret = intel_connector_update_modes(connector, edid); @@ -328,9 +327,10 @@ intel_dp_mst_detect(struct drm_connector struct intel_connector *intel_connector = to_intel_connector(connector); struct intel_dp *intel_dp = intel_connector->mst_port; - if (!intel_dp) + if (!READ_ONCE(connector->registered)) return connector_status_disconnected; - return drm_dp_mst_detect_port(connector, &intel_dp->mst_mgr, intel_connector->port); + return drm_dp_mst_detect_port(connector, &intel_dp->mst_mgr, + intel_connector->port); } static void @@ -370,7 +370,7 @@ intel_dp_mst_mode_valid(struct drm_conne int bpp = 24; /* MST uses fixed bpp */ int max_rate, mode_rate, max_lanes, max_link_clock; - if (!intel_dp) + if (!READ_ONCE(connector->registered)) return MODE_ERROR; max_link_clock = intel_dp_max_link_rate(intel_dp); @@ -399,7 +399,7 @@ static struct drm_encoder *intel_mst_ato struct intel_dp *intel_dp = intel_connector->mst_port; struct intel_crtc *crtc = to_intel_crtc(state->crtc); - if (!intel_dp) + if (!READ_ONCE(connector->registered)) return NULL; return &intel_dp->mst_encoders[crtc->pipe]->base.base; } @@ -491,7 +491,6 @@ static void intel_dp_register_mst_connec static void intel_dp_destroy_mst_connector(struct drm_dp_mst_topology_mgr *mgr, struct drm_connector *connector) { - struct intel_connector *intel_connector = to_intel_connector(connector); struct drm_i915_private *dev_priv = to_i915(connector->dev); drm_connector_unregister(connector); @@ -499,10 +498,6 @@ static void intel_dp_destroy_mst_connect if (dev_priv->fbdev) drm_fb_helper_remove_one_connector(&dev_priv->fbdev->helper, connector); - /* prevent race with the check in ->detect */ - drm_modeset_lock(&connector->dev->mode_config.connection_mutex, NULL); - intel_connector->mst_port = NULL; - drm_modeset_unlock(&connector->dev->mode_config.connection_mutex); drm_connector_unreference(connector); DRM_DEBUG_KMS("\n");