aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs/blocklayout
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2014-08-21 12:09:26 -0400
committerTrond Myklebust <trond.myklebust@primarydata.com>2014-09-10 15:47:02 -0400
commite3aaf7f2b8e9e858c0d6626577d3456bf6070e5a (patch)
tree08ff28dbec68a9af3b0528340e642b9c8ded3b08 /fs/nfs/blocklayout
parent5f919c9f10c1cf821ee5f414683214a361a1b98c (diff)
pnfs/blocklayout: reject pnfs blocksize larger than page size
The Linux VM subsystem can't support block sizes larger than page size for block based filesystems very well. While this can be hacked around to some extent for simple filesystems the read-modify-write cycles required for pnfs block invalid extents are extremly deadlock prone when operating on multiple pages. Reject this case early on instead of pretending to support it (badly). Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Diffstat (limited to 'fs/nfs/blocklayout')
-rw-r--r--fs/nfs/blocklayout/blocklayout.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/nfs/blocklayout/blocklayout.c b/fs/nfs/blocklayout/blocklayout.c
index cbb1797149d5..6c1a4212919d 100644
--- a/fs/nfs/blocklayout/blocklayout.c
+++ b/fs/nfs/blocklayout/blocklayout.c
@@ -1115,6 +1115,12 @@ bl_set_layoutdriver(struct nfs_server *server, const struct nfs_fh *fh)
1115 dprintk("%s Server did not return blksize\n", __func__); 1115 dprintk("%s Server did not return blksize\n", __func__);
1116 return -EINVAL; 1116 return -EINVAL;
1117 } 1117 }
1118 if (server->pnfs_blksize > PAGE_SIZE) {
1119 printk(KERN_ERR "%s: pNFS blksize %d not supported.\n",
1120 __func__, server->pnfs_blksize);
1121 return -EINVAL;
1122 }
1123
1118 b_mt_id = kzalloc(sizeof(struct block_mount_id), GFP_NOFS); 1124 b_mt_id = kzalloc(sizeof(struct block_mount_id), GFP_NOFS);
1119 if (!b_mt_id) { 1125 if (!b_mt_id) {
1120 status = -ENOMEM; 1126 status = -ENOMEM;