Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0f0afb1d authored by Al Viro's avatar Al Viro
Browse files

vfs: spread struct mount - change_mnt_propagation/set_mnt_shared



Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent b105e270
Loading
Loading
Loading
Loading
+4 −4
Original line number Diff line number Diff line
@@ -724,7 +724,7 @@ static struct vfsmount *clone_mnt(struct vfsmount *old, struct dentry *root,
			mnt->mnt.mnt_master = old->mnt_master;
		}
		if (flag & CL_MAKE_SHARED)
			set_mnt_shared(&mnt->mnt);
			set_mnt_shared(mnt);

		/* stick the duplicate mount on the same expiry list
		 * as the original if that was on one */
@@ -1239,7 +1239,7 @@ void umount_tree(struct vfsmount *mnt, int propagate, struct list_head *kill)
			p->mnt.mnt_parent->mnt_ghosts++;
			dentry_reset_mounted(p->mnt.mnt_mountpoint);
		}
		change_mnt_propagation(&p->mnt, MS_PRIVATE);
		change_mnt_propagation(p, MS_PRIVATE);
	}
	list_splice(&tmp_list, kill);
}
@@ -1608,7 +1608,7 @@ static int attach_recursive_mnt(struct mount *source_mnt,

	if (IS_MNT_SHARED(dest_mnt)) {
		for (p = source_mnt; p; p = next_mnt(p, &source_mnt->mnt))
			set_mnt_shared(&p->mnt);
			set_mnt_shared(p);
	}
	if (parent_path) {
		detach_mnt(source_mnt, parent_path);
@@ -1723,7 +1723,7 @@ static int do_change_type(struct path *path, int flag)

	br_write_lock(vfsmount_lock);
	for (m = mnt; m; m = (recurse ? next_mnt(m, &mnt->mnt) : NULL))
		change_mnt_propagation(&m->mnt, type);
		change_mnt_propagation(m, type);
	br_write_unlock(vfsmount_lock);

 out_unlock:
+6 −6
Original line number Diff line number Diff line
@@ -114,20 +114,20 @@ static int do_make_slave(struct vfsmount *mnt)
/*
 * vfsmount lock must be held for write
 */
void change_mnt_propagation(struct vfsmount *mnt, int type)
void change_mnt_propagation(struct mount *mnt, int type)
{
	if (type == MS_SHARED) {
		set_mnt_shared(mnt);
		return;
	}
	do_make_slave(mnt);
	do_make_slave(&mnt->mnt);
	if (type != MS_SLAVE) {
		list_del_init(&mnt->mnt_slave);
		mnt->mnt_master = NULL;
		list_del_init(&mnt->mnt.mnt_slave);
		mnt->mnt.mnt_master = NULL;
		if (type == MS_UNBINDABLE)
			mnt->mnt_flags |= MNT_UNBINDABLE;
			mnt->mnt.mnt_flags |= MNT_UNBINDABLE;
		else
			mnt->mnt_flags &= ~MNT_UNBINDABLE;
			mnt->mnt.mnt_flags &= ~MNT_UNBINDABLE;
	}
}

+4 −4
Original line number Diff line number Diff line
@@ -23,13 +23,13 @@
#define CL_MAKE_SHARED 		0x08
#define CL_PRIVATE 		0x10

static inline void set_mnt_shared(struct vfsmount *mnt)
static inline void set_mnt_shared(struct mount *mnt)
{
	mnt->mnt_flags &= ~MNT_SHARED_MASK;
	mnt->mnt_flags |= MNT_SHARED;
	mnt->mnt.mnt_flags &= ~MNT_SHARED_MASK;
	mnt->mnt.mnt_flags |= MNT_SHARED;
}

void change_mnt_propagation(struct vfsmount *, int);
void change_mnt_propagation(struct mount *, int);
int propagate_mnt(struct vfsmount *, struct dentry *, struct vfsmount *,
		struct list_head *);
int propagate_umount(struct list_head *);