On Wed, Jun 22, 2011 at 1:28 PM, Amit Nagal <helloin.amit@xxxxxxxxx> wrote: > Hi , > > 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 . if i have misunderstood facts , kindly clear my doubts . Regards Amit Nagal -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html