On Fri, Jul 12, 2013 at 11:24:56AM +0200, Michal Hocko wrote: > Cgroup events are unregistered from the workqueue context by > cgroup_event_remove scheduled by cgroup_destroy_locked (when a cgroup is > removed by rmdir). > > cgroup_event_remove removes the eventfd wait queue from the work > queue, then it unregisters all the registered events and finally > puts a reference to the cgroup dentry. css_free which triggers memcg > deallocation is called after the last reference is dropped. > > The scheduled vmpressure work item either happens before > cgroup_event_remove or it is not triggered at all so it always happen > _before_ the last dput thus css_free. I don't follow what the above has to do with ensuring work item execution is finished before the underlying data structure is released. How are the above relevant? What am I missing here? > This patch just documents this trickiness. This doesn't have to be tricky at all. It's a *completely* routine thing. Would you please stop making it one? -- tejun -- To unsubscribe from this list: send the line "unsubscribe cgroups" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html