Commit d8091614 authored by Miklos Szeredi's avatar Miklos Szeredi Committed by Linus Torvalds

[PATCH] fuse: add blksize option

Add 'blksize' option for block device based filesystems.  During
initialization this is used to set the block size on the device and the super
block.  The default block size is 512bytes.
Signed-off-by: default avatarMiklos Szeredi <miklos@szeredi.hu>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent d6392f87
...@@ -110,6 +110,11 @@ Mount options ...@@ -110,6 +110,11 @@ Mount options
The default is infinite. Note that the size of read requests is The default is infinite. Note that the size of read requests is
limited anyway to 32 pages (which is 128kbyte on i386). limited anyway to 32 pages (which is 128kbyte on i386).
'blksize=N'
Set the block size for the filesystem. The default is 512. This
option is only valid for 'fuseblk' type mounts.
Control filesystem Control filesystem
~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~
......
...@@ -39,6 +39,7 @@ struct fuse_mount_data { ...@@ -39,6 +39,7 @@ struct fuse_mount_data {
unsigned group_id_present : 1; unsigned group_id_present : 1;
unsigned flags; unsigned flags;
unsigned max_read; unsigned max_read;
unsigned blksize;
}; };
static struct inode *fuse_alloc_inode(struct super_block *sb) static struct inode *fuse_alloc_inode(struct super_block *sb)
...@@ -274,6 +275,7 @@ enum { ...@@ -274,6 +275,7 @@ enum {
OPT_DEFAULT_PERMISSIONS, OPT_DEFAULT_PERMISSIONS,
OPT_ALLOW_OTHER, OPT_ALLOW_OTHER,
OPT_MAX_READ, OPT_MAX_READ,
OPT_BLKSIZE,
OPT_ERR OPT_ERR
}; };
...@@ -285,14 +287,16 @@ static match_table_t tokens = { ...@@ -285,14 +287,16 @@ static match_table_t tokens = {
{OPT_DEFAULT_PERMISSIONS, "default_permissions"}, {OPT_DEFAULT_PERMISSIONS, "default_permissions"},
{OPT_ALLOW_OTHER, "allow_other"}, {OPT_ALLOW_OTHER, "allow_other"},
{OPT_MAX_READ, "max_read=%u"}, {OPT_MAX_READ, "max_read=%u"},
{OPT_BLKSIZE, "blksize=%u"},
{OPT_ERR, NULL} {OPT_ERR, NULL}
}; };
static int parse_fuse_opt(char *opt, struct fuse_mount_data *d) static int parse_fuse_opt(char *opt, struct fuse_mount_data *d, int is_bdev)
{ {
char *p; char *p;
memset(d, 0, sizeof(struct fuse_mount_data)); memset(d, 0, sizeof(struct fuse_mount_data));
d->max_read = ~0; d->max_read = ~0;
d->blksize = 512;
while ((p = strsep(&opt, ",")) != NULL) { while ((p = strsep(&opt, ",")) != NULL) {
int token; int token;
...@@ -345,6 +349,12 @@ static int parse_fuse_opt(char *opt, struct fuse_mount_data *d) ...@@ -345,6 +349,12 @@ static int parse_fuse_opt(char *opt, struct fuse_mount_data *d)
d->max_read = value; d->max_read = value;
break; break;
case OPT_BLKSIZE:
if (!is_bdev || match_int(&args[0], &value))
return 0;
d->blksize = value;
break;
default: default:
return 0; return 0;
} }
...@@ -500,15 +510,21 @@ static int fuse_fill_super(struct super_block *sb, void *data, int silent) ...@@ -500,15 +510,21 @@ static int fuse_fill_super(struct super_block *sb, void *data, int silent)
struct dentry *root_dentry; struct dentry *root_dentry;
struct fuse_req *init_req; struct fuse_req *init_req;
int err; int err;
int is_bdev = sb->s_bdev != NULL;
if (sb->s_flags & MS_MANDLOCK) if (sb->s_flags & MS_MANDLOCK)
return -EINVAL; return -EINVAL;
if (!parse_fuse_opt((char *) data, &d)) if (!parse_fuse_opt((char *) data, &d, is_bdev))
return -EINVAL; return -EINVAL;
if (is_bdev) {
if (!sb_set_blocksize(sb, d.blksize))
return -EINVAL;
} else {
sb->s_blocksize = PAGE_CACHE_SIZE; sb->s_blocksize = PAGE_CACHE_SIZE;
sb->s_blocksize_bits = PAGE_CACHE_SHIFT; sb->s_blocksize_bits = PAGE_CACHE_SHIFT;
}
sb->s_magic = FUSE_SUPER_MAGIC; sb->s_magic = FUSE_SUPER_MAGIC;
sb->s_op = &fuse_super_operations; sb->s_op = &fuse_super_operations;
sb->s_maxbytes = MAX_LFS_FILESIZE; sb->s_maxbytes = MAX_LFS_FILESIZE;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment