Re: list not released in case of -ENODEV in hidraw_release (hidraw.c)

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

 



On Wed, 22 Jun 2011, Amit Nagal wrote:

> > linux kernel ver 2.6.39.1  ,  hidraw.c  , in  hidraw_release function
> > , list pointer ( struct hidraw_list *list ) is not freed
> > in case of -ENODEV .
> >
> > i think the following patch is applicable :
> >
> > --- a/drivers/hid/hidraw.c      2011-06-22 08:57:55.000000000 -0400
> > +++ b/drivers/hid/hidraw.c      2011-06-22 08:42:04.000000000 -0400
> > @@ -298,6 +298,7 @@ static int hidraw_release(struct inode *
> >
> >        mutex_lock(&minors_lock);
> >        if (!hidraw_table[minor]) {
> > +               kfree(list);
> >                ret = -ENODEV;
> >                goto unlock;
> >        }
> >
> > Please correct me if i am mistaken .
> >
> 
> In continuation of above , in hidraw_release(), for the sequence
> disconnect  followed by last userspace close(fd) call ,
> even kfree(list->hidraw) should also be called , as in
> hidraw_disconnect() function kfree(hidraw) is called only when
> hidraw->open is 0 .
> so list->hidraw should also be freed when calling last close() call
> even after disconnect .

Hi Amit,

your analysis is correct. Could you please re-send the patch with the 
other fixes added, and also your Signed-off-by line?

Thanks,

-- 
Jiri Kosina
SUSE Labs
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


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

  Powered by Linux