OSDN Git Service

f2fs: enhance f2fs_is_checkpoint_ready()'s readability
[sagit-ice-cold/kernel_xiaomi_msm8998.git] / fs / pnode.c
index ddb846f..35154a5 100644 (file)
@@ -610,36 +610,18 @@ int propagate_umount(struct list_head *list)
        return 0;
 }
 
-/*
- *  Iterates over all slaves, and slaves of slaves.
- */
-static struct mount *next_descendent(struct mount *root, struct mount *cur)
-{
-       if (!IS_MNT_NEW(cur) && !list_empty(&cur->mnt_slave_list))
-               return first_slave(cur);
-       do {
-               struct mount *master = cur->mnt_master;
-
-               if (!master || cur->mnt_slave.next != &master->mnt_slave_list) {
-                       struct mount *next = next_slave(cur);
-
-                       return (next == root) ? NULL : next;
-               }
-               cur = master;
-       } while (cur != root);
-       return NULL;
-}
-
 void propagate_remount(struct mount *mnt)
 {
-       struct mount *m = mnt;
+       struct mount *parent = mnt->mnt_parent;
+       struct mount *p = mnt, *m;
        struct super_block *sb = mnt->mnt.mnt_sb;
 
-       if (sb->s_op->copy_mnt_data) {
-               m = next_descendent(mnt, m);
-               while (m) {
+       if (!sb->s_op->copy_mnt_data)
+               return;
+       for (p = propagation_next(parent, parent); p;
+                               p = propagation_next(p, parent)) {
+               m = __lookup_mnt(&p->mnt, mnt->mnt_mountpoint);
+               if (m)
                        sb->s_op->copy_mnt_data(m->mnt.data, mnt->mnt.data);
-                       m = next_descendent(mnt, m);
-               }
        }
 }