linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] quota: Properly invalidate caches even for filesystems with blocksize < pagesize
@ 2010-03-02 17:40 Jan Kara
  2010-03-02 17:56 ` Christoph Hellwig
  0 siblings, 1 reply; 2+ messages in thread
From: Jan Kara @ 2010-03-02 17:40 UTC (permalink / raw)
  To: linux-fsdevel; +Cc: hch, dmonakhov, Jan Kara

Sometimes invalidate_bdev() can fail to invalidate a part of block
device cache because of dirty data. If the filesystem has blocksize
smaller than page size, this can happen even for pages containing
quota files and thus kernel would operate on stale data. Fix the
issue by syncing the filesystem before invalidating the cache.

Signed-off-by: Jan Kara <jack@suse.cz>
---
 fs/quota/dquot.c |   12 +++++++-----
 1 files changed, 7 insertions(+), 5 deletions(-)

 I'm sending this patch for review. I plan to merge this fix via my tree.

								Honza

diff --git a/fs/quota/dquot.c b/fs/quota/dquot.c
index 4d2041f..10d021d 100644
--- a/fs/quota/dquot.c
+++ b/fs/quota/dquot.c
@@ -2033,11 +2033,13 @@ static int vfs_load_quota_inode(struct inode *inode, int type, int format_id,
 	}
 
 	if (!(dqopt->flags & DQUOT_QUOTA_SYS_FILE)) {
-		/* As we bypass the pagecache we must now flush the inode so
-		 * that we see all the changes from userspace... */
-		write_inode_now(inode, 1);
-		/* And now flush the block cache so that kernel sees the
-		 * changes */
+		/* As we bypass the pagecache we must now flush all the
+		 * dirty data and invalidate caches so that kernel sees
+		 * changes from userspace. It is not enough to just flush
+		 * the quota file since if blocksize < pagesize, invalidation
+		 * of the cache could fail because of other unrelated dirty
+		 * data */
+		sync_filesystem(sb);
 		invalidate_bdev(sb->s_bdev);
 	}
 	mutex_lock(&dqopt->dqonoff_mutex);
-- 
1.6.4.2


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] quota: Properly invalidate caches even for filesystems with blocksize < pagesize
  2010-03-02 17:40 [PATCH] quota: Properly invalidate caches even for filesystems with blocksize < pagesize Jan Kara
@ 2010-03-02 17:56 ` Christoph Hellwig
  0 siblings, 0 replies; 2+ messages in thread
From: Christoph Hellwig @ 2010-03-02 17:56 UTC (permalink / raw)
  To: Jan Kara; +Cc: linux-fsdevel, hch, dmonakhov

On Tue, Mar 02, 2010 at 06:40:47PM +0100, Jan Kara wrote:
> Sometimes invalidate_bdev() can fail to invalidate a part of block
> device cache because of dirty data. If the filesystem has blocksize
> smaller than page size, this can happen even for pages containing
> quota files and thus kernel would operate on stale data. Fix the
> issue by syncing the filesystem before invalidating the cache.

Looks good to me,


Reviewed-by: Christoph Hellwig <hch@lst.de>


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2010-03-02 17:56 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-03-02 17:40 [PATCH] quota: Properly invalidate caches even for filesystems with blocksize < pagesize Jan Kara
2010-03-02 17:56 ` Christoph Hellwig

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).