Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp519687imm; Thu, 6 Sep 2018 06:16:42 -0700 (PDT) X-Google-Smtp-Source: ANB0VdZDXGxpLiNHZ+Pc2CT8hKTYGFwSNUb3eZFuud1gFHyIXwabnxI4u9Sd0Zaezd/vqfY6Oh1S X-Received: by 2002:a63:d806:: with SMTP id b6-v6mr2598838pgh.347.1536239802752; Thu, 06 Sep 2018 06:16:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536239802; cv=none; d=google.com; s=arc-20160816; b=ZoW9aj8JBCMVZ3VzlCRRH0lMzHjIftU3YVsoqsxlvHs+GQ38xreuaA2vDOlhWQ7tyx YztEeYUwbR50+9NaA71emMwpaSqLzEiP/bR8onkFecmkrx2ibU+B/kCpa+KaKs1NJdg0 OQtTB1CMhJjYVNYBYgCKjhMG9KSlwvfYcjzHTxIQ5FvzMy0lgGYTt6TfHx38iGN6uETd Ro3PbaXqItncgcZIsg12ovQT73uJzjSrq4lEPx6Sev6wTmaG9VEaQmjbc+qcB5YaCEJg oB7x96RaAEC6eFavLltx3DJsx/i4Vz4hPlPZ6gugoAYTESut2MSVivGGg0RKPciK6lt5 JUcg== 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:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=S1U85ivCJ6XCvmXPLw3swGqwkiamqWu3KPLWsq69dAo=; b=mKcloAnMGD8vko5PcKmzZcrMQwRvmMX40wa4vO2gzNHVl3cQvuUF49ozWBA1cvXoU5 Yaz1n7Bj2cV0AyHCJhnd74xpL8PlWrclMyPSwHmiHv8q/BFwOAIzds6YtxNBrs2jLaK5 b48i6ArbCQdzf18L0ATov1GIwommY7uaexj+GjchI7J+oSVrusAQS6qU2+AawsjUK9a8 BRG4t5lfD+fxV5ctqbdWqOM1akWeXT332ajeEhroT5TnC/yKyBm6YVOho42JNQW3lHkq BEm0FD7EfF2nYk47zYL/OMlANQt5KyxGDuBDHX1GlWXjTpS7HBhUCQoTuwEtKcCGMPVP rBrw== 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 o1-v6si4906967pld.223.2018.09.06.06.16.26; Thu, 06 Sep 2018 06:16:42 -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 S1729170AbeIFRuT (ORCPT + 99 others); Thu, 6 Sep 2018 13:50:19 -0400 Received: from mail.bootlin.com ([62.4.15.54]:56785 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729143AbeIFRuT (ORCPT ); Thu, 6 Sep 2018 13:50:19 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id EA7AF20763; Thu, 6 Sep 2018 15:14:48 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from bbrezillon (AAubervilliers-681-1-30-219.w90-88.abo.wanadoo.fr [90.88.15.219]) by mail.bootlin.com (Postfix) with ESMTPSA id 29E942072B; Thu, 6 Sep 2018 15:14:38 +0200 (CEST) Date: Thu, 6 Sep 2018 15:14:37 +0200 From: Boris Brezillon To: Arnd Bergmann Cc: Przemyslaw Gaj , Vitor Soares , "open list:GPIO SUBSYSTEM" , Sekhar Nori , Wolfram Sang , Linux I2C , Jonathan Corbet , "open list:DOCUMENTATION" , gregkh , Przemyslaw Sroka , Arkadiusz Golec , Alan Douglas , Bartosz Folta , Damian Kos , Alicja Jurasik-Urbaniak , Cyprian Wronka , Suresh Punnoose , Rafal Ciepiela , Thomas Petazzoni , Nishanth Menon , Rob Herring , Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , DTML , Linux Kernel Mailing List , Geert Uytterhoeven , Linus Walleij , Xiang Lin , Peter Rosin Subject: Re: [PATCH v6 01/10] i3c: Add core I3C infrastructure Message-ID: <20180906151437.4259d6fc@bbrezillon> In-Reply-To: References: <20180719152930.3715-1-boris.brezillon@bootlin.com> <20180719152930.3715-2-boris.brezillon@bootlin.com> <20180824143934.6d6b6487@bbrezillon> <20180824201600.7d80bca9@bbrezillon> <20180828140209.29155d00@bbrezillon> <4DBE768F-3CDC-41BE-9CC8-E294E7277CB1@cadence.com> <8abfb007-d755-36a4-5960-fddd61d04aa2@synopsys.com> <3D2681D9-1ACC-42FF-9FAB-D86B3C689003@cadence.com> <9584757a-e7e2-5bfe-fc2c-e9bc14ad65a8@synopsys.com> <25862F03-9823-42B0-87AC-AE36D7E9C780@cadence.com> X-Mailer: Claws Mail 3.15.0-dirty (GTK+ 2.24.31; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 6 Sep 2018 14:59:46 +0200 Arnd Bergmann wrote: > On Thu, Sep 6, 2018 at 2:43 PM Przemyslaw Gaj wrote: > > > > Hi Boris, Vitor, > > > > This repository does not contain full kernel sources, but it should be enough to discuss mastership request feature. > > https://github.com/przemekgaj/i3c-linux/commit/d54fe68a9d3e573c0c454a2c6f1afafc20142ec5 > > > > Please keep in mind that this is initial version, but mastership works correctly. I added one property to DT to reflect relationship between masters. > > It is possible to request mastership on demand (using sysfs. Useful in case when Linux machine is equipped only with secondary master controller) or automatically change operation mode when device driver wants to read/write something from/to device. > > > > I'm sure I will have to rework something because this was implemented on sources from PATCH v4. I saw that Boris released v7 yesterday :) > > > Can you explain the reason for having a user space interface and DT property? > I thought we had concluded earlier that we wouldn't need that, but it's possible > that I missed something in the discussion since then. I don't think the sysfs knob is needed, this being said, after thinking a bit more about mastership handover and the secondary master case, I think we have something important to solve. When a master is not in control of the bus, it gets informed of devices present on the bus by monitoring DAA or DEFSLVS broadcast events. That means the secondary master should populate the bus with I3C/I2C devices on such events, but that's not enough, because DEFSLVS/DAA do not provide all device info. Some of them (like read/write/ibi limitations) require extra CCC commands, and, to send those CCC commands, the secondary master must claim the bus. We could add a case where we declare devices as partially discovered until the master acquires ownership of the bus, but that means part of the data returned by i3c_device_get_info() will be inaccurate, which might have an impact on some i3c driver ->probe() functions. We could also say that partially discovered devices should not be registered to the device model, but we then hit the problem of "who can force the secondary master to claim the bus if there's no users?".