aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/nfs/client.c10
-rw-r--r--fs/nfs/super.c2
-rw-r--r--mm/page-writeback.c11
3 files changed, 17 insertions, 6 deletions
diff --git a/fs/nfs/client.c b/fs/nfs/client.c
index e350bd6a2334..a7ce15d3c248 100644
--- a/fs/nfs/client.c
+++ b/fs/nfs/client.c
@@ -933,10 +933,6 @@ static int nfs_probe_fsinfo(struct nfs_server *server, struct nfs_fh *mntfh, str
933 goto out_error; 933 goto out_error;
934 934
935 nfs_server_set_fsinfo(server, &fsinfo); 935 nfs_server_set_fsinfo(server, &fsinfo);
936 error = bdi_init(&server->backing_dev_info);
937 if (error)
938 goto out_error;
939
940 936
941 /* Get some general file system info */ 937 /* Get some general file system info */
942 if (server->namelen == 0) { 938 if (server->namelen == 0) {
@@ -995,6 +991,12 @@ static struct nfs_server *nfs_alloc_server(void)
995 return NULL; 991 return NULL;
996 } 992 }
997 993
994 if (bdi_init(&server->backing_dev_info)) {
995 nfs_free_iostats(server->io_stats);
996 kfree(server);
997 return NULL;
998 }
999
998 return server; 1000 return server;
999} 1001}
1000 1002
diff --git a/fs/nfs/super.c b/fs/nfs/super.c
index de935692d40d..f1cc0587cfef 100644
--- a/fs/nfs/super.c
+++ b/fs/nfs/super.c
@@ -2190,8 +2190,8 @@ static void nfs_kill_super(struct super_block *s)
2190{ 2190{
2191 struct nfs_server *server = NFS_SB(s); 2191 struct nfs_server *server = NFS_SB(s);
2192 2192
2193 bdi_unregister(&server->backing_dev_info);
2194 kill_anon_super(s); 2193 kill_anon_super(s);
2194 bdi_unregister(&server->backing_dev_info);
2195 nfs_fscache_release_super_cookie(s); 2195 nfs_fscache_release_super_cookie(s);
2196 nfs_free_server(server); 2196 nfs_free_server(server);
2197} 2197}
diff --git a/mm/page-writeback.c b/mm/page-writeback.c
index 1eea4fa0d410..d1ba46441053 100644
--- a/mm/page-writeback.c
+++ b/mm/page-writeback.c
@@ -485,6 +485,7 @@ static void balance_dirty_pages(struct address_space *mapping)
485 unsigned long bdi_thresh; 485 unsigned long bdi_thresh;
486 unsigned long pages_written = 0; 486 unsigned long pages_written = 0;
487 unsigned long write_chunk = sync_writeback_pages(); 487 unsigned long write_chunk = sync_writeback_pages();
488 unsigned long pause = 1;
488 489
489 struct backing_dev_info *bdi = mapping->backing_dev_info; 490 struct backing_dev_info *bdi = mapping->backing_dev_info;
490 491
@@ -561,7 +562,15 @@ static void balance_dirty_pages(struct address_space *mapping)
561 if (pages_written >= write_chunk) 562 if (pages_written >= write_chunk)
562 break; /* We've done our duty */ 563 break; /* We've done our duty */
563 564
564 schedule_timeout(1); 565 schedule_timeout_interruptible(pause);
566
567 /*
568 * Increase the delay for each loop, up to our previous
569 * default of taking a 100ms nap.
570 */
571 pause <<= 1;
572 if (pause > HZ / 10)
573 pause = HZ / 10;
565 } 574 }
566 575
567 if (bdi_nr_reclaimable + bdi_nr_writeback < bdi_thresh && 576 if (bdi_nr_reclaimable + bdi_nr_writeback < bdi_thresh &&