From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932715AbdC1XpB (ORCPT ); Tue, 28 Mar 2017 19:45:01 -0400 Received: from mail.kernel.org ([198.145.29.136]:45076 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932547AbdC1Xo7 (ORCPT ); Tue, 28 Mar 2017 19:44:59 -0400 Date: Wed, 29 Mar 2017 08:44:35 +0900 From: Masami Hiramatsu To: Steven Rostedt Cc: Alban Crequy , Alban Crequy , Alexei Starovoitov , Jonathan Corbet , Ingo Molnar , Arnaldo Carvalho de Melo , Omar Sandoval , linux-doc@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, iago@kinvolk.io, michael@kinvolk.io, "Dorau, Lukasz" Subject: Re: [PATCH v1] tracing/kprobes: expose maxactive for kretprobe in kprobe_events Message-Id: <20170329084435.e2f4a2805e2139c2bf646f5b@kernel.org> In-Reply-To: <20170328113407.56926eec@gandalf.local.home> References: <1490709142-8856-1-git-send-email-alban@kinvolk.io> <20170329002335.1d1fcc491765b632f470f99b@kernel.org> <20170328113407.56926eec@gandalf.local.home> X-Mailer: Sylpheed 3.5.0 (GTK+ 2.24.30; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 28 Mar 2017 11:34:07 -0400 Steven Rostedt wrote: > On Wed, 29 Mar 2017 00:23:35 +0900 > Masami Hiramatsu wrote: > > > > @@ -598,8 +601,10 @@ static int create_trace_kprobe(int argc, char **argv) > > > { > > > /* > > > * Argument syntax: > > > - * - Add kprobe: p[:[GRP/]EVENT] [MOD:]KSYM[+OFFS]|KADDR [FETCHARGS] > > > - * - Add kretprobe: r[:[GRP/]EVENT] [MOD:]KSYM[+0] [FETCHARGS] > > > + * - Add kprobe: > > > + * p[:[GRP/]EVENT] [MOD:]KSYM[+OFFS]|KADDR [FETCHARGS] > > > + * - Add kretprobe: > > > + * r[MAXACTIVE][:[GRP/]EVENT] [MOD:]KSYM[+0] [FETCHARGS] > > > * Fetch args: > > > * $retval : fetch return value > > > * $stack : fetch stack address > > > @@ -619,6 +624,7 @@ static int create_trace_kprobe(int argc, char **argv) > > > int i, ret = 0; > > > bool is_return = false, is_delete = false; > > > char *symbol = NULL, *event = NULL, *group = NULL; > > > + int maxactive = 0; > > > char *arg; > > > unsigned long offset = 0; > > > void *addr = NULL; > > > @@ -637,8 +643,26 @@ static int create_trace_kprobe(int argc, char **argv) > > > return -EINVAL; > > > } > > > > > > - if (argv[0][1] == ':') { > > > + if (is_return && isdigit(argv[0][1]) && strchr(&argv[0][1], ':')) { > > > > This only supports r[MAXACTIVE:[GRP/]EVENT]. e.g "r100" without event name. > > You mean it doesn't support adding MAXACTIVE without the ':event'. Yeah, sorry for lacking the explanation... > > > > > Thank you, > > > > > + event = strchr(&argv[0][1], ':') + 1; > > > + event[-1] = '\0'; > > > + ret = kstrtouint(&argv[0][1], 0, &maxactive); > > > + if (ret) { > > > + pr_info("Failed to parse maxactive.\n"); > > > + return ret; > > > + } > > > + /* kretprobes instances are iterated over via a list. The > > > + * maximum should stay reasonable. > > > + */ > > > + if (maxactive > 1024) { > > Also, can we get rid of magic numbers within the code. There should be a > const or macro defined as MAX_MAXACTIVE or something, and use that here. Good catch! Thanks, > > -- Steve > > > > > + pr_info("Maxactive is too big.\n"); > > > + return -EINVAL; > > > + } > > > + } else if (argv[0][1] == ':') { > > > event = &argv[0][2]; > > > + } > > > + > > > + if (event) { > > > if (strchr(event, '/')) { > > > group = event; > > > event = strchr(group, '/') + 1; > > > @@ -718,8 +742,8 @@ static int create_trace_kprobe(int argc, char **argv) > > > is_return ? 'r' : 'p', addr); > > > event = buf; > > > } > > > - tk = alloc_trace_kprobe(group, event, addr, symbol, offset, argc, > > > - is_return); > > > + tk = alloc_trace_kprobe(group, event, addr, symbol, offset, maxactive, > > > + argc, is_return); > > > if (IS_ERR(tk)) { > > > pr_info("Failed to allocate trace_probe.(%d)\n", > > > (int)PTR_ERR(tk)); > > > -- > > > 2.7.4 > > > > > > > > -- Masami Hiramatsu