diff options
Diffstat (limited to 'fs/omfs')
| -rw-r--r-- | fs/omfs/bitmap.c | 2 | ||||
| -rw-r--r-- | fs/omfs/inode.c | 10 | 
2 files changed, 8 insertions, 4 deletions
| diff --git a/fs/omfs/bitmap.c b/fs/omfs/bitmap.c index 082234581d05..83f4e76511c2 100644 --- a/fs/omfs/bitmap.c +++ b/fs/omfs/bitmap.c @@ -159,7 +159,7 @@ int omfs_allocate_range(struct super_block *sb,  	goto out;  found: -	*return_block = i * bits_per_entry + bit; +	*return_block = (u64) i * bits_per_entry + bit;  	*return_size = run;  	ret = set_run(sb, i, bits_per_entry, bit, run, 1); diff --git a/fs/omfs/inode.c b/fs/omfs/inode.c index 138321b0c6c2..3d935c81789a 100644 --- a/fs/omfs/inode.c +++ b/fs/omfs/inode.c @@ -306,7 +306,8 @@ static const struct super_operations omfs_sops = {   */  static int omfs_get_imap(struct super_block *sb)  { -	unsigned int bitmap_size, count, array_size; +	unsigned int bitmap_size, array_size; +	int count;  	struct omfs_sb_info *sbi = OMFS_SB(sb);  	struct buffer_head *bh;  	unsigned long **ptr; @@ -359,7 +360,7 @@ nomem:  }  enum { -	Opt_uid, Opt_gid, Opt_umask, Opt_dmask, Opt_fmask +	Opt_uid, Opt_gid, Opt_umask, Opt_dmask, Opt_fmask, Opt_err  };  static const match_table_t tokens = { @@ -368,6 +369,7 @@ static const match_table_t tokens = {  	{Opt_umask, "umask=%o"},  	{Opt_dmask, "dmask=%o"},  	{Opt_fmask, "fmask=%o"}, +	{Opt_err, NULL},  };  static int parse_options(char *options, struct omfs_sb_info *sbi) @@ -548,8 +550,10 @@ static int omfs_fill_super(struct super_block *sb, void *data, int silent)  	}  	sb->s_root = d_make_root(root); -	if (!sb->s_root) +	if (!sb->s_root) { +		ret = -ENOMEM;  		goto out_brelse_bh2; +	}  	printk(KERN_DEBUG "omfs: Mounted volume %s\n", omfs_rb->r_name);  	ret = 0; |