|
|
|
/*
|
|
|
|
* fsync.c
|
|
|
|
*
|
|
|
|
* PURPOSE
|
|
|
|
* Fsync handling routines for the OSTA-UDF(tm) filesystem.
|
|
|
|
*
|
|
|
|
* COPYRIGHT
|
|
|
|
* This file is distributed under the terms of the GNU General Public
|
|
|
|
* License (GPL). Copies of the GPL can be obtained from:
|
|
|
|
* ftp://prep.ai.mit.edu/pub/gnu/GPL
|
|
|
|
* Each contributing author retains all rights to their own work.
|
|
|
|
*
|
|
|
|
* (C) 1999-2001 Ben Fennema
|
|
|
|
* (C) 1999-2000 Stelias Computing Inc
|
|
|
|
*
|
|
|
|
* HISTORY
|
|
|
|
*
|
|
|
|
* 05/22/99 blf Created.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "udfdecl.h"
|
|
|
|
|
|
|
|
#include <linux/fs.h>
|
|
|
|
|
|
|
|
static int udf_fsync_inode(struct inode *, int);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* File may be NULL when we are called. Perhaps we shouldn't
|
|
|
|
* even pass file to fsync ?
|
|
|
|
*/
|
|
|
|
|
|
|
|
int udf_fsync_file(struct file *file, struct dentry *dentry, int datasync)
|
|
|
|
{
|
|
|
|
struct inode *inode = dentry->d_inode;
|
|
|
|
|
|
|
|
return udf_fsync_inode(inode, datasync);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int udf_fsync_inode(struct inode *inode, int datasync)
|
|
|
|
{
|
|
|
|
int err;
|
|
|
|
|
|
|
|
err = sync_mapping_buffers(inode->i_mapping);
|
|
|
|
if (!(inode->i_state & I_DIRTY))
|
|
|
|
return err;
|
|
|
|
if (datasync && !(inode->i_state & I_DIRTY_DATASYNC))
|
|
|
|
return err;
|
|
|
|
|
|
|
|
err |= udf_sync_inode(inode);
|
|
|
|
|
|
|
|
return err ? -EIO : 0;
|
|
|
|
}
|