From 8dafb206406714d1cc075f077d520a8a993bc421 Mon Sep 17 00:00:00 2001 From: Andrew Morton Date: Fri, 24 Mar 2006 03:18:14 -0800 Subject: [PATCH] --- yaml --- r: 23445 b: refs/heads/master c: 18e79b40ed9c5223b88771f805c69f5993fc131b h: refs/heads/master i: 23443: 19a6f383aa0a2d5f7abe0a3661bf458ab75040b4 v: v3 --- [refs] | 2 +- trunk/fs/buffer.c | 43 +++++++++++++++++++++------------------- trunk/include/linux/fs.h | 1 + 3 files changed, 25 insertions(+), 21 deletions(-) diff --git a/[refs] b/[refs] index af3ce9660732..b0e8e3e68e17 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 676758bdb7bfca8413a85203921746f446e237be +refs/heads/master: 18e79b40ed9c5223b88771f805c69f5993fc131b diff --git a/trunk/fs/buffer.c b/trunk/fs/buffer.c index 24262ea8cc50..6d77ce9f54e5 100644 --- a/trunk/fs/buffer.c +++ b/trunk/fs/buffer.c @@ -327,31 +327,24 @@ int file_fsync(struct file *filp, struct dentry *dentry, int datasync) return ret; } -static long do_fsync(unsigned int fd, int datasync) +long do_fsync(struct file *file, int datasync) { - struct file * file; - struct address_space *mapping; - int ret, err; - - ret = -EBADF; - file = fget(fd); - if (!file) - goto out; + int ret; + int err; + struct address_space *mapping = file->f_mapping; - ret = -EINVAL; if (!file->f_op || !file->f_op->fsync) { /* Why? We can still call filemap_fdatawrite */ - goto out_putf; + ret = -EINVAL; + goto out; } - mapping = file->f_mapping; - current->flags |= PF_SYNCWRITE; ret = filemap_fdatawrite(mapping); /* - * We need to protect against concurrent writers, - * which could cause livelocks in fsync_buffers_list + * We need to protect against concurrent writers, which could cause + * livelocks in fsync_buffers_list(). */ mutex_lock(&mapping->host->i_mutex); err = file->f_op->fsync(file, file->f_dentry, datasync); @@ -362,21 +355,31 @@ static long do_fsync(unsigned int fd, int datasync) if (!ret) ret = err; current->flags &= ~PF_SYNCWRITE; - -out_putf: - fput(file); out: return ret; } +static long __do_fsync(unsigned int fd, int datasync) +{ + struct file *file; + int ret = -EBADF; + + file = fget(fd); + if (file) { + ret = do_fsync(file, datasync); + fput(file); + } + return ret; +} + asmlinkage long sys_fsync(unsigned int fd) { - return do_fsync(fd, 0); + return __do_fsync(fd, 0); } asmlinkage long sys_fdatasync(unsigned int fd) { - return do_fsync(fd, 1); + return __do_fsync(fd, 1); } /* diff --git a/trunk/include/linux/fs.h b/trunk/include/linux/fs.h index 092cfaee0cd2..215696a0f16f 100644 --- a/trunk/include/linux/fs.h +++ b/trunk/include/linux/fs.h @@ -1478,6 +1478,7 @@ extern int wait_on_page_writeback_range(struct address_space *mapping, extern int __filemap_fdatawrite_range(struct address_space *mapping, loff_t start, loff_t end, int sync_mode); +extern long do_fsync(struct file *file, int datasync); extern void sync_supers(void); extern void sync_filesystems(int wait); extern void emergency_sync(void);