]> Pileus Git - ~andy/linux/blob - fs/xfs/linux-2.6/xfs_sync.h
2509db021f792c65fbee3cb3fb2a95be45ea2bbb
[~andy/linux] / fs / xfs / linux-2.6 / xfs_sync.h
1 /*
2  * Copyright (c) 2000-2006 Silicon Graphics, Inc.
3  * All Rights Reserved.
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License as
7  * published by the Free Software Foundation.
8  *
9  * This program is distributed in the hope that it would be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write the Free Software Foundation,
16  * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
17  */
18 #ifndef XFS_SYNC_H
19 #define XFS_SYNC_H 1
20
21 struct xfs_mount;
22
23 typedef struct bhv_vfs_sync_work {
24         struct list_head        w_list;
25         struct xfs_mount        *w_mount;
26         void                    *w_data;        /* syncer routine argument */
27         void                    (*w_syncer)(struct xfs_mount *, void *);
28 } bhv_vfs_sync_work_t;
29
30 #define SYNC_ATTR               0x0001  /* sync attributes */
31 #define SYNC_DELWRI             0x0004  /* look at delayed writes */
32 #define SYNC_WAIT               0x0008  /* wait for i/o to complete */
33 #define SYNC_BDFLUSH            0x0010  /* BDFLUSH is calling -- don't block */
34 #define SYNC_FSDATA             0x0020  /* flush fs data (e.g. superblocks) */
35 #define SYNC_REFCACHE           0x0040  /* prune some of the nfs ref cache */
36 #define SYNC_REMOUNT            0x0080  /* remount readonly, no dummy LRs */
37 #define SYNC_IOWAIT             0x0100  /* wait for all I/O to complete */
38
39 /*
40  * When remounting a filesystem read-only or freezing the filesystem,
41  * we have two phases to execute. This first phase is syncing the data
42  * before we quiesce the fielsystem, and the second is flushing all the
43  * inodes out after we've waited for all the transactions created by
44  * the first phase to complete. The second phase uses SYNC_INODE_QUIESCE
45  * to ensure that the inodes are written to their location on disk
46  * rather than just existing in transactions in the log. This means
47  * after a quiesce there is no log replay required to write the inodes
48  * to disk (this is the main difference between a sync and a quiesce).
49  */
50 #define SYNC_DATA_QUIESCE       (SYNC_DELWRI|SYNC_FSDATA|SYNC_WAIT|SYNC_IOWAIT)
51
52 int xfs_syncd_init(struct xfs_mount *mp);
53 void xfs_syncd_stop(struct xfs_mount *mp);
54
55 int xfs_sync(struct xfs_mount *mp, int flags);
56 int xfs_sync_inodes(struct xfs_mount *mp, int flags);
57 int xfs_sync_fsdata(struct xfs_mount *mp, int flags);
58
59 int xfs_quiesce_data(struct xfs_mount *mp);
60
61 void xfs_flush_inode(struct xfs_inode *ip);
62 void xfs_flush_device(struct xfs_inode *ip);
63
64 #endif