Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1855524imu; Fri, 14 Dec 2018 01:34:22 -0800 (PST) X-Google-Smtp-Source: AFSGD/XW9qLctDnjnCbFHU8LDIBEe0iF3eoa9+Q70hQyEFqb2a6pdJB01w0Wm+eNTiYxzbwt7EFu X-Received: by 2002:a17:902:820f:: with SMTP id x15mr2108489pln.224.1544780062889; Fri, 14 Dec 2018 01:34:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544780062; cv=none; d=google.com; s=arc-20160816; b=HcDHjAN3JsNk5QhxRGk3kSCfjUBd2O9EUPaeEFPH/4O42Y2+DLy6nnA7rthEeQBrA3 YFkZEyzBEGzadEqN5KjNJPW8+DqnGKsBRQmkapx73Xc3dJK7UyzTjnOgqzqwho/pAlVn VTrGInBQTaMY3rHH/ua48lCec2bdjoYv8VhN0z1TFJ9C+/4BfiqN5PgQ0Btmgyp4YgFS oNIbuh6vxng5x0vhLQ1+vAlN4DllKSSKWtCuMeQyE7c6NMU7vmbaqIQbiUuaUiwVsU9q n+DIO3EjGjYV3Yo1XkFhdvxN1GQKEsy84qqFlyrWGsPMqizzA0LGxPIoyiqgReWxojom 7G7Q== 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=KoCIBm7CBYW1uN3jnXZWO/ouZf8zQtKhVCgewJTPktc=; b=pntL3WVLrq2tKKSkWL87a6InMDmACa+JEq+k1omYvGPzkgXtF7OTAyIxRY6DiMSztA I+dgzRnQJzBoPuJT/mwSFhkUMCFStW14t7n+M8IFFctVvfLocNCimgjfqFbSQgA5h295 HxO0CL2/2atvdUCE6TbnUO5pxx2K2xvnoyhn5BennH66oOEypJIQ3ZsJXyKfRbyrYFm9 q9uOnc5wNQ8cixy1iGn2+pod2EIZQ6JLCnMvwutLtM7n5czS1yeHJ8HsgSq9jXRRIrj6 15FKrkokFtafIYRAX93z1vZBN4/kLB+lUU/2KsPxyKVEIkRnMB0uSx3yiTyJBkIZ3HiD 247w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=RnCilNpB; 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 c12si300146pgb.402.2018.12.14.01.34.07; Fri, 14 Dec 2018 01:34:22 -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=fail header.i=@ffwll.ch header.s=google header.b=RnCilNpB; 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 S1728799AbeLNJdA (ORCPT + 99 others); Fri, 14 Dec 2018 04:33:00 -0500 Received: from mail-ed1-f66.google.com ([209.85.208.66]:34209 "EHLO mail-ed1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726344AbeLNJdA (ORCPT ); Fri, 14 Dec 2018 04:33:00 -0500 Received: by mail-ed1-f66.google.com with SMTP id b3so4426390ede.1 for ; Fri, 14 Dec 2018 01:32:58 -0800 (PST) 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=KoCIBm7CBYW1uN3jnXZWO/ouZf8zQtKhVCgewJTPktc=; b=RnCilNpBMh296ngDHxeR53eYl6mQllihE2UNOPQ6XAZkFql5IyUCJs3Txc/3x3n/bc +AGDMgyFIY2e5+7Tj58A9aRDe7S/uDY6LbTfUvClXSqvyXWocfmbAlWkFZQ7rdWedf7R 5/shAm4uuwKIdreoZb4lS6PAEmycAnqRKODSg= 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=KoCIBm7CBYW1uN3jnXZWO/ouZf8zQtKhVCgewJTPktc=; b=dD1QLAlRaj6tTfKk+g7FX+AUr8oa8xhYZh97E6QHHMaxz3fD19AeJeTMfffkOAUCr3 Bnl4eKzoIhaFXm1P4z8CvgGZU6EcUeKEfppd+haTg6eqaeqR+D68iByttYYaQk/dWI6/ Q+9SXPBsZ77plhbhp3xduhh3jCcGJZFBQlNq7B2F81k8o6opixR1ZbMDoElovSRQmeyS RyI8w8KXlAJJw9K6ZaTiBkBiYBybzanA43gtRff+8otPGmrQ4ZHlceQoRUOqAeIg6bDB DOLd+tjUyslfHGKmULGC6xNlafYYrVD4YNhMkgRrbcrisWMw0rDjIO/iCWP94g+tJU0d qTJw== X-Gm-Message-State: AA+aEWZThxCpa48Bz2EHHByaU3G2KB9VCjwwYrJ6cRYbIGdL9AFopRzB BlsHsV+EXXOFbV9NR6y7pZqPUQ== X-Received: by 2002:aa7:cdda:: with SMTP id h26mr2440576edw.248.1544779978106; Fri, 14 Dec 2018 01:32:58 -0800 (PST) Received: from phenom.ffwll.local ([2a02:168:569e:0:3106:d637:d723:e855]) by smtp.gmail.com with ESMTPSA id s12sm1380329edb.43.2018.12.14.01.32.56 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 14 Dec 2018 01:32:57 -0800 (PST) Date: Fri, 14 Dec 2018 10:32:55 +0100 From: Daniel Vetter To: Lyude Paul Cc: dri-devel@lists.freedesktop.org, nouveau@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, amd-gfx@lists.freedesktop.org, Daniel Vetter , Dave Airlie , Harry Wentland , Jerry Zuo , Jani Nikula , Joonas Lahtinen , Rodrigo Vivi , David Airlie , linux-kernel@vger.kernel.org Subject: Re: [WIP PATCH 06/15] drm/i915: Keep malloc references to MST ports Message-ID: <20181214093255.GO21184@phenom.ffwll.local> Mail-Followup-To: Lyude Paul , dri-devel@lists.freedesktop.org, nouveau@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, amd-gfx@lists.freedesktop.org, Dave Airlie , Harry Wentland , Jerry Zuo , Jani Nikula , Joonas Lahtinen , Rodrigo Vivi , David Airlie , linux-kernel@vger.kernel.org References: <20181214012604.13746-1-lyude@redhat.com> <20181214012604.13746-7-lyude@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181214012604.13746-7-lyude@redhat.com> X-Operating-System: Linux phenom 4.18.0-2-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, Dec 13, 2018 at 08:25:35PM -0500, Lyude Paul wrote: > So that the ports stay around until we've destroyed the connectors, in > order to ensure that we don't pass an invalid pointer to any MST helpers > once we introduce the new MST VCPI helpers. > > Signed-off-by: Lyude Paul > --- > drivers/gpu/drm/i915/intel_connector.c | 4 ++++ > drivers/gpu/drm/i915/intel_dp_mst.c | 2 ++ > 2 files changed, 6 insertions(+) > > diff --git a/drivers/gpu/drm/i915/intel_connector.c b/drivers/gpu/drm/i915/intel_connector.c > index 18e370f607bc..37d2c644f4b8 100644 > --- a/drivers/gpu/drm/i915/intel_connector.c > +++ b/drivers/gpu/drm/i915/intel_connector.c > @@ -95,6 +95,10 @@ void intel_connector_destroy(struct drm_connector *connector) > intel_panel_fini(&intel_connector->panel); > > drm_connector_cleanup(connector); > + > + if (intel_connector->port) We set this as the first thing in intel_dp_add_mst_connector, so this check isn't doing anything. > + drm_dp_mst_put_port_malloc(intel_connector->port); > + > kfree(connector); > } > > diff --git a/drivers/gpu/drm/i915/intel_dp_mst.c b/drivers/gpu/drm/i915/intel_dp_mst.c > index f05427b74e34..4d6ced34d465 100644 > --- a/drivers/gpu/drm/i915/intel_dp_mst.c > +++ b/drivers/gpu/drm/i915/intel_dp_mst.c > @@ -484,6 +484,8 @@ static struct drm_connector *intel_dp_add_mst_connector(struct drm_dp_mst_topolo > if (ret) > goto err; > > + drm_dp_mst_get_port_malloc(port); Needs to be moved up where we assing intel_connector->port, or it'll underflow on cleanup on error paths. > + > return connector; > > err: > -- > 2.19.2 > -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch