[Cluster-devel] Re: GFS2: Allow all meta/normal mount combinations
Steven Whitehouse
swhiteho at redhat.com
Fri Jun 5 14:17:43 UTC 2009
Hi,
On Fri, 2009-06-05 at 10:09 -0400, Christoph Hellwig wrote:
> On Fri, Jun 05, 2009 at 02:52:16PM +0100, Steven Whitehouse wrote:
> > +static int gfs2_get_sb(struct file_system_type *fs_type, int flags,
> > + const char *dev_name, void *data, struct vfsmount *mnt)
> > +{
> > + struct super_block *s;
> > + struct gfs2_sbd *sdp;
> > + int ret;
> > +
> > + /* First we assume its a block device */
> > + ret = get_sb_bdev(fs_type, flags, dev_name, data, fill_super, mnt);
> > + if (ret != -ENOTBLK)
> > + return ret;
> > +
> > + /* If that fails, we assume its a GFS2 inode on an existing sb */
> > + s = get_gfs2_sb(dev_name);
> > + if (IS_ERR(s)) {
> > + printk(KERN_WARNING "GFS2: gfs2 mount does not exist\n");
> > + return PTR_ERR(s);
> > + }
>
> This is pretty ugly. Even if this is how the old gfs2meta filesystem
> worked I would prefer to only allow it if mounted as type gfs2meta, not
> for normal gfs2 mount and gradually phase it out.
>
Which bit is ugly? We need to be able to do this to be sure that we can
get a metafs which exactly matches the "normal" fs without races I
think. Thats a requirement of the userland tools, unfortunately.
> > + sdp = s->s_fs_info;
> > + mnt->mnt_sb = s;
> > + mnt->mnt_root = gfs2_is_meta_fs(data) ? dget(sdp->sd_master_dir) :
> > + dget(sdp->sd_root_dir);
>
> if (gfs2_is_meta_fs(data))
> mnt->mnt_root = dget(sdp->sd_master_dir);
> else
> mnt->mnt_root = dget(sdp->sd_root_dir);
>
> would be a lot more readable..
Yes, thats true. I'll fix it,
Steve.
More information about the Cluster-devel
mailing list