[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <5814124.riuyD8fLGG@linux-5eaq.site>
Date: Thu, 11 Apr 2013 11:59:30 +0200
From: Oliver Neukum <oliver@...kum.org>
To: Ming Lei <tom.leiming@...il.com>
Cc: Bjørn Mork <bjorn@...k.no>,
Dan Williams <dcbw@...hat.com>,
Elina Pasheva <epasheva@...rrawireless.com>,
Network Development <netdev@...r.kernel.org>,
linux-usb <linux-usb@...r.kernel.org>,
Rory Filer <rfiler@...rrawireless.com>,
Phil Sutter <phil@....cc>
Subject: Re: [PATCH 1/2 v5] usbnet: allow status interrupt URB to always be active
On Thursday 11 April 2013 16:37:53 Ming Lei wrote:
> On Thu, Apr 11, 2013 at 4:06 PM, Bjørn Mork <bjorn@...k.no> wrote:
> > Oliver Neukum <oliver@...kum.org> writes:
> >
> > My immediate thought was that someone also might want to use this new
> > API from atomic context, e.g. calling it directly from an URB callback.
>
> I am wondering it is a valid use case, and if there is one URB submitted,
> the interrupt URB for status has been submitted already, hasn't it?
That is the point of this patch. There are multiple reasons to keep
the status urb submitted. The generic layer has to count them and
react to the count.
> > But that is of course not possible taking a mutex. Could the lock
> > preventing interrupt_count maybe be a spinlock instead? Or am I on the
> > completely wrong track here?
>
> Also it is a bit odd that the 'start' API is allowed in atomic context, but
> the 'stop' API isn't allowed, and it is very easy to cause unbalanced counter.
It simply is easier to submit an URB in an atomic context than to kill it.
The code allowing doing it under a spinlock would be complex.
> > In any case, I don't see the point unnecessarily limiting the API by
> > dropping the memflags. What possible problem would that solve?
>
> If you think 'start' API should be called in atomic context, the memflags
It may be called. It doesn't have to be. usbnet needs a certain amount
of genericness in the API. Passing a flag does that and is simple.
Regards
Oliver
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists