- patches.apparmor/remove_suid_new_case_in_2.6.22.diff: Merge fix.
[linux-flexiantxendom0-3.2.10.git] / fs / ext2 / fsync.c
1 /*
2  *  linux/fs/ext2/fsync.c
3  *
4  *  Copyright (C) 1993  Stephen Tweedie (sct@dcs.ed.ac.uk)
5  *  from
6  *  Copyright (C) 1992  Remy Card (card@masi.ibp.fr)
7  *                      Laboratoire MASI - Institut Blaise Pascal
8  *                      Universite Pierre et Marie Curie (Paris VI)
9  *  from
10  *  linux/fs/minix/truncate.c   Copyright (C) 1991, 1992  Linus Torvalds
11  * 
12  *  ext2fs fsync primitive
13  *
14  *  Big-endian to little-endian byte-swapping/bitmaps by
15  *        David S. Miller (davem@caip.rutgers.edu), 1995
16  * 
17  *  Removed unnecessary code duplication for little endian machines
18  *  and excessive __inline__s. 
19  *        Andi Kleen, 1997
20  *
21  * Major simplications and cleanup - we only need to do the metadata, because
22  * we can depend on generic_block_fdatasync() to sync the data blocks.
23  */
24
25 #include "ext2.h"
26 #include <linux/buffer_head.h>          /* for sync_mapping_buffers() */
27 #include <linux/pagemap.h>
28
29
30 /*
31  *      File may be NULL when we are called. Perhaps we shouldn't
32  *      even pass file to fsync ?
33  */
34
35 int ext2_sync_file(struct file *file, struct dentry *dentry, int datasync)
36 {
37         struct inode *inode = dentry->d_inode;
38         struct super_block *sb = inode->i_sb;
39         int err;
40         int ret;
41
42         ret = sync_mapping_buffers(inode->i_mapping);
43
44         /* it might make more sense to ext2_error on -EIO from
45          * sync_mapping_buffers as well, but those errors are isolated to just
46          * this file. We can safely return -EIO to fsync and let the app know
47          * they have a problem.
48          *
49          * AS_EIO indicates a failure to write a metadata page, but we have no
50          * way of knowing which one.  It's best to force readonly and let fsck
51          * figure it all out.
52          */
53         if (test_and_clear_bit(AS_EIO, &sb->s_bdev->bd_inode->i_mapping->flags)) {
54                 ext2_error(sb, "ext2_sync_file", "metadata io error");
55                 if (!ret)
56                         ret = -EIO;
57         }
58         if (!(inode->i_state & I_DIRTY))
59                 return ret;
60         if (datasync && !(inode->i_state & I_DIRTY_DATASYNC))
61                 return ret;
62
63         err = ext2_sync_inode(inode);
64         if (ret == 0)
65                 ret = err;
66         return ret;
67 }