Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp115065imm; Fri, 5 Oct 2018 00:27:22 -0700 (PDT) X-Google-Smtp-Source: ACcGV61zmRBPV9ISjJ3BNg45KPukI0l31qfApEON29jWZsrjFO6KcJbUO1P+FEs84fv7gAJ729NM X-Received: by 2002:a63:e54d:: with SMTP id z13-v6mr8938480pgj.169.1538724441947; Fri, 05 Oct 2018 00:27:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538724441; cv=none; d=google.com; s=arc-20160816; b=LtjoN4cgSjjyT2fe0Tvew6yYq28LVN/5XH+vEp8CjzIUGx0aUBxfYytdOsl5yN/EkD SHouT3tAKMTmBjjBYn5ZxtMhJv6on8AqyB9JeCLYxsKvVFtjmq1KMogeEKtNJ7vlOsk3 DekAlFxSsY2Ra+x8Q7zgsgiDa9TaWJJY7nqGsTU16bKYK5lHDiVgFYArxp3nQus+cAOI jnvHn7IOIuHvqOPyu8U8PZyZTVt8GRt3fDNLXPsjr3ApbevRjy4j5n7ho0Kdvt+FvPCt DDEeGwaOnbw1SgLDamBoUmSzRfMiGSZHFK3C7avqrqfd8S2Dlnen6+2ljDKx0pMSDxi+ DITw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature; bh=IIMDmP0Lt+tsl8HV8fvPT4gsIWb6rH5O1sMK5wMxZrs=; b=0DdtMWzN1iq4XJT3Za1Q9oTI1WDDWXuoA96/mRGiTqL9tDKHOT3Dtq/WtW8rS5Xr/A j5UbCAZqMVuT2p+0onF8nLveC75klzP3N1USQFSR1wJsAiUIwxJdw3GuZbcdss/jAPJz nWBdR+N2leqwLgtKajPYGqSE0TbjMQ+HP5732vtP/BthsEPf+tiln7EgQ0FNexnVAfhd 6fzxf0qjZBTcsr/WBYV4yhMnBC6bWcxl/E4iF7gRUNhhPD6/qtwZRT/8PG+Me0Uxgg5Q /s4naRG5RK1Lpo0XwUbE5w9EzqjYxEoK1FIvoKQbG4KSRYxDGPigptwWS9wHEZxzgzue Vn9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=PyoqxawH; 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 w6-v6si6751434pgp.42.2018.10.05.00.27.05; Fri, 05 Oct 2018 00:27:21 -0700 (PDT) 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=fail header.i=@ffwll.ch header.s=google header.b=PyoqxawH; 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 S1728279AbeJEOYQ (ORCPT + 99 others); Fri, 5 Oct 2018 10:24:16 -0400 Received: from mail-ed1-f65.google.com ([209.85.208.65]:45225 "EHLO mail-ed1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728046AbeJEOYQ (ORCPT ); Fri, 5 Oct 2018 10:24:16 -0400 Received: by mail-ed1-f65.google.com with SMTP id v18-v6so9708171edq.12 for ; Fri, 05 Oct 2018 00:26:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=sender:date:from:to:cc:subject:message-id:mail-followup-to :references:mime-version:content-disposition:in-reply-to:user-agent; bh=IIMDmP0Lt+tsl8HV8fvPT4gsIWb6rH5O1sMK5wMxZrs=; b=PyoqxawHu4f6vaDG8TF3O6bq4gqZYMVgTBDXabvNC5gr4jWt6iY7XlHE2anMAWIl2b 5LV+1Hf/lx2dUWBuaT1Q/l/SXKCQyj/ha4V7x7bwn09giHRhqrtC4Ch6HOxO7DxFBG/Z 8gCZpYf3Umqxo75734vmIRH3mFf/U2fpBvqT8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to:user-agent; bh=IIMDmP0Lt+tsl8HV8fvPT4gsIWb6rH5O1sMK5wMxZrs=; b=I1LMZbw8n0Ag9trqWGsQw2paqT6PtRnhrhyjpBHfVN5CtX94cONbQbj91nmy58rYa/ kfZ4mbjnXq1R4sEVNEEvWA7KwRtlyErbIAqfiQaaSZqWiV2h+uEmJVLfN9me/tI0VKCv o8p9GPO2klobcirF61XQL1ihdoNHOikqzFZB4CN9KlkM+eoWfUPvlvATiByunx3CHHgz SEs2iC+xtY9I1xLP/GsVHiNJECSx3/4ZhAEnmS4JQPbaFAcRu+WW429PMRCLWt99pIBh 69Hrczd2MpED7s0Lcve8K/BPKvt5omv5yGrUx4rYg7OyLw3kIO6T466v3PwIV7L23/3A 3LNQ== X-Gm-Message-State: ABuFfogTqQxZG9dRxUVXAz2CkfW4RMe2kdXBu8uDarlsZ0NHafsqtR1Y psyxYVVjs0q7gmNEUEULvRycjA== X-Received: by 2002:a50:a2a6:: with SMTP id 35-v6mr12677576edm.276.1538724409638; Fri, 05 Oct 2018 00:26:49 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:569e:0:3106:d637:d723:e855]) by smtp.gmail.com with ESMTPSA id h34-v6sm2232339eda.58.2018.10.05.00.26.47 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 05 Oct 2018 00:26:47 -0700 (PDT) Date: Fri, 5 Oct 2018 09:26:45 +0200 From: Daniel Vetter To: Lyude Paul Cc: nouveau@lists.freedesktop.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, Daniel Vetter , Jani Nikula , stable@vger.kernel.org, Joonas Lahtinen , Rodrigo Vivi , David Airlie , linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 4/5] drm/i915: Skip vcpi allocation for MSTB ports that are gone Message-ID: <20181005072645.GW31561@phenom.ffwll.local> Mail-Followup-To: Lyude Paul , nouveau@lists.freedesktop.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, Jani Nikula , stable@vger.kernel.org, Joonas Lahtinen , Rodrigo Vivi , David Airlie , linux-kernel@vger.kernel.org References: <20181005002956.7317-1-lyude@redhat.com> <20181005002956.7317-5-lyude@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181005002956.7317-5-lyude@redhat.com> X-Operating-System: Linux phenom 4.14.0-1-amd64 User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Oct 04, 2018 at 08:29:53PM -0400, Lyude Paul wrote: > Since we need to be able to allow DPMS on->off prop changes after an MST > port has disappeared from the system, we need to be able to make sure we > can compute a config for the resulting atomic commit. Currently this is > impossible when the port has disappeared, since the VCPI slot searching > we try to do in intel_dp_mst_compute_config() will fail with -EINVAL. > > Since the only commits we want to allow on no-longer-present MST ports > are ones that shut off display hardware, we already know that no VCPI > allocations are needed. So, hardcode the VCPI slot count to 0 when > intel_dp_mst_compute_config() is called on an MST port that's gone. > > Signed-off-by: Lyude Paul > Cc: stable@vger.kernel.org > --- > drivers/gpu/drm/i915/intel_dp_mst.c | 17 +++++++++++------ > 1 file changed, 11 insertions(+), 6 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_dp_mst.c b/drivers/gpu/drm/i915/intel_dp_mst.c > index fcb9b87b9339..a366f32b048a 100644 > --- a/drivers/gpu/drm/i915/intel_dp_mst.c > +++ b/drivers/gpu/drm/i915/intel_dp_mst.c > @@ -42,7 +42,7 @@ static bool intel_dp_mst_compute_config(struct intel_encoder *encoder, > to_intel_connector(conn_state->connector); > struct drm_atomic_state *state = pipe_config->base.state; > int bpp; > - int lane_count, slots; > + int lane_count, slots = 0; > const struct drm_display_mode *adjusted_mode = &pipe_config->base.adjusted_mode; > int mst_pbn; > bool reduce_m_n = drm_dp_has_quirk(&intel_dp->desc, > @@ -76,11 +76,16 @@ static bool intel_dp_mst_compute_config(struct intel_encoder *encoder, > mst_pbn = drm_dp_calc_pbn_mode(adjusted_mode->crtc_clock, bpp); > pipe_config->pbn = mst_pbn; > > - slots = drm_dp_atomic_find_vcpi_slots(state, &intel_dp->mst_mgr, > - connector->port, mst_pbn); > - if (slots < 0) { > - DRM_DEBUG_KMS("failed finding vcpi slots:%d\n", slots); > - return false; > + if (!connector->mst_port_gone) { Wondered why you don't need this for nouveau/amdgpu, but a bit of grepping later says they don't even bother to check that in their atomic_check functions. So if a multi-stream cable runs out of vcpi slots, they just toss up their hands, atomic be damned :-( With the s/mst_port_gone/READ_ONCE(!conn->registered)/ bikeshed: Reviewed-by: Daniel Vetter I wondered a bit whether ths fuction shouldn't just return 0 if the connector is gone, but we'd need to audit/fix other drivers first. -Daniel > + slots = drm_dp_atomic_find_vcpi_slots(state, > + &intel_dp->mst_mgr, > + connector->port, > + mst_pbn); > + if (slots < 0) { > + DRM_DEBUG_KMS("failed finding vcpi slots:%d\n", > + slots); > + return false; > + } > } > > intel_link_compute_m_n(bpp, lane_count, > -- > 2.17.1 > -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch