diff options
author | 2009-12-27 17:01:42 +0200 | |
---|---|---|
committer | 2010-01-05 09:14:32 +0200 | |
commit | efd124b999fb4d426b30675f1684521af0872789 (patch) | |
tree | f9421d61b3c4faf682fc1a52b72b241fa9b37558 /net/lapb/lapb_subr.c | |
parent | exofs: fix pnfs_osd re-definitions in pre-pnfs trees (diff) | |
download | linux-dev-efd124b999fb4d426b30675f1684521af0872789.tar.xz linux-dev-efd124b999fb4d426b30675f1684521af0872789.zip |
exofs: simple_write_end does not mark_inode_dirty
exofs uses simple_write_end() for it's .write_end handler. But
it is not enough because simple_write_end() does not call
mark_inode_dirty() when it extends i_size. So even if we do
call mark_inode_dirty at beginning of write out, with a very
long IO and a saturated system we might get the .write_inode()
called while still extend-writing to file and miss out on the last
i_size updates.
So override .write_end, call simple_write_end(), and afterwords if
i_size was changed call mark_inode_dirty().
It stands to logic that since simple_write_end() was the one extending
i_size it should also call mark_inode_dirty(). But it looks like all
users of simple_write_end() are memory-bound pseudo filesystems, who
could careless about mark_inode_dirty(). I might submit a
warning-comment patch to simple_write_end() in future.
CC: Stable <stable@kernel.org>
Signed-off-by: Boaz Harrosh <bharrosh@panasas.com>
Diffstat (limited to 'net/lapb/lapb_subr.c')
0 files changed, 0 insertions, 0 deletions