Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp400033imm; Tue, 15 May 2018 03:29:12 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrfd2cZ7UKPx2pWge+UxMcEvE8HddfOZC5voAWharUDuRFJRAQbnIYaOD2JuUgr5dDPInY1 X-Received: by 2002:a17:902:6f16:: with SMTP id w22-v6mr13640537plk.216.1526380152872; Tue, 15 May 2018 03:29:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526380152; cv=none; d=google.com; s=arc-20160816; b=TafCkCoz2y0bezQWcPN8iYeFco9SreQdIHwR5cL0kQT2lXwBMKMibM6+0DxSmZb1sk KyLn3QExhVYTiamn5pRXACRsaVUt3V2n8CQVQ3TEH79SnttQpLtT8QbUWLbm/MnKNSTb sBvLJm2lpo0WfollshHd3z87tkIrbwpGv6A+Uza4ow2vq2AenZkXMuUhzsY7a7apLMzJ MMpXtBEsjm4ZxDV3fOKc9uwJl0LUU96XXmj3PAc4rzjP2+aXjriAFrwKhF6aN/BBLHu9 PPE2epqBnAXEVVnXYux/EzkF2ljX11atuYYM7UkFOg3IIyXEpg5fUnygzKOofPO85QIr CQJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=ucs7+hOZ1DL/c4LD8E0e852ryqdxmefk9NSIaznOCfE=; b=TL/8TP6AZNvsgR3g6KhVMK720k+md5GvUDx5aYwOl8a1twrXpuPI6mWtm80C68U+yC v3r6U+eZGgB43+YHhWiasXt7Er1gEbWBWPf46AZFcEHz6ewvwVN1FyYb+7sUw4TS2OOZ B9qgs9D34Dg/5GKi+kOTxtalESvtFQdlBN6wcpEXXPpN6uZo5CXf6mURrfN0pXAYT/hM 8rw7LiP/yx3Vv9EjqbWKaLQZo8r4N6/TmU35srqfy0qM5abNZbA5BkA6YkGx6acVF3hZ P9REVhHPDcQqCDTTssQLuaAA8XlJ/1780ngO4NuBlFsUXO6miay9UYwAuOUXm2FaHlIV 8BQQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=TC600jMo; 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 k90-v6si12333082pfh.50.2018.05.15.03.28.58; Tue, 15 May 2018 03:29:12 -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=TC600jMo; 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 S1752838AbeEOKW5 (ORCPT + 99 others); Tue, 15 May 2018 06:22:57 -0400 Received: from mail-it0-f66.google.com ([209.85.214.66]:54630 "EHLO mail-it0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752343AbeEOKWl (ORCPT ); Tue, 15 May 2018 06:22:41 -0400 Received: by mail-it0-f66.google.com with SMTP id z6-v6so26543iti.4 for ; Tue, 15 May 2018 03:22:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=ucs7+hOZ1DL/c4LD8E0e852ryqdxmefk9NSIaznOCfE=; b=TC600jMot1TFW8GHkAuZTWXgYBM6WuBVr45qeCMuz1aDXRBw/0Mw32I4lhzDNQBBQh 4Kdz+2dyeYSPfM3UuMrHdcQxAKe3v6uS5qrL4Z2sTrf5H89ImobhgVSCozOxMUJI9N+R hg8iM2NFmKdy0cF2J0lPbCbrhf6LVVODFZF90= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:sender:in-reply-to:references:from :date:message-id:subject:to:cc; bh=ucs7+hOZ1DL/c4LD8E0e852ryqdxmefk9NSIaznOCfE=; b=WmKq029VNM8GwphCof1XYxNMOJCs7akPVXb07fXOaktegCAmtSjkm3nrb/m1z1ZHkC RuRj5TviC9vzRkwvxecRK3dyszCRAd/W8F2prvh4VhsQemS1qPKIS53scbMWcK/udQmv L1HW8XrEaVmhdq/tJuazjvOwse5EbEYwy/pzmqc3TTYfWb5wFuBdtYfPIvzLpqKhYrfd gotIQFfwhhw7g7B4iDUMhjaUKenKS0y4rgXmHxvukXJPHu6PmGsf1b+H4WfHLuos5uIv letJQE9LbPtl/2b+JTXDyfmKq4HpNshdBGUaftvJ/7Fg1jy2ES9RhO2zp6ZZoNO8G/7O /05Q== X-Gm-Message-State: ALKqPweCEEA/1bdf3hOqkWOogRU2z4aNaWLKy0XG4/Vc0NSUw5Ka4/CC eIclG1nMRzKrA8DoYkk+ha/8JqhuD80CJ5D3JqKckw== X-Received: by 2002:a24:6b4f:: with SMTP id v76-v6mr13087365itc.59.1526379760358; Tue, 15 May 2018 03:22:40 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a4f:1684:0:0:0:0:0 with HTTP; Tue, 15 May 2018 03:22:38 -0700 (PDT) X-Originating-IP: [2a02:168:5628:0:d0c7:bcda:eea:9e5d] In-Reply-To: <73fa1ca3-28e4-96c5-1fc6-23e9c0cebb49@axentia.se> References: <20180504135212.26977-1-peda@axentia.se> <20180504135212.26977-27-peda@axentia.se> <20180514162828.GE28661@phenom.ffwll.local> <73fa1ca3-28e4-96c5-1fc6-23e9c0cebb49@axentia.se> From: Daniel Vetter Date: Tue, 15 May 2018 12:22:38 +0200 X-Google-Sender-Auth: qma7EQWhlm9_XNRT2JY6CH91Y1A Message-ID: Subject: Re: [PATCH v2 26/26] drm/bridge: establish a link between the bridge supplier and consumer To: Peter Rosin Cc: Andrzej Hajda , Linux Kernel Mailing List , Archit Taneja , Laurent Pinchart , David Airlie , Peter Senna Tschudin , Martin Donnelly , Martyn Welch , Gustavo Padovan , Maarten Lankhorst , Sean Paul , Inki Dae , Joonyoung Shim , Seung-Woo Kim , Kyungmin Park , Kukjin Kim , Krzysztof Kozlowski , CK Hu , Philipp Zabel , Matthias Brugger , Rob Clark , Sandy Huang , =?UTF-8?Q?Heiko_St=C3=BCbner?= , Benjamin Gaignard , Vincent Abriou , dri-devel , Linux ARM , linux-samsung-soc , "moderated list:ARM/Mediatek SoC support" , linux-arm-msm , freedreno , "open list:DRM DRIVERS FOR RENESAS" , "open list:ARM/Rockchip SoC..." , Jyri Sarha Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, May 14, 2018 at 10:40 PM, Peter Rosin wrote: > On 2018-05-14 18:28, Daniel Vetter wrote: >> On Fri, May 11, 2018 at 09:37:47AM +0200, Peter Rosin wrote: >>> On 2018-05-10 10:10, Andrzej Hajda wrote: >>>> On 04.05.2018 15:52, 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 >>>>> --- >>>>> 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 78d186b6831b..0259f0a3ff27 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" >>>>> @@ -127,12 +128,25 @@ int drm_bridge_attach(struct drm_encoder *encoder, struct drm_bridge *bridge, >>>>> if (bridge->dev) >>>>> return -EBUSY; >>>>> >>>>> + if (encoder->dev->dev != bridge->odev) { >>>> >>>> I wonder why device_link_add does not handle this case (self dependency) >>>> silently as noop, as it seems to be a correct behavior. >>> >>> It's kind-of a silly corner-case though, so perfectly understandable >>> that it isn't handled. >>> >>>>> + bridge->link = device_link_add(encoder->dev->dev, >>>>> + bridge->odev, 0); >>>>> + if (!bridge->link) { >>>>> + dev_err(bridge->odev, "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; >>>>> @@ -159,6 +173,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 b656e505d11e..804189c63a4c 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 >>>> >>>> Nitpick: "<->" suggests symmetry, maybe "device link from drm consumer >>>> to the bridge" would be better. >>> >>> I meant "<->" to indicate that the link is bidirectional, not that the >>> relationship is in any way symmetric. I wasn't aware of any implication >>> of a symmetric relationship when using "<->", do you have a reference? >>> But I guess the different arrow notations in math are somewhat overloaded >>> and that someone at some point must have used "<->" to indicate a >>> symmetric relationship... >> >> Yeah I agree with Andrzej here, for me <-> implies a symmetric >> relationship. Spelling it out like Andrzej suggested sounds like the >> better idea. >> -Daniel > > Ok, I guess that means I have to do a v3 after all. Or can this > trivial documentation update be done by the committer? I hate to > spam everyone with another volley... > > Or perhaps I should squash patches 2-23 that are all rather similar > and mechanic? I separated them to allow for easier review from > individual driver maintainers, but that didn't seem to happen > anyway... Do another volley of the full set, or in-reply-to to just replace the patch that needs to be respun (but some people don't like that). When resending just make sure you're picking up all the acks/r-bs you have already. -Daniel > Cheers, > Peter > >> >>> >>>> Anyway: >>>> Reviewed-by: Andrzej Hajda >>> >>> Thanks! >>> >>> Cheers, >>> Peter >>> >>>> -- >>>> Regards >>>> Andrzej >>>> >>>>> * @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; >>>> >>>> >>> >> > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel -- Daniel Vetter Software Engineer, Intel Corporation +41 (0) 79 365 57 48 - http://blog.ffwll.ch