関数内でファイルシステムの aio_write を呼び出す。
.aio_write = generic_file_aio_write, fs/adfs/file.c: .aio_write = generic_file_aio_write, fs/affs/file.c: .aio_write = generic_file_aio_write, fs/bfs/file.c: .aio_write = generic_file_aio_write, fs/ecryptfs/file.c: .aio_write = generic_file_aio_write, fs/exofs/file.c: .aio_write = generic_file_aio_write, fs/ext2/file.c: .aio_write = generic_file_aio_write, fs/ext3/file.c: .aio_write = generic_file_aio_write, fs/fat/file.c: .aio_write = generic_file_aio_write, fs/hfs/inode.c: .aio_write = generic_file_aio_write, fs/hfsplus/inode.c: .aio_write = generic_file_aio_write, fs/hostfs/hostfs_kern.c: .aio_write = generic_file_aio_write, fs/hpfs/file.c: .aio_write = generic_file_aio_write, fs/jffs2/file.c: .aio_write = generic_file_aio_write, fs/jfs/file.c: .aio_write = generic_file_aio_write, fs/minix/file.c: .aio_write = generic_file_aio_write, fs/nilfs2/file.c: .aio_write = generic_file_aio_write, fs/omfs/file.c: .aio_write = generic_file_aio_write, fs/ramfs/file-mmu.c: .aio_write = generic_file_aio_write, fs/ramfs/file-nommu.c: .aio_write = generic_file_aio_write, fs/reiserfs/file.c: .aio_write = generic_file_aio_write, fs/sysv/file.c: .aio_write = generic_file_aio_write, fs/ufs/file.c:
.aio_write = afs_file_write, fs/afs/file.c: .aio_write = bad_file_aio_write, fs/bad_inode.c: .aio_write = blkdev_aio_write, fs/block_dev.c: .aio_write = cifs_file_aio_write, fs/cifs/cifsfs.c: .aio_write = ext4_file_write, fs/ext4/file.c: .aio_write = fuse_dev_write, fs/fuse/dev.c: .aio_write = fuse_file_aio_write, fs/fuse/file.c: .aio_write = gfs2_file_aio_write, fs/gfs2/file.c: .aio_write = nfs_file_write, fs/nfs/file.c: .aio_write = ntfs_file_aio_write, fs/ntfs/file.c: .aio_write = ocfs2_file_aio_write, fs/ocfs2/file.c: .aio_write = pipe_write, fs/pipe.c: .aio_write = smb_file_aio_write, fs/smbfs/file.c: .aio_write = ubifs_aio_write, fs/ubifs/file.c: .aio_write = udf_file_aio_write, fs/udf/file.c: .aio_write = xfs_file_aio_write, fs/xfs/linux-2.6/xfs_file.c:
ssize_t do_sync_write(struct file *filp, const char __user *buf, size_t len, loff_t *ppos) { struct iovec iov = { .iov_base = (void __user *)buf, .iov_len = len }; struct kiocb kiocb; ssize_t ret;
init_sync_kiocb(&kiocb, filp); kiocb.ki_pos = *ppos; kiocb.ki_left = len;
for (;;) { ret = filp->f_op->aio_write(&kiocb, &iov, 1, kiocb.ki_pos); if (ret != -EIOCBRETRY) break; wait_on_retry_sync_kiocb(&kiocb);
} if (-EIOCBQUEUED == ret) ret = wait_on_sync_kiocb(&kiocb); *ppos = kiocb.ki_pos;
return ret; } EXPORT_SYMBOL(do_sync_write);