This patch fixes vectored write support on fat to do the nessecary non-standard action done in write() aswell.
Also adds aio support and makes read/write wrappers around the aio version. --- 1.28/fs/fat/file.c 2005-01-21 06:02:08 +01:00 +++ edited/fs/fat/file.c 2005-01-25 14:10:05 +01:00 @@ -12,13 +12,28 @@ #include <linux/smp_lock.h> #include <linux/buffer_head.h> -static ssize_t fat_file_write(struct file *filp, const char __user *buf, - size_t count, loff_t *ppos) +static ssize_t fat_file_aio_write(struct kiocb *iocb, const char __user *buf, + size_t count, loff_t pos) +{ + struct inode *inode = iocb->ki_filp->f_dentry->d_inode; + int retval; + + retval = generic_file_aio_write(iocb, buf, count, pos); + if (retval > 0) { + inode->i_mtime = inode->i_ctime = CURRENT_TIME_SEC; + MSDOS_I(inode)->i_attrs |= ATTR_ARCH; + mark_inode_dirty(inode); + } + return retval; +} + +static ssize_t fat_file_writev(struct file *filp, const struct iovec *iov, + unsigned long nr_segs, loff_t *ppos) { struct inode *inode = filp->f_dentry->d_inode; int retval; - retval = generic_file_write(filp, buf, count, ppos); + retval = generic_file_writev(filp, iov, nr_segs, ppos); if (retval > 0) { inode->i_mtime = inode->i_ctime = CURRENT_TIME_SEC; MSDOS_I(inode)->i_attrs |= ATTR_ARCH; @@ -29,12 +44,14 @@ struct file_operations fat_file_operations = { .llseek = generic_file_llseek, - .read = generic_file_read, - .write = fat_file_write, + .read = do_sync_read, + .write = do_sync_write, + .readv = generic_file_readv, + .writev = fat_file_writev, + .aio_read = generic_file_aio_read, + .aio_write = fat_file_aio_write, .mmap = generic_file_mmap, .fsync = file_fsync, - .readv = generic_file_readv, - .writev = generic_file_writev, .sendfile = generic_file_sendfile, }; - To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html