Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Unverified Commit f1d908e8 authored by Alessio Balsini's avatar Alessio Balsini Committed by Michael Bestas
Browse files

UPSTREAM: fuse: fix matching of FUSE_DEV_IOC_CLONE command



With commit f8425c939663 ("fuse: 32-bit user space ioctl compat for fuse
device") the matching constraints for the FUSE_DEV_IOC_CLONE ioctl command
are relaxed, limited to the testing of command type and number.  As Arnd
noticed, this is wrong as it wouldn't ensure the correctness of the data
size or direction for the received FUSE device ioctl.

Fix by bringing back the comparison of the ioctl received by the FUSE
device to the originally generated FUSE_DEV_IOC_CLONE.

Fixes: f8425c939663 ("fuse: 32-bit user space ioctl compat for fuse device")
Reported-by: default avatarArnd Bergmann <arnd@kernel.org>
Signed-off-by: default avatarAlessio Balsini <balsini@android.com>
Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
Signed-off-by: default avatarLee Jones <lee.jones@linaro.org>
Signed-off-by: default avatarAlessio Balsini <balsini@android.com>
Change-Id: I372d8399db6d603ba20ef50528acf6645e4d3c66
(cherry picked from commit 6076f5f341e612152879bfda99f0b76c1953bf0b)
parent 06d2948e
Loading
Loading
Loading
Loading
+3 −6
Original line number Diff line number Diff line
@@ -2269,11 +2269,8 @@ static long fuse_dev_ioctl(struct file *file, unsigned int cmd,
	int oldfd;
	struct fuse_dev *fud = NULL;

	if (_IOC_TYPE(cmd) != FUSE_DEV_IOC_MAGIC)
		return -EINVAL;

	switch (_IOC_NR(cmd)) {
	case _IOC_NR(FUSE_DEV_IOC_CLONE):
	switch (cmd) {
	case FUSE_DEV_IOC_CLONE:
		res = -EFAULT;
		if (!get_user(oldfd, (__u32 __user *)arg)) {
			struct file *old = fget(oldfd);
@@ -2298,7 +2295,7 @@ static long fuse_dev_ioctl(struct file *file, unsigned int cmd,
			}
		}
		break;
	case _IOC_NR(FUSE_DEV_IOC_PASSTHROUGH_OPEN):
	case FUSE_DEV_IOC_PASSTHROUGH_OPEN:
		res = -EFAULT;
		if (!get_user(oldfd, (__u32 __user *)arg)) {
			res = -EINVAL;