Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp5219262imm; Tue, 9 Oct 2018 11:29:25 -0700 (PDT) X-Google-Smtp-Source: ACcGV60QQFVIEUsFxgijACKhDdOEIWbYsR7ZQSfdoskr46Q7FAAKwEyyHvYJnTSvOM1asOGQvQ8j X-Received: by 2002:a17:902:d694:: with SMTP id v20-v6mr17649841ply.146.1539109765252; Tue, 09 Oct 2018 11:29:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539109765; cv=none; d=google.com; s=arc-20160816; b=v/zm1CGhN8LRg4lOZ/zohFfTmDKnVBJMEtETDugl4QaA32SmeGa3pG+dkAPBNDccsK EzDnY9cWYlXr0WF5hoiGJHn4CqAWkLkzw6QZPshD06WD+L0/B1w5w2CfcBEN4G2TaieC JAIGecklnDGTtYVL0ncW41uhLbYx2n0VVzKkYG/cyUlIfyX6kGXUERG5SVPMD5GJDoCk HZedSvFOQyyJGu7aKONkiHj/ayMww0mNfQyyDMriPeQJEMZKmhK3uNUKq1WIxdZ6X01z TJvIgohOaOuq2TD+KUO8CGlE8SAekheiw2mevdfbVyN8fc8cjU3ievZqE7nmVeIG0GfY skNQ== 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:message-id:subject:cc :to:from:date:dkim-signature; bh=zoQiANYIVcrou2eHOo8lEvFxfrvLop17S2AHUGis6H0=; b=SL6OVFDroVcbe7HVgQ5JDZc/O52WsVs4/0uk9CEF1ZN/itl8eFajQFZy55asnyvxhv kr9IErhgjRqP5O4KoF6DSqPki4y/7IjigeArhqYJ0TGtHz0NVNb1eoofFjo4DRWElqX+ uDLxdeNKwgsI9Vix/Q0JLEA2/3+kUU7p+z/CsUxbgCUytQTpFvVCeP12kEoN936RVjUy +I2FW1H261+pVLjrpqkA11+wtlDYsK7DFDxwswNY88Wv+RZW5YMue05Wz9+4ZD6Rb0BT 8Y5IfGx+0bTsam3CbWCsp575lTdkqELDxmFb6Iv8+vqmyytc/NJeGdYByfQEhM3yhWd9 2T3A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=LCjvJldJ; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d16-v6si21840407pfj.251.2018.10.09.11.29.09; Tue, 09 Oct 2018 11:29:25 -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=pass header.i=@linaro.org header.s=google header.b=LCjvJldJ; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726868AbeJJBpd (ORCPT + 99 others); Tue, 9 Oct 2018 21:45:33 -0400 Received: from mail-pl1-f194.google.com ([209.85.214.194]:42934 "EHLO mail-pl1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726483AbeJJBpd (ORCPT ); Tue, 9 Oct 2018 21:45:33 -0400 Received: by mail-pl1-f194.google.com with SMTP id c8-v6so1231324plo.9 for ; Tue, 09 Oct 2018 11:27:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=zoQiANYIVcrou2eHOo8lEvFxfrvLop17S2AHUGis6H0=; b=LCjvJldJN3RekrWdTujnsbopSN75zBN2ncB+Zeyumun9tsr+mCiUzssUNCS0llAYFq jcEZVhJDsM388IXe5IFzEllpz/i5KsaMNhZdzm55XxVj9AcDzLNTy22t3IhaT9ELdfF3 hG3jh2R2B2RFZtYSh84wsC0QELcU2awKkeqPk= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=zoQiANYIVcrou2eHOo8lEvFxfrvLop17S2AHUGis6H0=; b=nOoUFAi+sX2y0osXgJoJzN8GBOklSCYmv4uzDTJSh1/b8FXCw7EPmd0BIyytNo1rV4 ycox7lH1v+wzkpvaubect2LsApYB4YK4jd/UHIi1CVBFj+3xQnV3x+9f51usI2NjvPjF DZFoVV9iEUQt5m5WE3yHzCv88RYbOZ6YwF6rmPLFMrv1lspVO4C6gNRfIHcMva01rRTt FQgkT/5bWyNO2iP6rjbXENcCLjmkVIGc3LLGo1OujA3Ef94byWceIgCBINGSo9X3vEMT h1tjpxnvDsMtL/HCOykgS6d4yNIlVi34jqq3xN4PCrwhGq1TJ47Ikc3hxWBMD+keU9bh 3X4A== X-Gm-Message-State: ABuFfoiXCplitJwoE3EWLGf0a6C+V4kZMlycOH/WOhVgtJ9dVMabUUUM Q6FhYHJkuY3s7YaasfwJ9MM+4w== X-Received: by 2002:a17:902:7c96:: with SMTP id y22-v6mr29787300pll.321.1539109637003; Tue, 09 Oct 2018 11:27:17 -0700 (PDT) Received: from tuxbook-pro (104-188-17-28.lightspeed.sndgca.sbcglobal.net. [104.188.17.28]) by smtp.gmail.com with ESMTPSA id s78-v6sm62221779pfd.138.2018.10.09.11.27.15 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 09 Oct 2018 11:27:16 -0700 (PDT) Date: Tue, 9 Oct 2018 11:27:12 -0700 From: Bjorn Andersson To: Arnaud Pouliquen Cc: Arun Kumar Neelakantam , ohad@wizery.com, clew@codeaurora.org, sricharan@codeaurora.org, linux-remoteproc@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V4 0/4] Add TIOCM Signals support for RPMSG char devices Message-ID: <20181009182712.GC28399@tuxbook-pro> References: <1538980699-21516-1-git-send-email-aneela@codeaurora.org> <20181008162325.GA1331@tuxbook-pro> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: 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 Tue 09 Oct 09:02 PDT 2018, Arnaud Pouliquen wrote: > hello Bjorn, > > On 10/08/2018 06:23 PM, Bjorn Andersson wrote: > > On Mon 08 Oct 06:08 PDT 2018, Arnaud Pouliquen wrote: > > > >> Hi Arun, Bjorn, > >> > >> On 10/08/2018 08:38 AM, Arun Kumar Neelakantam wrote: > >>> Glink transport support signals to exchange state notification between > >>> local and remote side clients. Adding support to send/receive the signal > >>> command and notify the clients through callback and POLL notification. > >> > >> Please correct me if i'm wrong...My concern here is that this patchset > >> implements a rpmsg service in the rpmsg core. I would separate this from > >> the rpmsg core, as this is not part of the rpmsg protocol but seems > >> linked to the serial protocol itself. > >> Could it be implemented in rpmsg_char, using a dedicated channel...? > >> > > > > rpmsg_char does expose a rpmsg channel (be it virtio, smd or glink) to > > user space. This patch series add support for invoking TIOCMGET and > > TIOCMSET on these channels. > > I'm not familiar with this concept, that could explain that i don't > understand this patchset... > > TIOCMGET and TIOCMSET is related to the serial/console flow control, to > control remote modem/processor, right? > Correct, using the known tty ioctls for flow control we allow userspace to communicate flow control information to the rpmsg_char driver. > it seems be implemented only to support the rpmsg_char ioctl interface. > When i have a look to the glink code, signal is treated by a message > sent to remote processor. Therefore it seems that it could be treated as > a service on top of rpmsg (so treat it in rpmsg_char instead of extend > the rpmsg protocol to treat it in glink driver). > The glink message is a control message, so it's not possible to pass this inside a channel. As such it's not possible to solve this entirely in rpmsg_char. Looking at SMD, this is a set of bits in a per-channel control structure. So there it's clearer that it's some side-band control information. Further more, the rpmsg_char driver just exposes a channel to user space, it does not care about the data inside. As such it's not possible to generically extend it to support this with in-band messages. > > > > In addition to adding the client side of this to rpmsg_char it provides > > this support for glink, but the same mechanism exists in smd - while > > this is not supported (today) by the virtio rpmsg. > This is my main concern, i would like to be sure that this service is > not related to specific needs introduced by the rmpsg char implementation: > In this case this should not be part of the rpmsg core but perhaps some > ops directly provided to the rpmsg_char on registration > (rpmsg_chrdev_register_device?)... > Arun's imminent need is for a user space client that needs to flow control the incoming data stream. But the possibility of controlling the incoming flow of data is useful in a number of situations. > > > > > > I'm uncertain of how we could implement this mechanism for virtio rpmsg, > > given that it as a transport doesn't really have a concept of > > channels/flows - but it's really useful to have! > > > > PS. rpmsg_set_signals() can be called from any rpmsg device to perform > > flow control of the communication channel. > > For my point of view this patch-set extends the rpmsg protocol to add > channel flow control. > Does it make sense to have a flow control in rpmsg protocol? > if yes, should it be linked to a channel or to the remote processor itself? > Having per-channel flow control particularly useful in scenarios where one has multiple types of data flowing over a shared underlying FIFO - such as virtio rpmsg. As this allows these different applications to limit the data rate without having to use application specific side band controls. > Extra comment: associated documentation update is missing. > Good catch, we should have a section in Documentation/rpmsg.txt describing this mechanism. Regards, Bjorn > Regards, > Arnaud > > > > > Regards, > > Bjorn > > > >> Regards > >> Arnaud > >> > >>> > >>> Changes since v1: > >>> - Split the patches as per functional areas like core, char, glink > >>> - Add set, clear mask for TIOCMSET > >>> - Merge the char signal callback and POLLPRI patches > >>> > >>> Changes since v2: > >>> - Modify the rpmsg_get_signals function prototype > >>> > >>> Changes since v3: > >>> - Correct the TICOMGET case handling as per new rpmsg_get_signals prototype > >>> - Update the rpmsg_get_signals function header > >>> > >>> Arun Kumar Neelakantam (4): > >>> rpmsg: core: Add signal API support > >>> rpmsg: glink: Add support to handle signals command > >>> rpmsg: char: Add TIOCMGET/TIOCMSET ioctl support > >>> rpmsg: char: Add signal callback and POLLPRI support > >>> > >>> drivers/rpmsg/qcom_glink_native.c | 126 ++++++++++++++++++++++++++++++++++++++ > >>> drivers/rpmsg/rpmsg_char.c | 74 +++++++++++++++++++++- > >>> drivers/rpmsg/rpmsg_core.c | 41 +++++++++++++ > >>> drivers/rpmsg/rpmsg_internal.h | 5 ++ > >>> include/linux/rpmsg.h | 26 ++++++++ > >>> 5 files changed, 269 insertions(+), 3 deletions(-) > >>>