Re: [PATCH V8 00/33] loop: Issue O_DIRECT aio using bio_vec

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Jul 25, 2013 at 7:50 PM, Dave Kleikamp <dave.kleikamp@xxxxxxxxxx> wrote:
> This patch series adds a kernel interface to fs/aio.c so that kernel code can
> issue concurrent asynchronous IO to file systems.  It adds an aio command and
> file system methods which specify io memory with pages instead of userspace
> addresses.
>
> This series was written to reduce the current overhead loop imposes by
> performing synchronus buffered file system IO from a kernel thread.  These
> patches turn loop into a light weight layer that translates bios into iocbs.
>
> It introduces new file ops, read_iter() and write_iter(), that replace the
> aio_read() and aio_write() operations. The iov_iter structure can now contain
> either a user-space iovec or a kernel-space bio_vec. Since it would be
> overly complicated to replace every instance of aio_read() and aio_write(),
> the old operations are not removed, but file systems implementing the new
> ones need not keep the old ones.
>
> Verion 8 is little changed from Version 7 that I send out in March, just
> updated to the latest kernel. These patches apply to 3.11-rc2 and can
> also be found at:
>
> git://github.com/kleikamp/linux-shaggy.git aio_loop
>

What has happened to that aio_loop patchset?
Is it in Linux-next?
( /me started to play with "block: loop: convert to blk-mq (v3)", so I
recalled this other improvement. )

- Sedat -

> Asias He (1):
>   block_dev: add support for read_iter, write_iter
>
> Dave Kleikamp (22):
>   iov_iter: iov_iter_copy_from_user() should use non-atomic copy
>   iov_iter: add __iovec_copy_to_user()
>   fuse: convert fuse to use iov_iter_copy_[to|from]_user
>   iov_iter: ii_iovec_copy_to_user should pre-fault user pages
>   dio: Convert direct_IO to use iov_iter
>   dio: add bio_vec support to __blockdev_direct_IO()
>   aio: add aio_kernel_() interface
>   aio: add aio support for iov_iter arguments
>   fs: create file_readable() and file_writable() functions
>   fs: use read_iter and write_iter rather than aio_read and aio_write
>   fs: add read_iter and write_iter to several file systems
>   ocfs2: add support for read_iter and  write_iter
>   ext4: add support for read_iter and write_iter
>   nfs: add support for read_iter, write_iter
>   nfs: simplify swap
>   btrfs: add support for read_iter and write_iter
>   xfs: add support for read_iter and write_iter
>   gfs2: Convert aio_read/write ops to read/write_iter
>   udf: convert file ops from aio_read/write to read/write_iter
>   afs: add support for read_iter and write_iter
>   ecrpytfs: Convert aio_read/write ops to read/write_iter
>   ubifs: convert file ops from aio_read/write to read/write_iter
>
> Hugh Dickins (1):
>   tmpfs: add support for read_iter and write_iter
>
> Zach Brown (9):
>   iov_iter: move into its own file
>   iov_iter: add copy_to_user support
>   iov_iter: hide iovec details behind ops function pointers
>   iov_iter: add bvec support
>   iov_iter: add a shorten call
>   iov_iter: let callers extract iovecs and bio_vecs
>   fs: pull iov_iter use higher up the stack
>   bio: add bvec_length(), like iov_length()
>   loop: use aio to perform io on the underlying file
>
>  Documentation/filesystems/Locking   |   6 +-
>  Documentation/filesystems/vfs.txt   |  12 +-
>  drivers/block/loop.c                | 148 ++++++++----
>  drivers/char/raw.c                  |   4 +-
>  drivers/mtd/nand/nandsim.c          |   4 +-
>  drivers/usb/gadget/storage_common.c |   4 +-
>  fs/9p/vfs_addr.c                    |  12 +-
>  fs/9p/vfs_file.c                    |   8 +-
>  fs/Makefile                         |   2 +-
>  fs/adfs/file.c                      |   4 +-
>  fs/affs/file.c                      |   4 +-
>  fs/afs/file.c                       |   4 +-
>  fs/afs/internal.h                   |   3 +-
>  fs/afs/write.c                      |   9 +-
>  fs/aio.c                            | 152 ++++++++++++-
>  fs/bad_inode.c                      |  14 ++
>  fs/bfs/file.c                       |   4 +-
>  fs/block_dev.c                      |  27 ++-
>  fs/btrfs/file.c                     |  42 ++--
>  fs/btrfs/inode.c                    |  63 +++---
>  fs/ceph/addr.c                      |   3 +-
>  fs/cifs/file.c                      |   4 +-
>  fs/direct-io.c                      | 223 +++++++++++++------
>  fs/ecryptfs/file.c                  |  15 +-
>  fs/exofs/file.c                     |   4 +-
>  fs/ext2/file.c                      |   4 +-
>  fs/ext2/inode.c                     |   8 +-
>  fs/ext3/file.c                      |   4 +-
>  fs/ext3/inode.c                     |  15 +-
>  fs/ext4/ext4.h                      |   3 +-
>  fs/ext4/file.c                      |  34 +--
>  fs/ext4/indirect.c                  |  16 +-
>  fs/ext4/inode.c                     |  23 +-
>  fs/f2fs/data.c                      |   4 +-
>  fs/f2fs/file.c                      |   4 +-
>  fs/fat/file.c                       |   4 +-
>  fs/fat/inode.c                      |  10 +-
>  fs/fuse/cuse.c                      |  10 +-
>  fs/fuse/file.c                      |  90 ++++----
>  fs/fuse/fuse_i.h                    |   5 +-
>  fs/gfs2/aops.c                      |   7 +-
>  fs/gfs2/file.c                      |  21 +-
>  fs/hfs/inode.c                      |  11 +-
>  fs/hfsplus/inode.c                  |  10 +-
>  fs/hostfs/hostfs_kern.c             |   4 +-
>  fs/hpfs/file.c                      |   4 +-
>  fs/internal.h                       |   4 +
>  fs/iov-iter.c                       | 411 ++++++++++++++++++++++++++++++++++
>  fs/jffs2/file.c                     |   8 +-
>  fs/jfs/file.c                       |   4 +-
>  fs/jfs/inode.c                      |   7 +-
>  fs/logfs/file.c                     |   4 +-
>  fs/minix/file.c                     |   4 +-
>  fs/nfs/direct.c                     | 302 ++++++++++++++++---------
>  fs/nfs/file.c                       |  33 ++-
>  fs/nfs/internal.h                   |   4 +-
>  fs/nfs/nfs4file.c                   |   4 +-
>  fs/nilfs2/file.c                    |   4 +-
>  fs/nilfs2/inode.c                   |   8 +-
>  fs/ocfs2/aops.c                     |   8 +-
>  fs/ocfs2/aops.h                     |   2 +-
>  fs/ocfs2/file.c                     |  55 ++---
>  fs/ocfs2/ocfs2_trace.h              |   6 +-
>  fs/omfs/file.c                      |   4 +-
>  fs/ramfs/file-mmu.c                 |   4 +-
>  fs/ramfs/file-nommu.c               |   4 +-
>  fs/read_write.c                     |  78 +++++--
>  fs/reiserfs/file.c                  |   4 +-
>  fs/reiserfs/inode.c                 |   7 +-
>  fs/romfs/mmap-nommu.c               |   2 +-
>  fs/sysv/file.c                      |   4 +-
>  fs/ubifs/file.c                     |  12 +-
>  fs/udf/file.c                       |  13 +-
>  fs/udf/inode.c                      |  10 +-
>  fs/ufs/file.c                       |   4 +-
>  fs/xfs/xfs_aops.c                   |  13 +-
>  fs/xfs/xfs_file.c                   |  51 ++---
>  include/linux/aio.h                 |  20 +-
>  include/linux/bio.h                 |   8 +
>  include/linux/blk_types.h           |   2 -
>  include/linux/fs.h                  | 165 ++++++++++++--
>  include/linux/nfs_fs.h              |  13 +-
>  include/uapi/linux/aio_abi.h        |   2 +
>  include/uapi/linux/loop.h           |   1 +
>  mm/filemap.c                        | 433 ++++++++++++++----------------------
>  mm/page_io.c                        |  15 +-
>  mm/shmem.c                          |  61 ++---
>  87 files changed, 1862 insertions(+), 1002 deletions(-)
>  create mode 100644 fs/iov-iter.c
>
> --
> 1.8.3.4
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]
  Powered by Linux