Linux-2.6.12-rc2
[linux-2.6/linux-acpi-2.6/ibm-acpi-2.6.git] / fs / udf / fsync.c
blob2dde6b888c2bac2e21d22c590a333ea5648e5b92
1 /*
2 * fsync.c
4 * PURPOSE
5 * Fsync handling routines for the OSTA-UDF(tm) filesystem.
7 * CONTACTS
8 * E-mail regarding any portion of the Linux UDF file system should be
9 * directed to the development team mailing list (run by majordomo):
10 * linux_udf@hpesjro.fc.hp.com
12 * COPYRIGHT
13 * This file is distributed under the terms of the GNU General Public
14 * License (GPL). Copies of the GPL can be obtained from:
15 * ftp://prep.ai.mit.edu/pub/gnu/GPL
16 * Each contributing author retains all rights to their own work.
18 * (C) 1999-2001 Ben Fennema
19 * (C) 1999-2000 Stelias Computing Inc
21 * HISTORY
23 * 05/22/99 blf Created.
26 #include "udfdecl.h"
28 #include <linux/fs.h>
29 #include <linux/smp_lock.h>
31 static int udf_fsync_inode(struct inode *, int);
34 * File may be NULL when we are called. Perhaps we shouldn't
35 * even pass file to fsync ?
38 int udf_fsync_file(struct file * file, struct dentry *dentry, int datasync)
40 struct inode *inode = dentry->d_inode;
41 return udf_fsync_inode(inode, datasync);
44 static int udf_fsync_inode(struct inode *inode, int datasync)
46 int err;
48 err = sync_mapping_buffers(inode->i_mapping);
49 if (!(inode->i_state & I_DIRTY))
50 return err;
51 if (datasync && !(inode->i_state & I_DIRTY_DATASYNC))
52 return err;
54 err |= udf_sync_inode (inode);
55 return err ? -EIO : 0;