[Devel] [PATCH vz7 46/46] fuse: ioctl() to bind fuse device to input queue
Maxim Patlasov
mpatlasov at virtuozzo.com
Fri Mar 24 19:30:58 PDT 2017
By default all fuse devices refer to the main input queue: fc->main_iq.
Userspace may change the mapping by:
ioctl(fd, FUSE_DEV_IOC_SETAFF, i);
where "fd" is clone file descriptor for "/dev/fuse" and "i" is
an integer from zero to num_online_cpus-1.
Signed-off-by: Maxim Patlasov <mpatlasov at virtuozzo.com>
---
fs/fuse/dev.c | 16 ++++++++++++++++
include/uapi/linux/fuse.h | 1 +
2 files changed, 17 insertions(+)
diff --git a/fs/fuse/dev.c b/fs/fuse/dev.c
index 08c825e..8dd5154 100644
--- a/fs/fuse/dev.c
+++ b/fs/fuse/dev.c
@@ -2272,6 +2272,22 @@ static long fuse_dev_ioctl(struct file *file, unsigned int cmd,
fput(old);
}
}
+ } else if (cmd == FUSE_DEV_IOC_SETAFF) {
+ if (arg >= num_online_cpus()) {
+ err = -EINVAL;
+ } else {
+ struct fuse_dev *fud = fuse_get_dev(file);
+ spin_lock(&fud->fc->lock);
+
+ fud->fiq->handled_by_fud--;
+ BUG_ON(fud->fiq->handled_by_fud < 0);
+
+ fud->fiq = per_cpu_ptr(fud->fc->iqs, arg);
+
+ fud->fiq->handled_by_fud++;
+ spin_unlock(&fud->fc->lock);
+ err = 0;
+ }
}
return err;
}
diff --git a/include/uapi/linux/fuse.h b/include/uapi/linux/fuse.h
index 3262980..c2c1ac9 100644
--- a/include/uapi/linux/fuse.h
+++ b/include/uapi/linux/fuse.h
@@ -751,5 +751,6 @@ struct fuse_notify_inval_files_out {
/* Device ioctls: */
#define FUSE_DEV_IOC_CLONE _IOR(229, 0, uint32_t)
+#define FUSE_DEV_IOC_SETAFF _IOR(229, 1, uint32_t)
#endif /* _LINUX_FUSE_H */
More information about the Devel
mailing list