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 && |
