summaryrefslogtreecommitdiff
path: root/drivers/mtd/ubi/cdev.c
diff options
context:
space:
mode:
authorArtem Bityutskiy <Artem.Bityutskiy@nokia.com>2007-12-17 14:09:09 +0300
committerArtem Bityutskiy <Artem.Bityutskiy@nokia.com>2007-12-26 20:15:15 +0300
commit450f872a8e1763c883c9f723e6937b7ed223e6d3 (patch)
tree256c2d6a485a4d5b4d38d2e591eb8c9105b38f90 /drivers/mtd/ubi/cdev.c
parentc63a491d3737aec3c47c5e785d87021752ad9fa6 (diff)
downloadlinux-450f872a8e1763c883c9f723e6937b7ed223e6d3.tar.xz
UBI: get device when opening volume
When a volume is opened, get its kref via get_device() call. And put the reference when closing the volume. With this, we may have a bit saner volume delete. Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
Diffstat (limited to 'drivers/mtd/ubi/cdev.c')
-rw-r--r--drivers/mtd/ubi/cdev.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/mtd/ubi/cdev.c b/drivers/mtd/ubi/cdev.c
index 24344ba3cfed..35d34b675c78 100644
--- a/drivers/mtd/ubi/cdev.c
+++ b/drivers/mtd/ubi/cdev.c
@@ -635,9 +635,12 @@ static int ubi_cdev_ioctl(struct inode *inode, struct file *file,
}
err = ubi_remove_volume(desc);
- if (err)
- ubi_close_volume(desc);
-
+ /*
+ * The volume is deleted, and the 'struct ubi_volume' object
+ * will be freed when 'ubi_close_volume()' will call
+ * 'put_device()'.
+ */
+ ubi_close_volume(desc);
break;
}