From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752898AbcKSMSE (ORCPT ); Sat, 19 Nov 2016 07:18:04 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:35678 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752315AbcKSMSD (ORCPT ); Sat, 19 Nov 2016 07:18:03 -0500 Date: Sat, 19 Nov 2016 13:18:12 +0100 From: Greg Kroah-Hartman To: Tomas Winkler Cc: Alexander Usyskin , linux-kernel@vger.kernel.org Subject: Re: [char-misc-next 4/4 V2] mei: bus: enable non-blocking RX Message-ID: <20161119121812.GA1476@kroah.com> References: <1479557771-19689-1-git-send-email-tomas.winkler@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1479557771-19689-1-git-send-email-tomas.winkler@intel.com> User-Agent: Mutt/1.7.1 (2016-10-04) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Nov 19, 2016 at 02:16:11PM +0200, Tomas Winkler wrote: > From: Alexander Usyskin > > Enable non-blocking receive for drivers on mei bus, this allows checking > for data availability by mei client drivers. This is most effective for > fixed address clients, that lacks flow control. > > This function adds new API function mei_cldev_recv_nonblock(), it > retuns -EGAIN if function will block. > > Signed-off-by: Alexander Usyskin > Signed-off-by: Tomas Winkler > --- > V2: use _nonblock() function suffix instead of NONBLOCK flag > > drivers/misc/mei/bus-fixup.c | 4 ++-- > drivers/misc/mei/bus.c | 31 +++++++++++++++++++++++++++++-- > drivers/misc/mei/mei_dev.h | 7 ++++++- > include/linux/mei_cl_bus.h | 6 ++++-- > 4 files changed, 41 insertions(+), 7 deletions(-) > > diff --git a/drivers/misc/mei/bus-fixup.c b/drivers/misc/mei/bus-fixup.c > index 7f2cef9011ae..18e05ca7584f 100644 > --- a/drivers/misc/mei/bus-fixup.c > +++ b/drivers/misc/mei/bus-fixup.c > @@ -141,7 +141,7 @@ static int mei_osver(struct mei_cl_device *cldev) > if (ret < 0) > return ret; > > - ret = __mei_cl_recv(cldev->cl, buf, length); > + ret = __mei_cl_recv(cldev->cl, buf, length, 0); What is 0 here? Again, mode...