diff options
author | blogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2014-04-07 15:10:18 +0000 |
---|---|---|
committer | blogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2014-04-07 15:10:18 +0000 |
commit | a533aa753c3863ad09d88484edc5451576d38f2f (patch) | |
tree | 7754fb569ebd088fd01b8bff323644ff40b55a52 /target/linux | |
parent | 47147e1d204181225ace2819a759baa454bd5797 (diff) |
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')
-rw-r--r-- | target/linux/generic/patches-3.10/413-mtd-ubi-forced-detach.patch | 41 |
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 */ + |