aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/generic
diff options
context:
space:
mode:
authorJohn Crispin <blogic@openwrt.org>2014-04-07 15:10:18 +0000
committerJohn Crispin <blogic@openwrt.org>2014-04-07 15:10:18 +0000
commitc3f869a05f27793755b371f6cdad1a2741c76cc7 (patch)
tree7754fb569ebd088fd01b8bff323644ff40b55a52 /target/linux/generic
parent1a579e57fe608e50edae8db5d71e68f1dc99cbfd (diff)
downloadupstream-c3f869a05f27793755b371f6cdad1a2741c76cc7.tar.gz
upstream-c3f869a05f27793755b371f6cdad1a2741c76cc7.tar.bz2
upstream-c3f869a05f27793755b371f6cdad1a2741c76cc7.zip
kernel: add a ubi forced detach ioctl
Signed-off-by: John Crispin <blogic@openwrt.org> git-svn-id: svn://svn.openwrt.org/openwrt/trunk@40417 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/generic')
-rw-r--r--target/linux/generic/patches-3.10/413-mtd-ubi-forced-detach.patch41
1 files changed, 41 insertions, 0 deletions
diff --git a/target/linux/generic/patches-3.10/413-mtd-ubi-forced-detach.patch b/target/linux/generic/patches-3.10/413-mtd-ubi-forced-detach.patch
new file mode 100644
index 0000000000..0d4fff1ee5
--- /dev/null
+++ b/target/linux/generic/patches-3.10/413-mtd-ubi-forced-detach.patch
@@ -0,0 +1,41 @@
+--- a/drivers/mtd/ubi/cdev.c
++++ b/drivers/mtd/ubi/cdev.c
+@@ -974,7 +974,7 @@ static long ubi_cdev_ioctl(struct file *
+ static long ctrl_cdev_ioctl(struct file *file, unsigned int cmd,
+ unsigned long arg)
+ {
+- int err = 0;
++ int err = 0, force = 0;
+ void __user *argp = (void __user *)arg;
+
+ if (!capable(CAP_SYS_RESOURCE))
+@@ -1024,6 +1024,10 @@ static long ctrl_cdev_ioctl(struct file
+ }
+
+ /* Detach an MTD device command */
++ case UBI_IOCFDET:
++ force = 1;
++ /* no break */
++
+ case UBI_IOCDET:
+ {
+ int ubi_num;
+@@ -1036,7 +1040,7 @@ static long ctrl_cdev_ioctl(struct file
+ }
+
+ mutex_lock(&ubi_devices_mutex);
+- err = ubi_detach_mtd_dev(ubi_num, 0);
++ err = ubi_detach_mtd_dev(ubi_num, force);
+ mutex_unlock(&ubi_devices_mutex);
+ break;
+ }
+--- a/include/uapi/mtd/ubi-user.h
++++ b/include/uapi/mtd/ubi-user.h
+@@ -168,6 +168,7 @@
+ #define UBI_IOCATT _IOW(UBI_CTRL_IOC_MAGIC, 64, struct ubi_attach_req)
+ /* Detach an MTD device */
+ #define UBI_IOCDET _IOW(UBI_CTRL_IOC_MAGIC, 65, __s32)
++#define UBI_IOCFDET _IOW(UBI_CTRL_IOC_MAGIC, 99, __s32)
+
+ /* ioctl commands of UBI volume character devices */
+