summaryrefslogtreecommitdiff
path: root/other/ecfs/fsync.c
diff options
context:
space:
mode:
authorRoot THC2026-02-24 12:42:47 +0000
committerRoot THC2026-02-24 12:42:47 +0000
commitc9cbeced5b3f2bdd7407e29c0811e65954132540 (patch)
treeaefc355416b561111819de159ccbd86c3004cf88 /other/ecfs/fsync.c
parent073fe4bf9fca6bf40cef2886d75df832ef4b6fca (diff)
initial
Diffstat (limited to 'other/ecfs/fsync.c')
-rw-r--r--other/ecfs/fsync.c54
1 files changed, 54 insertions, 0 deletions
diff --git a/other/ecfs/fsync.c b/other/ecfs/fsync.c
new file mode 100644
index 0000000..4079de1
--- /dev/null
+++ b/other/ecfs/fsync.c
@@ -0,0 +1,54 @@
1/*
2 * linux/fs/ecfs/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 * ecfsfs 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 <linux/fs_ecfs.h>
26#include <linux/ecfs_fs.h>
27#include <linux/locks.h>
28#include <linux/smp_lock.h>
29
30
31/*
32 * File may be NULL when we are called. Perhaps we shouldn't
33 * even pass file to fsync ?
34 */
35
36int ecfs_sync_file(struct file * file, struct dentry *dentry, int datasync)
37{
38 struct inode *inode = dentry->d_inode;
39 return ecfs_fsync_inode(inode, datasync);
40}
41
42int ecfs_fsync_inode(struct inode *inode, int datasync)
43{
44 int err;
45
46 err = fsync_inode_buffers(inode);
47 if (!(inode->i_state & I_DIRTY))
48 return err;
49 if (datasync && !(inode->i_state & I_DIRTY_DATASYNC))
50 return err;
51
52 err |= ecfs_sync_inode(inode);
53 return err ? -EIO : 0;
54}