Linux Container Development
 help / color / mirror / Atom feed
  • [parent not found: <20121129142646.GD24683@htj.dyndns.org>]
  • [parent not found: <1354138460-19286-1-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>]
  • [parent not found: <20121203152205.GB17093@dhcp22.suse.cz>]
  • [parent not found: <1354138460-19286-7-git-send-email-tj@kernel.org>]
  • * [PATCHSET cgroup/for-3.8] cpuset: decouple cpuset locking from cgroup core
    @ 2012-11-28 21:34 Tejun Heo
      0 siblings, 0 replies; 39+ messages in thread
    From: Tejun Heo @ 2012-11-28 21:34 UTC (permalink / raw)
      To: lizefan-hv44wF8Li93QT0dZR+AlfA, paul-inf54ven1CmVyaH7bEyXVA,
    	glommer-bzQdu9zFT3WakBO8gow8eQ
      Cc: containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA,
    	linux-kernel-u79uwXL29TY76Z2rM5mHXA, mhocko-AlSwsSmVLrQ,
    	linux-mm-Bw31MaZKKs3YtjvyW6yDsg, hannes-druUgvl0LCNAfugRpC6u6w,
    	cgroups-u79uwXL29TY76Z2rM5mHXA
    
    Hello, guys.
    
    Depending on cgroup core locking - cgroup_mutex - is messy and makes
    cgroup prone to locking dependency problems.  The current code already
    has lock dependency loop - memcg nests get_online_cpus() inside
    cgroup_mutex.  cpuset the other way around.
    
    Regardless of the locking details, whatever is protecting cgroup has
    inherently to be something outer to most other locking constructs.
    cgroup calls into a lot of major subsystems which in turn have to
    perform subsystem-specific locking.  Trying to nest cgroup
    synchronization inside other locks isn't something which can work
    well.
    
    cgroup now has enough API to allow subsystems to implement their own
    locking and cgroup_mutex is scheduled to be made private to cgroup
    core.  This patchset makes cpuset implement its own locking instead of
    relying on cgroup_mutex.
    
    cpuset is rather nasty in this respect.  Some of it seems to have come
    from the implementation history - cgroup core grew out of cpuset - but
    big part stems from cpuset's need to migrate tasks to an ancestor
    cgroup when an hotunplug event makes a cpuset empty (w/o any cpu or
    memory).
    
    This patchset decouples cpuset locking from cgroup_mutex.  After the
    patchset, cpuset uses cpuset-specific cpuset_mutex instead of
    cgroup_mutex.  This also removes the lockdep warning triggered during
    cpu offlining (see 0009).
    
    Note that this leaves memcg as the only external user of cgroup_mutex.
    Michal, Kame, can you guys please convert memcg to use its own locking
    too?
    
    This patchset contains the following thirteen patches.
    
     0001-cpuset-remove-unused-cpuset_unlock.patch
     0002-cpuset-remove-fast-exit-path-from-remove_tasks_in_em.patch
     0003-cpuset-introduce-css_on-offline.patch
     0004-cpuset-introduce-CS_ONLINE.patch
     0005-cpuset-introduce-cpuset_for_each_child.patch
     0006-cpuset-cleanup-cpuset-_can-_attach.patch
     0007-cpuset-drop-async_rebuild_sched_domains.patch
     0008-cpuset-reorganize-CPU-memory-hotplug-handling.patch
     0009-cpuset-don-t-nest-cgroup_mutex-inside-get_online_cpu.patch
     0010-cpuset-make-CPU-memory-hotplug-propagation-asynchron.patch
     0011-cpuset-pin-down-cpus-and-mems-while-a-task-is-being-.patch
     0012-cpuset-schedule-hotplug-propagation-from-cpuset_atta.patch
     0013-cpuset-replace-cgroup_mutex-locking-with-cpuset-inte.patch
    
    0001-0006 are prep patches.
    
    0007-0009 make cpuset nest get_online_cpus() inside cgroup_mutex, not
    the other way around.
    
    0010-0012 plug holes which would be exposed by switching to
    cpuset-specific locking.
    
    0013 replaces cgroup_mutex with cpuset_mutex.
    
    This patchset is on top of cgroup/for-3.8 (fddfb02ad0) and also
    available in the following git branch.
    
     git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup.git review-cpuset-locking
    
    diffstat follows.
    
     kernel/cpuset.c |  750 +++++++++++++++++++++++++++++++-------------------------
     1 file changed, 423 insertions(+), 327 deletions(-)
    
    Thanks.
    
    --
    tejun
    
    ^ permalink raw reply	[flat|nested] 39+ messages in thread

    end of thread, other threads:[~2013-01-06 23:28 UTC | newest]
    
    Thread overview: 39+ messages (download: mbox.gz follow: Atom feed
    -- links below jump to the message on this page --
         [not found] <1354138460-19286-1-git-send-email-tj@kernel.org>
         [not found] ` <50B743A1.4040405@parallels.com>
         [not found]   ` <50B743A1.4040405-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
    2012-11-29 14:26     ` [PATCHSET cgroup/for-3.8] cpuset: decouple cpuset locking from cgroup core Tejun Heo
         [not found]   ` <20121129142646.GD24683@htj.dyndns.org>
         [not found]     ` <20121129142646.GD24683-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org>
    2012-11-29 14:36       ` Tejun Heo
         [not found] ` <1354138460-19286-1-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
    2012-11-28 21:34   ` [PATCH 01/13] cpuset: remove unused cpuset_unlock() Tejun Heo
    2012-11-28 21:34   ` [PATCH 02/13] cpuset: remove fast exit path from remove_tasks_in_empty_cpuset() Tejun Heo
    2012-11-28 21:34   ` [PATCH 03/13] cpuset: introduce ->css_on/offline() Tejun Heo
    2012-11-28 21:34   ` [PATCH 04/13] cpuset: introduce CS_ONLINE Tejun Heo
    2012-11-28 21:34   ` [PATCH 05/13] cpuset: introduce cpuset_for_each_child() Tejun Heo
    2012-11-28 21:34   ` [PATCH 06/13] cpuset: cleanup cpuset[_can]_attach() Tejun Heo
    2012-11-28 21:34   ` [PATCH 07/13] cpuset: drop async_rebuild_sched_domains() Tejun Heo
    2012-11-28 21:34   ` [PATCH 08/13] cpuset: reorganize CPU / memory hotplug handling Tejun Heo
    2012-11-28 21:34   ` [PATCH 09/13] cpuset: don't nest cgroup_mutex inside get_online_cpus() Tejun Heo
    2012-11-28 21:34   ` [PATCH 10/13] cpuset: make CPU / memory hotplug propagation asynchronous Tejun Heo
    2012-11-28 21:34   ` [PATCH 11/13] cpuset: pin down cpus and mems while a task is being attached Tejun Heo
    2012-11-28 21:34   ` [PATCH 12/13] cpuset: schedule hotplug propagation from cpuset_attach() if the cpuset is empty Tejun Heo
    2012-11-28 21:34   ` [PATCH 13/13] cpuset: replace cgroup_mutex locking with cpuset internal locking Tejun Heo
    2012-11-29 11:14   ` [PATCHSET cgroup/for-3.8] cpuset: decouple cpuset locking from cgroup core Glauber Costa
    2012-11-30  3:21   ` Kamezawa Hiroyuki
         [not found]     ` <50B875B4.2020507@parallels.com>
         [not found]       ` <20121130092435.GD29317@dhcp22.suse.cz>
         [not found]         ` <50B87F84.7040206@parallels.com>
         [not found]           ` <50B87F84.7040206-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
    2012-11-30  9:49             ` Michal Hocko
         [not found]               ` <20121130094959.GE29317-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
    2012-11-30 10:00                 ` Glauber Costa
         [not found]                   ` <50B883B5.8020705-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
    2012-11-30 14:59                     ` Tejun Heo
         [not found]                   ` <20121130145924.GA3873@htj.dyndns.org>
         [not found]                     ` <20121130145924.GA3873-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org>
    2012-11-30 15:09                       ` Glauber Costa
    2012-12-03 15:22   ` Michal Hocko
    2012-12-26 10:51   ` Li Zefan
         [not found]     ` <50DAD696.8050400-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
    2013-01-02  8:53       ` Michal Hocko
    2013-01-03 22:20       ` Tejun Heo
         [not found]     ` <20130102085355.GA22160@dhcp22.suse.cz>
         [not found]       ` <20130102085355.GA22160-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
    2013-01-02 15:36         ` Tejun Heo
         [not found]           ` <20130102153605.GB11220-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2013-01-02 16:02             ` Michal Hocko
         [not found] ` <20121203152205.GB17093@dhcp22.suse.cz>
         [not found]   ` <20121203152205.GB17093-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
    2012-12-03 16:53     ` Tejun Heo
         [not found]   ` <20121203165338.GF19802@htj.dyndns.org>
         [not found]     ` <20121203165338.GF19802-Gd/HAXX7CRxy/B6EtB590w@public.gmane.org>
    2012-12-06  6:25       ` Li Zefan
         [not found]         ` <50C03A3F.7070605-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
    2012-12-06 13:09           ` Michal Hocko
         [not found]             ` <20121206130904.GC10931-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
    2012-12-06 16:54               ` Tejun Heo
         [not found] ` <1354138460-19286-7-git-send-email-tj@kernel.org>
         [not found]   ` <1354138460-19286-7-git-send-email-tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
    2012-12-26 10:20     ` [PATCH 06/13] cpuset: cleanup cpuset[_can]_attach() Li Zefan
         [not found]       ` <50DACF5B.6050705-hv44wF8Li93QT0dZR+AlfA@public.gmane.org>
    2012-12-26 12:04         ` Tejun Heo
         [not found]       ` <20121226120415.GA18193@mtj.dyndns.org>
         [not found]         ` <20121226120415.GA18193-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2013-01-02  4:42           ` Rusty Russell
         [not found]         ` <87zk0s5h7c.fsf@rustcorp.com.au>
         [not found]           ` <87zk0s5h7c.fsf-8n+1lVoiYb80n/F98K4Iww@public.gmane.org>
    2013-01-02 15:34             ` Tejun Heo
         [not found]               ` <20130102153439.GA11220-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2013-01-03  0:47                 ` Rusty Russell
         [not found]               ` <871ue35bzk.fsf@rustcorp.com.au>
         [not found]                 ` <871ue35bzk.fsf-8n+1lVoiYb80n/F98K4Iww@public.gmane.org>
    2013-01-03  2:29                   ` Tejun Heo
         [not found]                     ` <20130103022911.GH11220-9pTldWuhBndy/B6EtB590w@public.gmane.org>
    2013-01-06 23:28                       ` Rusty Russell
    2012-11-28 21:34 [PATCHSET cgroup/for-3.8] cpuset: decouple cpuset locking from cgroup core Tejun Heo
    

    This is a public inbox, see mirroring instructions
    for how to clone and mirror all data and code used for this inbox