|
@@ -627,6 +627,7 @@ static void nfs_server_set_fsinfo(struct nfs_server *server, struct nfs_fsinfo *
|
|
if (server->rsize > NFS_MAX_FILE_IO_SIZE)
|
|
if (server->rsize > NFS_MAX_FILE_IO_SIZE)
|
|
server->rsize = NFS_MAX_FILE_IO_SIZE;
|
|
server->rsize = NFS_MAX_FILE_IO_SIZE;
|
|
server->rpages = (server->rsize + PAGE_CACHE_SIZE - 1) >> PAGE_CACHE_SHIFT;
|
|
server->rpages = (server->rsize + PAGE_CACHE_SIZE - 1) >> PAGE_CACHE_SHIFT;
|
|
|
|
+
|
|
server->backing_dev_info.ra_pages = server->rpages * NFS_MAX_READAHEAD;
|
|
server->backing_dev_info.ra_pages = server->rpages * NFS_MAX_READAHEAD;
|
|
|
|
|
|
if (server->wsize > max_rpc_payload)
|
|
if (server->wsize > max_rpc_payload)
|
|
@@ -677,6 +678,10 @@ static int nfs_probe_fsinfo(struct nfs_server *server, struct nfs_fh *mntfh, str
|
|
goto out_error;
|
|
goto out_error;
|
|
|
|
|
|
nfs_server_set_fsinfo(server, &fsinfo);
|
|
nfs_server_set_fsinfo(server, &fsinfo);
|
|
|
|
+ error = bdi_init(&server->backing_dev_info);
|
|
|
|
+ if (error)
|
|
|
|
+ goto out_error;
|
|
|
|
+
|
|
|
|
|
|
/* Get some general file system info */
|
|
/* Get some general file system info */
|
|
if (server->namelen == 0) {
|
|
if (server->namelen == 0) {
|
|
@@ -756,6 +761,7 @@ void nfs_free_server(struct nfs_server *server)
|
|
nfs_put_client(server->nfs_client);
|
|
nfs_put_client(server->nfs_client);
|
|
|
|
|
|
nfs_free_iostats(server->io_stats);
|
|
nfs_free_iostats(server->io_stats);
|
|
|
|
+ bdi_destroy(&server->backing_dev_info);
|
|
kfree(server);
|
|
kfree(server);
|
|
nfs_release_automount_timer();
|
|
nfs_release_automount_timer();
|
|
dprintk("<-- nfs_free_server()\n");
|
|
dprintk("<-- nfs_free_server()\n");
|