• Tejun Heo's avatar
    cgroup: treat cgroup_dummy_root as an equivalent hierarchy during rebinding · 5df36032
    Tejun Heo authored
    
    
    Currently, while rebinding, cgroup_dummy_root serves as the anchor
    point.  In addition to the target root, rebind_subsystems() takes
    @added_mask and @removed_mask.  The subsystems specified in the former
    are expected to be on the dummy root and then moved to the target
    root.  The ones in the latter are moved from non-dummy root to dummy.
    Now that the dummy root is a fully functional one and we're planning
    to use it for the default unified hierarchy, this level of distinction
    between dummy and non-dummy roots is quite awkward.
    
    This patch updates rebind_subsystems() to take the target root and one
    subsystem mask and move the specified subsystmes to the target root
    which may or may not be the dummy root.  IOW, unbinding now becomes
    moving the subsystems to the dummy root and binding to non-dummy root.
    This makes the dummy root mostly equivalent to other hierarchies in
    terms of the mechanism of moving subsystems around; however, we still
    retain all the semantical restrictions so that this patch doesn't
    introduce any visible behavior differences.  Another noteworthy detail
    is that rebind_subsystems() guarantees that moving a subsystem to the
    dummy root never fails so that valid unmounting attempts always
    succeed.
    
    This unifies binding and unbinding of subsystems.  The invocation
    points of ->bind() were inconsistent between the two and now moved
    after whole rebinding is complete.  This doesn't break the current
    users and generally makes more sense.
    
    All rebind_subsystems() users are converted accordingly.  Note that
    cgroup_remount() now makes two calls to rebind_subsystems() to bind
    and then unbind the requested subsystems.
    
    This will allow repurposing of the dummy hierarchy as the default
    unified hierarchy and shouldn't make any userland visible behavior
    difference.
    Signed-off-by: default avatarTejun Heo <tj@kernel.org>
    Acked-by: default avatarLi Zefan <lizefan@huawei.com>
    5df36032
cgroup.c 128 KB