diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/uio/uio.c | 19 |
1 files changed, 4 insertions, 15 deletions
diff --git a/drivers/uio/uio.c b/drivers/uio/uio.c index 5110f367f1f1..c8b926291e28 100644 --- a/drivers/uio/uio.c +++ b/drivers/uio/uio.c | |||
@@ -369,26 +369,15 @@ static void uio_dev_del_attributes(struct uio_device *idev) | |||
369 | static int uio_get_minor(struct uio_device *idev) | 369 | static int uio_get_minor(struct uio_device *idev) |
370 | { | 370 | { |
371 | int retval = -ENOMEM; | 371 | int retval = -ENOMEM; |
372 | int id; | ||
373 | 372 | ||
374 | mutex_lock(&minor_lock); | 373 | mutex_lock(&minor_lock); |
375 | if (idr_pre_get(&uio_idr, GFP_KERNEL) == 0) | 374 | retval = idr_alloc(&uio_idr, idev, 0, UIO_MAX_DEVICES, GFP_KERNEL); |
376 | goto exit; | 375 | if (retval >= 0) { |
377 | 376 | idev->minor = retval; | |
378 | retval = idr_get_new(&uio_idr, idev, &id); | 377 | } else if (retval == -ENOSPC) { |
379 | if (retval < 0) { | ||
380 | if (retval == -EAGAIN) | ||
381 | retval = -ENOMEM; | ||
382 | goto exit; | ||
383 | } | ||
384 | if (id < UIO_MAX_DEVICES) { | ||
385 | idev->minor = id; | ||
386 | } else { | ||
387 | dev_err(idev->dev, "too many uio devices\n"); | 378 | dev_err(idev->dev, "too many uio devices\n"); |
388 | retval = -EINVAL; | 379 | retval = -EINVAL; |
389 | idr_remove(&uio_idr, id); | ||
390 | } | 380 | } |
391 | exit: | ||
392 | mutex_unlock(&minor_lock); | 381 | mutex_unlock(&minor_lock); |
393 | return retval; | 382 | return retval; |
394 | } | 383 | } |