Commit c4bca7ac authored by Trond Myklebust's avatar Trond Myklebust

Decrement the nr_unstable page state after the COMMIT RPC call

completes instead of before. This ensures that writeback 
WB_SYNC_ALL does wait on completion.

Don't overreport the number of pages we wrote out. It is safer to
underreport.

Fix missing NFSv3 unstable write accounting in fs/fs-writeback.c
and mm/page-writeback.c
parent c2769b50
...@@ -367,7 +367,8 @@ void sync_inodes_sb(struct super_block *sb, int wait) ...@@ -367,7 +367,8 @@ void sync_inodes_sb(struct super_block *sb, int wait)
}; };
get_page_state(&ps); get_page_state(&ps);
wbc.nr_to_write = ps.nr_dirty + ps.nr_dirty / 4; wbc.nr_to_write = ps.nr_dirty + ps.nr_unstable +
(ps.nr_dirty + ps.nr_unstable) / 4;
spin_lock(&inode_lock); spin_lock(&inode_lock);
sync_sb_inodes(sb, &wbc); sync_sb_inodes(sb, &wbc);
spin_unlock(&inode_lock); spin_unlock(&inode_lock);
......
...@@ -280,8 +280,6 @@ nfs_writepages(struct address_space *mapping, struct writeback_control *wbc) ...@@ -280,8 +280,6 @@ nfs_writepages(struct address_space *mapping, struct writeback_control *wbc)
err = nfs_wb_all(inode); err = nfs_wb_all(inode);
} else } else
nfs_commit_file(inode, NULL, 0, 0, 0); nfs_commit_file(inode, NULL, 0, 0, 0);
/* Avoid races. Tell upstream we've done all we were told to do */
wbc->nr_to_write = 0;
out: out:
return err; return err;
} }
...@@ -490,7 +488,6 @@ nfs_scan_commit(struct inode *inode, struct list_head *dst, struct file *file, u ...@@ -490,7 +488,6 @@ nfs_scan_commit(struct inode *inode, struct list_head *dst, struct file *file, u
int res; int res;
res = nfs_scan_list(&nfsi->commit, dst, file, idx_start, npages); res = nfs_scan_list(&nfsi->commit, dst, file, idx_start, npages);
nfsi->ncommit -= res; nfsi->ncommit -= res;
sub_page_state(nr_unstable,res);
if ((nfsi->ncommit == 0) != list_empty(&nfsi->commit)) if ((nfsi->ncommit == 0) != list_empty(&nfsi->commit))
printk(KERN_ERR "NFS: desynchronized value of nfs_i.ncommit.\n"); printk(KERN_ERR "NFS: desynchronized value of nfs_i.ncommit.\n");
return res; return res;
...@@ -1009,6 +1006,7 @@ nfs_commit_done(struct rpc_task *task) ...@@ -1009,6 +1006,7 @@ nfs_commit_done(struct rpc_task *task)
{ {
struct nfs_write_data *data = (struct nfs_write_data *)task->tk_calldata; struct nfs_write_data *data = (struct nfs_write_data *)task->tk_calldata;
struct nfs_page *req; struct nfs_page *req;
int res = 0;
dprintk("NFS: %4d nfs_commit_done (status %d)\n", dprintk("NFS: %4d nfs_commit_done (status %d)\n",
task->tk_pid, task->tk_status); task->tk_pid, task->tk_status);
...@@ -1043,7 +1041,9 @@ nfs_commit_done(struct rpc_task *task) ...@@ -1043,7 +1041,9 @@ nfs_commit_done(struct rpc_task *task)
nfs_mark_request_dirty(req); nfs_mark_request_dirty(req);
next: next:
nfs_unlock_request(req); nfs_unlock_request(req);
res++;
} }
sub_page_state(nr_unstable,res);
} }
#endif #endif
......
...@@ -272,7 +272,7 @@ int wakeup_bdflush(long nr_pages) ...@@ -272,7 +272,7 @@ int wakeup_bdflush(long nr_pages)
struct page_state ps; struct page_state ps;
get_page_state(&ps); get_page_state(&ps);
nr_pages = ps.nr_dirty; nr_pages = ps.nr_dirty + ps.nr_unstable;
} }
return pdflush_operation(background_writeout, nr_pages); return pdflush_operation(background_writeout, nr_pages);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment