Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp1817957ybe; Tue, 3 Sep 2019 04:04:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqx1Dlx5oxyCVWsQznjr9RnWQ3335BYpLKQqLIGzTAGd7UHK5nCAzxWOfYeEu+zLCoYrBDo7 X-Received: by 2002:a63:89c7:: with SMTP id v190mr28582124pgd.299.1567508699709; Tue, 03 Sep 2019 04:04:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567508699; cv=none; d=google.com; s=arc-20160816; b=J3HAxzsWBvTBebUZoj41Ye9AcYM3t2u6fEs8gLxoNoY+D1u2mOkCOFTLJcJdAQJxSP S+6ojk3MLsqnr3VphSj45l05AHC8hX3KhONIGg0V3drmwTYuXsvtudVqNS4jVPPxfhjt r+LEFbvOL1PmvTL+hUboGskT/2MYRMz/iC7V9EKH/zvAD4vGF1UcI5nsWBVwwKsTTJua IYRn01ciLlHD8se9mvW+p0pMrptRhY9GmwGbE0o7/xbdfrKNsV87i2QsyfPNglsiu+W3 MpD9MBHvMrDQ0ur89ePQTCg+GvWS2L5DbffNf9UEAfB3Iqj7LUr8hXG6BeMd6eeZbIPq Gn7A== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=FfE6CODMI13uwE8m8m7XE49vLjuQ7Vam2ly20J6ymvM=; b=ZLajZNyS93b6rCSRsV7P8etyR1/PG0sWLGr9J60N/NVxw9/BH6CDsDPuDWxIgw2uTb 1S5GS17ry05bESNza/qW1iLJhR+o/VC95hDQTR2/pZr2Q13oW0t0+i7ETxDWWw8rotvg 649+tjFCwW9EF6YtoCfNtGX1WRuJNuy2++L+2s3Y0TYT6HdUoeOjEY9cY/t1N3CrrAsm 13jBCF7Dh2rHfQLFxisxguUZXcJkTs8sncTDY9ADxNyHF1NmwIPrRZ5gw53urA3cBNxa Thz++cgjafbKYRdGWTrsOy3J1bJhbE+QfTdmDnemWwbr7D0n8fHMoKnc2OT5zuGyk6Im jB+A== ARC-Authentication-Results: i=1; mx.google.com; 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 o5si14655610plh.382.2019.09.03.04.04.42; Tue, 03 Sep 2019 04:04:59 -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; 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 S1728824AbfICLDf (ORCPT + 99 others); Tue, 3 Sep 2019 07:03:35 -0400 Received: from hostingweb31-40.netsons.net ([89.40.174.40]:58973 "EHLO hostingweb31-40.netsons.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727639AbfICLDc (ORCPT ); Tue, 3 Sep 2019 07:03:32 -0400 Received: from [109.168.11.45] (port=42494 helo=[192.168.101.73]) by hostingweb31.netsons.net with esmtpsa (TLSv1.2:ECDHE-RSA-AES128-GCM-SHA256:128) (Exim 4.92) (envelope-from ) id 1i56at-003rql-Gm; Tue, 03 Sep 2019 13:03:27 +0200 Subject: Re: [RFC,v2 3/6] media: dt-bindings: add DS90UB954-Q1 video deserializer To: Wolfram Sang Cc: linux-media@vger.kernel.org, linux-i2c@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Mauro Carvalho Chehab , Rob Herring , Mark Rutland , Sakari Ailus , Hans Verkuil , Laurent Pinchart , Kieran Bingham , Jacopo Mondi , Vladimir Zapolskiy , Peter Rosin References: <20190723203723.11730-1-luca@lucaceresoli.net> <20190723203723.11730-4-luca@lucaceresoli.net> <20190902204841.GB7253@kunai> <63d99d6d-ecdd-7dd8-0dcb-126bfd89b258@lucaceresoli.net> <20190903093455.GD1020@kunai> From: Luca Ceresoli Message-ID: Date: Tue, 3 Sep 2019 13:03:27 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20190903093455.GD1020@kunai> Content-Type: text/plain; charset=windows-1252 Content-Language: en-US Content-Transfer-Encoding: 7bit X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - hostingweb31.netsons.net X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - lucaceresoli.net X-Get-Message-Sender-Via: hostingweb31.netsons.net: authenticated_id: luca+lucaceresoli.net/only user confirmed/virtual account not confirmed X-Authenticated-Sender: hostingweb31.netsons.net: luca@lucaceresoli.net X-Source: X-Source-Args: X-Source-Dir: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Wolfram, On 03/09/19 11:34, Wolfram Sang wrote: > >> Not if you define enough addresses in the pool. E.g. the DS90UB954 >> hardware can have 8 aliases per port, so if you have (n_ports * 8) >> addresses in the pool the problem is solved. > > And then you plug-in somewhere another board with another need for ATR > and you are out of addresses. Now I got what you mean: the aliases in a pool are reserved to an ATR and not available to another ATR. What about hoisting the pool one level up in DT, to the adapter where the ATRs are connected? >>> And another add-on module with >>> non-repogrammable devices may occupy addresses from the defined pool >>> above. >> >> You mean a new device on the local (SoC-to-ATR) bus? Well, it could as >> well occupy a non-described address that the ATR has already picked as >> an alias. > > Nope, I mean a seperate add-on which has a hardcoded I2C address on the > bus of the ATR parent. Then this hardcoded address needs to be removed > from the pool if it is in the wrong range. As I understand it, we are referring to the same use case: .---------------. .-----. .-------------------. | adapter (SoC) |---+---| ATR |---| remote slave 0x10 | '---------------' | '-----' '-------------------' | .----------. | device X | '----------' Here device X with hard-coded address 0x20 is plugged in at runtime. As you say it, if 0x20 is in the ATR pool we have a problem. But even without an explicit pool, initially 0x20 is unused and the ATR can use it for remote slave 0x10. Then at some point device X is connected, and suddenly 0x20 conflicts. To a limited extend the explicit pool could help if the list of possible addons is known: one can put in the pool only address that will never appear in addons. Hey, wait, the no-pool solution could have a way to handle this conflict. When device X is connected, the adapter can look for a new alias (0x21), call the i2c_atr_deconfigure_hw() and i2c_atr_setup_hw() callbacks to stop using 0x20 and start using 0x21. Doesn't look very lovely, but may be worth considering. >>> I am not perfectly happy with the assumption that all undescribed >>> addresses are automatically free. That also might need DTS updates to >>> describe all clients properly. But this change only needs to be done >>> once, and it will improve the description of the hardware. >> >> Right, but I still suspect some users won't do their homework and >> discover address conflicts at runtime, maybe months later, in a painful >> way. Also a chip might be undocumented on a given board, so they could >> do their homework and still have problems. > > Yes, we probably need a binding to mark an address as used even though > we don't know the device or don't have a driver for it. > > Don't get me wrong, I know what you mean. One of my boards has a client > soldered in a way so that it is still in debug mode. That means it > listens to addresses 0x03-0x07 to provide debug information. Took me a > while to find out what is happening there. > > But still, 'i2cdetect' showed all of these. > >> Despite my comments, I'm not strongly against your proposal. To me it >> doesn't seem to solve any problem, while it does introduce some degree >> of risk. Could you elaborate more on but what benefit it introduces? > > I'd think the risk of running out of defined addresses is somewhere > equal to running into (after a while) an unexpectedly used address. > I like the fix for the latter better because describing what is on the > bus is more helpful and generic than updating the pool-property every > time you need it. Plus, as mentioned above, other add-on hardware may > disturb your pool allocation. > > I expect this topic to be one of the discussion points of the BoF. Definitely. And having a list of use cases would help a lot IMO. I had never considered the use case described above, for example. Thanks, -- Luca