Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp237913ybe; Tue, 3 Sep 2019 21:46:14 -0700 (PDT) X-Google-Smtp-Source: APXvYqzUureH8hV05Ad+Uw+swLCPgkE7I7UKz8u1fJPwhpwGqr8iUqqMlV+hAM14FDWDOW4X58I/ X-Received: by 2002:a65:6114:: with SMTP id z20mr33874521pgu.141.1567572374265; Tue, 03 Sep 2019 21:46:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567572374; cv=none; d=google.com; s=arc-20160816; b=q2qzfumVhZi0sp6YIirT+8bZ3Eu7VvM8e8kGmgOg4VIqS41UQYUL4vFisFtYWVvkav 5S9AthRTxSD4Py6ZH0EdqfB367q+ubD/T9MTNdh1VR3taBc2Rcz40/To3O6N96ARaKCF 2Rr+hAbKQ7dDvKgvSk5+OWqkzOOUWXlr3Zdtn/eVv/Sw/lS6UgEq83QW9p/86pl8dKS1 kL005yEbqDvNhL5+ckm7jCJDTlf4QZJ9vQgVxL1Q/qjK0rt0MtJjn1qQeli4s8vl50bS yHud0L4JrXD6mxgSFeCg/Cto5nI7DEL0CnuLL9YAEMJJSwr/37svZLFANMkQkTSDL0wc HywQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=ZdND8YxjoFl7C+oYjsjla5d+S11BgE1Rp3NLcbkw4D8=; b=xw9/qdp9bxj/rBjXYzNdyV4pnkFT4TTczFsa3DmQtOaQfA4tl4X+iY7m9cXK5Xj2lw 4XsV9ePSf6BUXeXuMK9mFWhYC3x4MsxXtTcBiyb5nTsVLBecRr0kW3bpMbP9xmjIJQMh 5J3VzvBgX/69riGTfdqIJbd2KMCQt/acjzhw9yRIQB+MRlhL0BqYGHw72ZgXBwmqYi4w nWpjo5UHsUmHGGPrTvmi0iS44EiU7pXrFeYcU9c50ZARDoIy+/LuR7uW8DpNCqyRdzj+ N0daw5R3fah+E1qUtHqnwpTMoGx2GLTjzdTegbF4cP/1ymz4dkSLZyf2snsGKBynlJvm cRug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Pj6Bj+SG; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id ck3si16865133plb.429.2019.09.03.21.45.59; Tue, 03 Sep 2019 21:46:14 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Pj6Bj+SG; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727994AbfIDEpF (ORCPT + 99 others); Wed, 4 Sep 2019 00:45:05 -0400 Received: from mail-wm1-f66.google.com ([209.85.128.66]:39093 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725877AbfIDEpE (ORCPT ); Wed, 4 Sep 2019 00:45:04 -0400 Received: by mail-wm1-f66.google.com with SMTP id q12so61257wmj.4 for ; Tue, 03 Sep 2019 21:45:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=ZdND8YxjoFl7C+oYjsjla5d+S11BgE1Rp3NLcbkw4D8=; b=Pj6Bj+SGv+AFUXT9EcZXmMudHNzHJsZrvUEwyc7OVQLmaWkuYZgZAX/FBObnO146Qc 5dvzgB464Q5VdJ8uCikMxGriZSQcwpEf9la60hDCKTLzd8PAgTTt/zzJWcWqJMkBvsiz ansABPD5UFMCh5JfbgQ7BdJXTEkNaULX/jxQ9BJ6Ku/qcijiGpvFCdkRN9zBgw+tNlgB VMaB7BFGrTkNwaaK9xOr3UeW6Eir1bOCLkxv9WgbBAbLiW1dY/3La46eVOe8QwenrB8W SGYlvV6CXjcImie3WEjs+9Nv/eZrLGda8QxDv+iVQdKee/cz4gV1tX8BxRoGg1TfxGyj 3Y2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ZdND8YxjoFl7C+oYjsjla5d+S11BgE1Rp3NLcbkw4D8=; b=fSahjxJicX1Jsy5pNGObVupbqOIesu5lwPtjXw9o6evyOK1m5dgcw1RYOyv6gB/tkQ yzq1CRdptVemID3i7+EAcl4xRzMFFaDZ3zZNIv6uo5SWZfqlRCaG7tzIeuK6niTsGsdI tNFq5vIR2SHee/L8h3DFlj9dcLGtsfG/VdBLj2EF9CTeApv4TSqbP0FXTYum+h4jg4kT lKeTb/wm5/RMZHRldm6faE1FmhJWTFE90up31IUHvoJVATVgUcS3lOonEFMzcp/CwB+O oS4LIRwbL06/hQPmIS95LjCU2xfmWI+vfvHgrjtmDWVn5wB7brbmKdOPXSxpT8zvUhzN /qjw== X-Gm-Message-State: APjAAAWj6OR5g/4fSL+W3xOzxOzJmVxmdXVbFoSMfGqWxadk+sHdYDjr m35z09cjujr3qbz0yOYD0DZB6MMAvr8kCYcuPOr8cA== X-Received: by 2002:a7b:c4d6:: with SMTP id g22mr2525255wmk.21.1567572301979; Tue, 03 Sep 2019 21:45:01 -0700 (PDT) MIME-Version: 1.0 References: <20190903200905.198642-1-joel@joelfernandes.org> In-Reply-To: <20190903200905.198642-1-joel@joelfernandes.org> From: Suren Baghdasaryan Date: Tue, 3 Sep 2019 21:44:51 -0700 Message-ID: Subject: Re: [PATCH v2] mm: emit tracepoint when RSS changes by threshold To: "Joel Fernandes (Google)" Cc: LKML , Tim Murray , Carmen Jackson , mayankgupta@google.com, Daniel Colascione , Steven Rostedt , Minchan Kim , Andrew Morton , kernel-team , "Aneesh Kumar K.V" , Dan Williams , Jerome Glisse , linux-mm , Matthew Wilcox , Michal Hocko , Ralph Campbell , Vlastimil Babka Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Sep 3, 2019 at 1:09 PM Joel Fernandes (Google) wrote: > > Useful to track how RSS is changing per TGID to detect spikes in RSS and > memory hogs. Several Android teams have been using this patch in various > kernel trees for half a year now. Many reported to me it is really > useful so I'm posting it upstream. > > Initial patch developed by Tim Murray. Changes I made from original patch: > o Prevent any additional space consumed by mm_struct. > o Keep overhead low by checking if tracing is enabled. > o Add some noise reduction and lower overhead by emitting only on > threshold changes. > > Co-developed-by: Tim Murray > Signed-off-by: Tim Murray > Signed-off-by: Joel Fernandes (Google) > > --- > > v1->v2: Added more commit message. > > Cc: carmenjackson@google.com > Cc: mayankgupta@google.com > Cc: dancol@google.com > Cc: rostedt@goodmis.org > Cc: minchan@kernel.org > Cc: akpm@linux-foundation.org > Cc: kernel-team@android.com > > include/linux/mm.h | 14 +++++++++++--- > include/trace/events/kmem.h | 21 +++++++++++++++++++++ > mm/memory.c | 20 ++++++++++++++++++++ > 3 files changed, 52 insertions(+), 3 deletions(-) > > diff --git a/include/linux/mm.h b/include/linux/mm.h > index 0334ca97c584..823aaf759bdb 100644 > --- a/include/linux/mm.h > +++ b/include/linux/mm.h > @@ -1671,19 +1671,27 @@ static inline unsigned long get_mm_counter(struct mm_struct *mm, int member) > return (unsigned long)val; > } > > +void mm_trace_rss_stat(int member, long count, long value); > + > static inline void add_mm_counter(struct mm_struct *mm, int member, long value) > { > - atomic_long_add(value, &mm->rss_stat.count[member]); > + long count = atomic_long_add_return(value, &mm->rss_stat.count[member]); > + > + mm_trace_rss_stat(member, count, value); > } > > static inline void inc_mm_counter(struct mm_struct *mm, int member) > { > - atomic_long_inc(&mm->rss_stat.count[member]); > + long count = atomic_long_inc_return(&mm->rss_stat.count[member]); > + > + mm_trace_rss_stat(member, count, 1); > } > > static inline void dec_mm_counter(struct mm_struct *mm, int member) > { > - atomic_long_dec(&mm->rss_stat.count[member]); > + long count = atomic_long_dec_return(&mm->rss_stat.count[member]); > + > + mm_trace_rss_stat(member, count, -1); > } > > /* Optimized variant when page is already known not to be PageAnon */ > diff --git a/include/trace/events/kmem.h b/include/trace/events/kmem.h > index eb57e3037deb..8b88e04fafbf 100644 > --- a/include/trace/events/kmem.h > +++ b/include/trace/events/kmem.h > @@ -315,6 +315,27 @@ TRACE_EVENT(mm_page_alloc_extfrag, > __entry->change_ownership) > ); > > +TRACE_EVENT(rss_stat, > + > + TP_PROTO(int member, > + long count), > + > + TP_ARGS(member, count), > + > + TP_STRUCT__entry( > + __field(int, member) > + __field(long, size) > + ), > + > + TP_fast_assign( > + __entry->member = member; > + __entry->size = (count << PAGE_SHIFT); > + ), > + > + TP_printk("member=%d size=%ldB", > + __entry->member, > + __entry->size) > + ); > #endif /* _TRACE_KMEM_H */ > > /* This part must be outside protection */ > diff --git a/mm/memory.c b/mm/memory.c > index e2bb51b6242e..9d81322c24a3 100644 > --- a/mm/memory.c > +++ b/mm/memory.c > @@ -72,6 +72,8 @@ > #include > #include > > +#include > + > #include > #include > #include > @@ -140,6 +142,24 @@ static int __init init_zero_pfn(void) > } > core_initcall(init_zero_pfn); > > +/* > + * This threshold is the boundary in the value space, that the counter has to > + * advance before we trace it. Should be a power of 2. It is to reduce unwanted > + * trace overhead. The counter is in units of number of pages. > + */ > +#define TRACE_MM_COUNTER_THRESHOLD 128 IIUC the counter has to change by 128 pages (512kB assuming 4kB pages) before the change gets traced. Would it make sense to make this step size configurable? For a system with limited memory size change of 512kB might be considerable while on systems with plenty of memory that might be negligible. Not even mentioning possible difference in page sizes. Maybe something like /sys/kernel/debug/tracing/rss_step_order with TRACE_MM_COUNTER_THRESHOLD=(1< + > +void mm_trace_rss_stat(int member, long count, long value) > +{ > + long thresh_mask = ~(TRACE_MM_COUNTER_THRESHOLD - 1); > + > + if (!trace_rss_stat_enabled()) > + return; > + > + /* Threshold roll-over, trace it */ > + if ((count & thresh_mask) != ((count - value) & thresh_mask)) > + trace_rss_stat(member, count); > +} > > #if defined(SPLIT_RSS_COUNTING) > > -- > 2.23.0.187.g17f5b7556c-goog > > -- > To unsubscribe from this group and stop receiving emails from it, send an email to kernel-team+unsubscribe@android.com. >