diff options
-rw-r--r-- | fs/nfs/client.c | 10 | ||||
-rw-r--r-- | fs/nfs/super.c | 2 | ||||
-rw-r--r-- | mm/page-writeback.c | 11 |
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 && |