Re: [bug report] usb: gadget: add raw-gadget interface

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Apr 06, 2020 at 03:06:12PM +0200, Andrey Konovalov wrote:
> On Mon, Apr 6, 2020 at 12:55 PM Dan Carpenter <dan.carpenter@xxxxxxxxxx> wrote:
> >
> > Hello Andrey Konovalov,
> >
> > The patch f2c2e717642c: "usb: gadget: add raw-gadget interface" from
> > Feb 24, 2020, leads to the following static checker warning:
> >
> >     drivers/usb/gadget/legacy/raw_gadget.c:102 raw_event_queue_fetch() warn: inconsistent returns 'queue->sema'.
> >       Locked on  : 96,102
> >       Unlocked on: 93
> >
> > drivers/usb/gadget/legacy/raw_gadget.c
> >     81  static struct usb_raw_event *raw_event_queue_fetch(
> >     82                                  struct raw_event_queue *queue)
> >     83  {
> >     84          unsigned long flags;
> >     85          struct usb_raw_event *event;
> >     86
> >     87          /*
> >     88           * This function can be called concurrently. We first check that
> >     89           * there's at least one event queued by decrementing the semaphore,
> >     90           * and then take the lock to protect queue struct fields.
> >     91           */
> >     92          if (down_interruptible(&queue->sema))
> >     93                  return NULL;
> >     94          spin_lock_irqsave(&queue->lock, flags);
> >     95          if (WARN_ON(!queue->size))
> >     96                  return NULL;
> >
> > I'm going to have investigate to see why Smatch doesn't complain that
> > we have disabled IRQs on this path...  Anyway, this doesn't seem like it
> > can be correct.  I get that this is a WARN_ON() path, but we're leaving
> > the computer in a very screwed up state we don't at least enable IRQs.
> 
> Hi Dan,
> 
> Oh, right, I'll send a patch to add spin_lock_irqsave() there.
> 
> I don't really get the warning about queue->sema though, is there
> something wrong with it, or is it actually a warning about
> queue->lock?

The rule here is that we return NULL here and on line 93, so how does
the caller know if we took that "queue->sema" lock?

regards,
dan carpenter




[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux