Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 185699
b: refs/heads/master
c: 796a6b5
h: refs/heads/master
i:
  185697: f18a657
  185695: a5098c3
v: v3
  • Loading branch information
Al Viro committed Mar 3, 2010
1 parent 2c6a20b commit 13c2896
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 15 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: c177c2ac8c5aa83ed181db44543c3b38fd1f17a6
refs/heads/master: 796a6b521d0eadb338adf8cf7e482351c3a8a7b4
2 changes: 1 addition & 1 deletion trunk/fs/namespace.c
Original file line number Diff line number Diff line change
Expand Up @@ -573,7 +573,7 @@ static struct vfsmount *clone_mnt(struct vfsmount *old, struct dentry *root,
mnt->mnt_master = old;
CLEAR_MNT_SHARED(mnt);
} else if (!(flag & CL_PRIVATE)) {
if ((flag & CL_PROPAGATION) || IS_MNT_SHARED(old))
if ((flag & CL_MAKE_SHARED) || IS_MNT_SHARED(old))
list_add(&mnt->mnt_share, &old->mnt_share);
if (IS_MNT_SLAVE(old))
list_add(&mnt->mnt_slave, &old->mnt_slave);
Expand Down
28 changes: 17 additions & 11 deletions trunk/fs/pnode.c
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ static int do_make_slave(struct vfsmount *mnt)

/*
* slave 'mnt' to a peer mount that has the
* same root dentry. If none is available than
* same root dentry. If none is available then
* slave it to anything that is available.
*/
while ((peer_mnt = next_peer(peer_mnt)) != mnt &&
Expand Down Expand Up @@ -147,6 +147,11 @@ void change_mnt_propagation(struct vfsmount *mnt, int type)
* get the next mount in the propagation tree.
* @m: the mount seen last
* @origin: the original mount from where the tree walk initiated
*
* Note that peer groups form contiguous segments of slave lists.
* We rely on that in get_source() to be able to find out if
* vfsmount found while iterating with propagation_next() is
* a peer of one we'd found earlier.
*/
static struct vfsmount *propagation_next(struct vfsmount *m,
struct vfsmount *origin)
Expand Down Expand Up @@ -186,10 +191,6 @@ static struct vfsmount *get_source(struct vfsmount *dest,
{
struct vfsmount *p_last_src = NULL;
struct vfsmount *p_last_dest = NULL;
*type = CL_PROPAGATION;

if (IS_MNT_SHARED(dest))
*type |= CL_MAKE_SHARED;

while (last_dest != dest->mnt_master) {
p_last_dest = last_dest;
Expand All @@ -202,13 +203,18 @@ static struct vfsmount *get_source(struct vfsmount *dest,
do {
p_last_dest = next_peer(p_last_dest);
} while (IS_MNT_NEW(p_last_dest));
/* is that a peer of the earlier? */
if (dest == p_last_dest) {
*type = CL_MAKE_SHARED;
return p_last_src;
}
}

if (dest != p_last_dest) {
*type |= CL_SLAVE;
return last_src;
} else
return p_last_src;
/* slave of the earlier, then */
*type = CL_SLAVE;
/* beginning of peer group among the slaves? */
if (IS_MNT_SHARED(dest))
*type |= CL_MAKE_SHARED;
return last_src;
}

/*
Expand Down
3 changes: 1 addition & 2 deletions trunk/fs/pnode.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,7 @@
#define CL_SLAVE 0x02
#define CL_COPY_ALL 0x04
#define CL_MAKE_SHARED 0x08
#define CL_PROPAGATION 0x10
#define CL_PRIVATE 0x20
#define CL_PRIVATE 0x10

static inline void set_mnt_shared(struct vfsmount *mnt)
{
Expand Down

0 comments on commit 13c2896

Please sign in to comment.