X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=kernel%2Fdrivers%2Fuio%2Fuio.c;fp=kernel%2Fdrivers%2Fuio%2Fuio.c;h=bcc1fc027311335cbd6e56583777c05684ac05e1;hb=e09b41010ba33a20a87472ee821fa407a5b8da36;hp=65bf0676d54afc785107822f51a696ae373a2702;hpb=f93b97fd65072de626c074dbe099a1fff05ce060;p=kvmfornfv.git diff --git a/kernel/drivers/uio/uio.c b/kernel/drivers/uio/uio.c index 65bf0676d..bcc1fc027 100644 --- a/kernel/drivers/uio/uio.c +++ b/kernel/drivers/uio/uio.c @@ -524,6 +524,7 @@ static ssize_t uio_read(struct file *filep, char __user *buf, event_count = atomic_read(&idev->event); if (event_count != listener->event_count) { + __set_current_state(TASK_RUNNING); if (copy_to_user(buf, &event_count, count)) retval = -EFAULT; else { @@ -879,7 +880,8 @@ void uio_unregister_device(struct uio_info *info) uio_dev_del_attributes(idev); - free_irq(idev->info->irq, idev); + if (info->irq && info->irq != UIO_IRQ_CUSTOM) + free_irq(info->irq, idev); device_destroy(&uio_class, MKDEV(uio_major, idev->minor)); @@ -895,6 +897,7 @@ static int __init uio_init(void) static void __exit uio_exit(void) { release_uio_class(); + idr_destroy(&uio_idr); } module_init(uio_init)