public inbox for cgroups@vger.kernel.org
 help / color / mirror / Atom feed
From: Michal Hocko <mhocko-AlSwsSmVLrQ@public.gmane.org>
To: Glauber Costa <glommer-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
Cc: Vladimir Davydov
	<vdavydov-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>,
	LKML <linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
	cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	devel-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org,
	Johannes Weiner <hannes-druUgvl0LCNAfugRpC6u6w@public.gmane.org>,
	Balbir Singh
	<bsingharora-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>,
	KAMEZAWA Hiroyuki
	<kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
Subject: Re: [PATCH] memcg: remove KMEM_ACCOUNTED_ACTIVATED
Date: Mon, 2 Dec 2013 19:51:12 +0100	[thread overview]
Message-ID: <20131202185112.GB5524@dhcp22.suse.cz> (raw)
In-Reply-To: <CAA6-i6rWsZNQmFY5L-=yc6TaTGyg4hP4qn9gMZVsu8wWJ=1ywg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>

On Mon 02-12-13 22:26:48, Glauber Costa wrote:
> On Mon, Dec 2, 2013 at 10:15 PM, Michal Hocko <mhocko-AlSwsSmVLrQ@public.gmane.org> wrote:
> > [CCing Glauber - please do so in other posts for kmem related changes]
> >
> > On Mon 02-12-13 17:08:13, Vladimir Davydov wrote:
> >> The KMEM_ACCOUNTED_ACTIVATED was introduced by commit a8964b9b ("memcg:
> >> use static branches when code not in use") in order to guarantee that
> >> static_key_slow_inc(&memcg_kmem_enabled_key) will be called only once
> >> for each memory cgroup when its kmem limit is set. The point is that at
> >> that time the memcg_update_kmem_limit() function's workflow looked like
> >> this:
> >>
> >>       bool must_inc_static_branch = false;
> >>
> >>       cgroup_lock();
> >>       mutex_lock(&set_limit_mutex);
> >>       if (!memcg->kmem_account_flags && val != RESOURCE_MAX) {
> >>               /* The kmem limit is set for the first time */
> >>               ret = res_counter_set_limit(&memcg->kmem, val);
> >>
> >>               memcg_kmem_set_activated(memcg);
> >>               must_inc_static_branch = true;
> >>       } else
> >>               ret = res_counter_set_limit(&memcg->kmem, val);
> >>       mutex_unlock(&set_limit_mutex);
> >>       cgroup_unlock();
> >>
> >>       if (must_inc_static_branch) {
> >>               /* We can't do this under cgroup_lock */
> >>               static_key_slow_inc(&memcg_kmem_enabled_key);
> >>               memcg_kmem_set_active(memcg);
> >>       }
> >>
> >> Today, we don't use cgroup_lock in memcg_update_kmem_limit(), and
> >> static_key_slow_inc() is called under the set_limit_mutex, but the
> >> leftover from the above-mentioned commit is still here. Let's remove it.
> >
> > OK, so I have looked there again and 692e89abd154b (memcg: increment
> > static branch right after limit set) which went in after cgroup_mutex
> > has been removed. It came along with the following comment.
> >                 /*
> >                  * setting the active bit after the inc will guarantee no one
> >                  * starts accounting before all call sites are patched
> >                  */
> >
> > This suggests that the flag is needed after all because we have
> > to be sure that _all_ the places have to be patched. AFAIU
> > memcg_kmem_newpage_charge might see the static key already patched so
> > it would do a charge but memcg_kmem_commit_charge would still see it
> > unpatched and so the charge won't be committed.
> >
> > Or am I missing something?
> 
> You are correct. This flag is there due to the way we are using static branches.
> The patching of one call site is atomic, but the patching of all of
> them are not.
> Therefore we need to use a two-flag scheme to guarantee that in the first time
> we turn the static branches on, there will be a clear point after
> which we're going
> to start accounting.

So http://lkml.org/lkml/2013/11/27/314 is correct then, right?
-- 
Michal Hocko
SUSE Labs

  parent reply	other threads:[~2013-12-02 18:51 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-12-02 13:08 [PATCH] memcg: remove KMEM_ACCOUNTED_ACTIVATED Vladimir Davydov
     [not found] ` <1385989693-28788-1-git-send-email-vdavydov-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
2013-12-02 18:15   ` Michal Hocko
     [not found]     ` <20131202181501.GA5524-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
2013-12-02 18:26       ` Glauber Costa
     [not found]         ` <CAA6-i6rWsZNQmFY5L-=yc6TaTGyg4hP4qn9gMZVsu8wWJ=1ywg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-12-02 18:51           ` Michal Hocko [this message]
     [not found]             ` <20131202185112.GB5524-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
2013-12-02 19:06               ` Glauber Costa
2013-12-02 19:21           ` Vladimir Davydov
     [not found]             ` <529CDDB3.3090301-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
2013-12-03  7:56               ` Glauber Costa
2013-12-03  8:06                 ` Vladimir Davydov
     [not found]                   ` <529D9100.4070207-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
2013-12-03 22:38                     ` Glauber Costa
     [not found]                       ` <CAA6-i6q2viRkbjYOHcoiCHgvdfbfo-4j0k9gj9AA4SH1YToqVg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-12-04  7:35                         ` Vladimir Davydov
     [not found]                           ` <529EDB41.8030505-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
2013-12-04 10:08                             ` Glauber Costa
2013-12-04 11:56                               ` Vladimir Davydov
     [not found]                                 ` <529F1883.3030907-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
2013-12-09 15:22                                   ` Michal Hocko
2013-12-09 18:44                                     ` Vladimir Davydov
     [not found]                                       ` <52A60FA3.20106-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
2013-12-10  9:13                                         ` Michal Hocko
     [not found]                                           ` <20131210091312.GA20242-2MMpYkNvuYDjFM9bn6wA6Q@public.gmane.org>
2013-12-10 12:05                                             ` Vladimir Davydov
2013-12-02 19:12       ` Vladimir Davydov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20131202185112.GB5524@dhcp22.suse.cz \
    --to=mhocko-alswssmvlrq@public.gmane.org \
    --cc=bsingharora-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
    --cc=cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=devel-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org \
    --cc=glommer-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
    --cc=hannes-druUgvl0LCNAfugRpC6u6w@public.gmane.org \
    --cc=kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org \
    --cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=vdavydov-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox