Fix loop device becomes read-only
Commit 933ec99
removes read and write from f_op because the vfs layer will
select iter_write or aio_write automatically. However, for Linux <= 4.0,
loop_set_fd will actually check f_op->write and set read-only if not exists.
This patch add them back and use the generic do_sync_{read,write} for
aio_{read,write} and new_sync_{read,write} for {read,write}_iter.
Reviewed-by: George Melikov <mail@gmelikov.ru>
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Chunwei Chen <david.chen@osnexus.com>
Closes #5776
Closes #5855
This commit is contained in:
parent
03336d011c
commit
2094a93e87
|
@ -1,5 +1,5 @@
|
||||||
dnl #
|
dnl #
|
||||||
dnl # Linux 4.1.x API
|
dnl # Linux 3.16 API
|
||||||
dnl #
|
dnl #
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_VFS_RW_ITERATE],
|
AC_DEFUN([ZFS_AC_KERNEL_VFS_RW_ITERATE],
|
||||||
[AC_MSG_CHECKING([whether fops->read/write_iter() are available])
|
[AC_MSG_CHECKING([whether fops->read/write_iter() are available])
|
||||||
|
@ -21,6 +21,26 @@ AC_DEFUN([ZFS_AC_KERNEL_VFS_RW_ITERATE],
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AC_DEFINE(HAVE_VFS_RW_ITERATE, 1,
|
AC_DEFINE(HAVE_VFS_RW_ITERATE, 1,
|
||||||
[fops->read/write_iter() are available])
|
[fops->read/write_iter() are available])
|
||||||
|
|
||||||
|
ZFS_AC_KERNEL_NEW_SYNC_READ
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl #
|
||||||
|
dnl # Linux 4.1 API
|
||||||
|
dnl #
|
||||||
|
AC_DEFUN([ZFS_AC_KERNEL_NEW_SYNC_READ],
|
||||||
|
[AC_MSG_CHECKING([whether new_sync_read() is available])
|
||||||
|
ZFS_LINUX_TRY_COMPILE([
|
||||||
|
#include <linux/fs.h>
|
||||||
|
],[
|
||||||
|
new_sync_read(NULL, NULL, 0, NULL);
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_NEW_SYNC_READ, 1,
|
||||||
|
[new_sync_read() is available])
|
||||||
],[
|
],[
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
])
|
])
|
||||||
|
|
|
@ -857,9 +857,15 @@ const struct file_operations zpl_file_operations = {
|
||||||
.release = zpl_release,
|
.release = zpl_release,
|
||||||
.llseek = zpl_llseek,
|
.llseek = zpl_llseek,
|
||||||
#ifdef HAVE_VFS_RW_ITERATE
|
#ifdef HAVE_VFS_RW_ITERATE
|
||||||
|
#ifdef HAVE_NEW_SYNC_READ
|
||||||
|
.read = new_sync_read,
|
||||||
|
.write = new_sync_write,
|
||||||
|
#endif
|
||||||
.read_iter = zpl_iter_read,
|
.read_iter = zpl_iter_read,
|
||||||
.write_iter = zpl_iter_write,
|
.write_iter = zpl_iter_write,
|
||||||
#else
|
#else
|
||||||
|
.read = do_sync_read,
|
||||||
|
.write = do_sync_write,
|
||||||
.aio_read = zpl_aio_read,
|
.aio_read = zpl_aio_read,
|
||||||
.aio_write = zpl_aio_write,
|
.aio_write = zpl_aio_write,
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue