Received: by 10.192.165.148 with SMTP id m20csp3918326imm; Mon, 30 Apr 2018 08:33:32 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoyh0wYAV9PdaQ/GLrtg/wG5jxcAb2uSiPaqeD/EWXaBtf+8Fx4ev+HRjDUOE7ObgXC8LWX X-Received: by 10.98.13.151 with SMTP id 23mr12508825pfn.231.1525102412780; Mon, 30 Apr 2018 08:33:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525102412; cv=none; d=google.com; s=arc-20160816; b=Dn39gnU4I3IBW+/PjRCz835RebmX8W6USZkH6QsVia0IhmyPx4RAasLw+SWYhVu+wQ dIYvLotqLIhUMko5kOlf91J3owPr/7PQ6Ki5eEKuAHHZgvRUMf9uT3T9QVNGUavYhlbj S44vtLUymdXlpD78qZl5oJwB771I3JBGH5mCg4CCD7RKrbOSfd1/4WTeK+bUltsGvYuE BklsSI69q5KSU5Nj1+6kYveh2td6OjIUsiNjqDBoY4T4rXeq0zBtjfGCgTTolrZCMvkK HcCG1IB2wXaxxSs+1dudJM2RrAzoa4T6x/qM6SHJVq2mEzlqZ8qWzt0p/FBhM2aNXDjx DmIQ== 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 :arc-authentication-results; bh=EnOiXN1YxglgXerJ6sMn/8rdoTJJH7jhJmZmYK8rmHQ=; b=ZhY1XkJ06h+ToDsFyomySMOtZ6ii/ZabM7AokBKJJkH4yyzwnMD/5/hPrnOV5IQ4k5 16OfeQNx/pULg4+goRELj8kP+dPdtxx05HL32qKistWvhLR/4MV1jjCIz8VrhKKyjKYh o6Y3EsCzPQqsvz+aoH+kFzQUTc88sQoQRdCzSs98Nc6iEtAr+EeCzDBd9GI2eWIyCT1R TrS82m15nVlREc6bmIAqGY2ETkB0cMZIfWpMv1FCsoNsebXQy/fPNnF0dp7YyviZc2+N s3F/OzKfiCzLYL9kcyTIoEf6StmH/5Nnc7F9mT3PGrhzpOtkVR7a4bRAdLc68v/Rbt00 D5aQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=LWYwmNJt; 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 k2-v6si6394347pgn.599.2018.04.30.08.33.18; Mon, 30 Apr 2018 08:33:32 -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=LWYwmNJt; 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 S1754753AbeD3Pco (ORCPT + 99 others); Mon, 30 Apr 2018 11:32:44 -0400 Received: from mail-wm0-f65.google.com ([74.125.82.65]:39606 "EHLO mail-wm0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754639AbeD3Pck (ORCPT ); Mon, 30 Apr 2018 11:32:40 -0400 Received: by mail-wm0-f65.google.com with SMTP id f8so4380445wmc.4 for ; Mon, 30 Apr 2018 08:32:40 -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=EnOiXN1YxglgXerJ6sMn/8rdoTJJH7jhJmZmYK8rmHQ=; b=LWYwmNJthGmOAqQ3vVjYNr6JhuuOJlEa60DPDVQJoruOS8aMRyOLi5HGLVyCa5IBd7 Jysi8RoustEohKP95XxjL68cGAABHsvkZeO6YhpuSw4RthxgbtNt5eTf0+qAdKQRENIR 93LxwNgAM9fvyxYWC0KOQeZKfFK1Vpud7I6WE= 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=EnOiXN1YxglgXerJ6sMn/8rdoTJJH7jhJmZmYK8rmHQ=; b=BnWrgmCvkq7U5OV8okcgekAgld8RIc3d0EzaDHsqUGqP/PeCZwN85DquiXi2lXMsmU yQpm9VCC2w4WVOg9tiqnndM2zFiG79Fb450pzWaU94tOwfRY0OEuULmz5hAnfBteahqE zXz+mwdK9E1NCc8thW5VWvJtJv+cn0yrIZ4ktU2zosxWxmKOYQdzFsPCs220Cyvy+84V fsa9i4HHtVIj8ewu3B4hlE0I8iRcKurrNCRiwz5LrQhV84ibOQMfIYHx5ZMmzyY1JDRd bwQ2LemJwGDdZvLt/aqJw7cmShhlwIu0kED9zptBq6L4dGwikPp6OHMMBSvG+cTUOEDf El2A== X-Gm-Message-State: ALQs6tAPIfaVCjzVJa8mxjU+Dccsgt8pkFDLX6aaMWJ1rL4Vwr0clcWe dV+Mozy8o6DJxCzRbXzSOUIOOg== X-Received: by 2002:a50:a550:: with SMTP id z16-v6mr17125640edb.103.1525102359614; Mon, 30 Apr 2018 08:32:39 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:5635:0:39d2:f87e:2033:9f6]) by smtp.gmail.com with ESMTPSA id v17-v6sm4767178edl.47.2018.04.30.08.32.38 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 30 Apr 2018 08:32:38 -0700 (PDT) Date: Mon, 30 Apr 2018 17:32:36 +0200 From: Daniel Vetter To: Peter Rosin Cc: linux-kernel@vger.kernel.org, Martyn Welch , David Airlie , dri-devel@lists.freedesktop.org, Laurent Pinchart , linux-samsung-soc@vger.kernel.org, Kyungmin Park , Krzysztof Kozlowski , Kukjin Kim , Peter Senna Tschudin , Martin Donnelly , linux-arm-msm@vger.kernel.org, Jyri Sarha , Matthias Brugger , Vincent Abriou , linux-arm-kernel@lists.infradead.org, Seung-Woo Kim , linux-renesas-soc@vger.kernel.org, linux-mediatek@lists.infradead.org, freedreno@lists.freedesktop.org Subject: Re: [PATCH 24/24] drm/bridge: establish a link between the bridge supplier and consumer Message-ID: <20180430153236.GP12521@phenom.ffwll.local> Mail-Followup-To: Peter Rosin , linux-kernel@vger.kernel.org, Martyn Welch , David Airlie , dri-devel@lists.freedesktop.org, Laurent Pinchart , linux-samsung-soc@vger.kernel.org, Kyungmin Park , Krzysztof Kozlowski , Kukjin Kim , Peter Senna Tschudin , Martin Donnelly , linux-arm-msm@vger.kernel.org, Jyri Sarha , Matthias Brugger , Vincent Abriou , linux-arm-kernel@lists.infradead.org, Seung-Woo Kim , linux-renesas-soc@vger.kernel.org, linux-mediatek@lists.infradead.org, freedreno@lists.freedesktop.org References: <20180426223139.16740-1-peda@axentia.se> <20180426223139.16740-25-peda@axentia.se> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180426223139.16740-25-peda@axentia.se> X-Operating-System: Linux phenom 4.15.0-3-amd64 User-Agent: Mutt/1.9.5 (2018-04-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Apr 27, 2018 at 12:31:39AM +0200, Peter Rosin wrote: > If the bridge supplier is unbound, this will bring the bridge consumer > down along with the bridge. Thus, there will no longer linger any > dangling pointers from the bridge consumer (the drm_device) to some > non-existent bridge supplier. > > Signed-off-by: Peter Rosin Minus the ->owner bikeshed I brought up in the previous patch I agree with this approach as the best way to move forward for now. Acked-by: Daniel Vetter One small suggestion below, for merging I'd say pls get Jyri's review/tested-by too, since you're both working on the same problem it seems. Aside: Do you want commit rights to drm-misc to be able to push work like this? Cheers, Daniel > --- > drivers/gpu/drm/drm_bridge.c | 18 ++++++++++++++++++ > include/drm/drm_bridge.h | 2 ++ > 2 files changed, 20 insertions(+) > > diff --git a/drivers/gpu/drm/drm_bridge.c b/drivers/gpu/drm/drm_bridge.c > index a038da696802..f0c79043ec43 100644 > --- a/drivers/gpu/drm/drm_bridge.c > +++ b/drivers/gpu/drm/drm_bridge.c > @@ -26,6 +26,7 @@ > #include > > #include > +#include > #include > > #include "drm_crtc_internal.h" > @@ -124,12 +125,25 @@ int drm_bridge_attach(struct drm_encoder *encoder, struct drm_bridge *bridge, > if (bridge->dev) > return -EBUSY; > > + if (encoder->dev->dev != bridge->owner) { You might end up with a NULL encoder->dev->dev. Perhaps check that and bail with a WARN_ON? > + bridge->link = device_link_add(encoder->dev->dev, > + bridge->owner, 0); > + if (!bridge->link) { > + dev_err(bridge->owner, "failed to link bridge to %s\n", > + dev_name(encoder->dev->dev)); > + return -EINVAL; > + } > + } > + > bridge->dev = encoder->dev; > bridge->encoder = encoder; > > if (bridge->funcs->attach) { > ret = bridge->funcs->attach(bridge); > if (ret < 0) { > + if (bridge->link) > + device_link_del(bridge->link); > + bridge->link = NULL; > bridge->dev = NULL; > bridge->encoder = NULL; > return ret; > @@ -156,6 +170,10 @@ void drm_bridge_detach(struct drm_bridge *bridge) > if (bridge->funcs->detach) > bridge->funcs->detach(bridge); > > + if (bridge->link) > + device_link_del(bridge->link); > + bridge->link = NULL; > + > bridge->dev = NULL; > } > > diff --git a/include/drm/drm_bridge.h b/include/drm/drm_bridge.h > index 3bc659f3e7d2..9a386559a41a 100644 > --- a/include/drm/drm_bridge.h > +++ b/include/drm/drm_bridge.h > @@ -261,6 +261,7 @@ struct drm_bridge_timings { > * @list: to keep track of all added bridges > * @timings: the timing specification for the bridge, if any (may > * be NULL) > + * @link: drm consumer <-> bridge supplier > * @funcs: control functions > * @driver_private: pointer to the bridge driver's internal context > */ > @@ -271,6 +272,7 @@ struct drm_bridge { > struct drm_bridge *next; > struct list_head list; > const struct drm_bridge_timings *timings; > + struct device_link *link; > > const struct drm_bridge_funcs *funcs; > void *driver_private; > -- > 2.11.0 > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch