git.samba.org
/
sfrench
/
cifs-2.6.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'for-linus' of git://git.open-osd.org/linux-open-osd
[sfrench/cifs-2.6.git]
/
fs
/
exofs
/
file.c
diff --git
a/fs/exofs/file.c
b/fs/exofs/file.c
index f9bfe2b501d5ecac5e9bc936173131d6b739c2d9..68cb23e3bb9828e88c2647a7f028db6d2f94bd78 100644
(file)
--- a/
fs/exofs/file.c
+++ b/
fs/exofs/file.c
@@
-30,9
+30,6
@@
* along with exofs; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
* along with exofs; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
-
-#include <linux/buffer_head.h>
-
#include "exofs.h"
static int exofs_release_file(struct inode *inode, struct file *filp)
#include "exofs.h"
static int exofs_release_file(struct inode *inode, struct file *filp)
@@
-40,19
+37,27
@@
static int exofs_release_file(struct inode *inode, struct file *filp)
return 0;
}
return 0;
}
+/* exofs_file_fsync - flush the inode to disk
+ *
+ * Note, in exofs all metadata is written as part of inode, regardless.
+ * The writeout is synchronous
+ */
static int exofs_file_fsync(struct file *filp, int datasync)
{
int ret;
static int exofs_file_fsync(struct file *filp, int datasync)
{
int ret;
- struct address_space *mapping = filp->f_mapping;
- struct inode *inode = mapping->host;
+ struct inode *inode = filp->f_mapping->host;
+ struct writeback_control wbc = {
+ .sync_mode = WB_SYNC_ALL,
+ .nr_to_write = 0, /* metadata-only; caller takes care of data */
+ };
struct super_block *sb;
struct super_block *sb;
- ret = filemap_write_and_wait(mapping);
- if (ret)
- return ret;
+ if (!(inode->i_state & I_DIRTY))
+ return 0;
+ if (datasync && !(inode->i_state & I_DIRTY_DATASYNC))
+ return 0;
- /* sync the inode attributes */
- ret = write_inode_now(inode, 1);
+ ret = sync_inode(inode, &wbc);
/* This is a good place to write the sb */
/* TODO: Sechedule an sb-sync on create */
/* This is a good place to write the sb */
/* TODO: Sechedule an sb-sync on create */
@@
-65,9
+70,9
@@
static int exofs_file_fsync(struct file *filp, int datasync)
static int exofs_flush(struct file *file, fl_owner_t id)
{
static int exofs_flush(struct file *file, fl_owner_t id)
{
-
exofs_file_fsync(file, 1
);
+
int ret = vfs_fsync(file, 0
);
/* TODO: Flush the OSD target */
/* TODO: Flush the OSD target */
- return
0
;
+ return
ret
;
}
const struct file_operations exofs_file_operations = {
}
const struct file_operations exofs_file_operations = {