Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp3637176ioo; Mon, 30 May 2022 06:33:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz16ylV55EDDDFzb1SDVGGHR1TXzl74MYkw63fnBVEtaQCR0DGFvnSu56BxG+hs1gSqb9CE X-Received: by 2002:aa7:dbc1:0:b0:42b:77a2:4f81 with SMTP id v1-20020aa7dbc1000000b0042b77a24f81mr36430826edt.287.1653917595472; Mon, 30 May 2022 06:33:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653917595; cv=none; d=google.com; s=arc-20160816; b=fu4Yb+GT2v+hv6A3ajZFSyMYswg4pyGLFaNq65o68fq385P83gQEO68Acp2FRP4KCv HTlBHKCn6pAzA/z+3dhwCFWimePCyBslAB2PvbW+PNkHkWqfQOXghZ1qnYhlwdAs6rUE 25u+Pt9DQd9frWGDLrrBfFBToVpynnmuquFQsmGiEJs0M9HfoProNa3npy2GdmIJEOet etKaFb8/ocTUfOZpgKbbAccjFVRyotq2nmvNnp46KUbOdAB9DVmAeCPwH3D+uT3ArkcS PvR/HBVm+PUYJSbcpT1loJC6gA/gHyOX5BmpHYN/xQwmHQgYQ0cunkAcfpQ6y7N4ZT1/ 01xA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=IAux/HNoQn50bE9AcGHVpSHYBQpzBl59divQ7oBLfPU=; b=eaWrWwb2K/yX2YZE1JmkdQxHhVWpX7Mvq5mOE4vaWoXFTr1Q83v+3TUJtEi6LYnaQG /funEzyw6Mzi0q0IiJF2Qro7rkGTiIbeEJhnXttSh7i7jhAa1//AjjdYg5x7NyOm3WYt JY+W/HNp5BzNCSh8ER0u2bRFA5Upcb6y8wlKux+k+u3p7bwuC2+nET6hUs3uKTUOvExV P1TfN89138yc+62GfrKe0Yd37lQYgUwn0Z9qKPOZIImdhNBe0tltHjP961kdgQdAMzpk 28W7fBWmPq80M3YLnw2cRxHBhO795v3vo3HdHrIJ4FYJWSnll45sckz3MnxXH9OknFpj maig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=hjy86r2Y; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r6-20020a170906280600b006f3af36fea2si5726186ejc.362.2022.05.30.06.32.48; Mon, 30 May 2022 06:33:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=hjy86r2Y; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231680AbiE3Arv (ORCPT + 99 others); Sun, 29 May 2022 20:47:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55074 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230242AbiE3Art (ORCPT ); Sun, 29 May 2022 20:47:49 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 90DE426AE8 for ; Sun, 29 May 2022 17:47:47 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id ED81AB80B8E for ; Mon, 30 May 2022 00:47:45 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E2296C385A9; Mon, 30 May 2022 00:47:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1653871664; bh=AKGFZnFZhl5FcvGf409jZaWe3zPmGMXl8Zhf0Ptpo4w=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=hjy86r2YHNEC1a6MlICcDjLkSGgwQslRNby6pF7aNVfHIjaGaUQJkdUQPZHivV3i9 Xc764Xhh8x8g4VeZ9IcRGRb9lcTOMIU2nfxTohv/FfBAGc21VF5lUelyUtgjm6QAgP AKw0IB3t3rVAOXas3xFnCmuRwTdPMNwKtE1kUA2URhPXi+lgNHXgN3Cs4asJ9Rwh3V W3YoJhjR/8DKXyAOobaYPWg5BGF2XyFmgjogmZNC5rl3AnSrLX3JtSdhykeL3h0FNg q9BWx+i1sO4AU/s2HOm9OK4kg8JP1PAiKyf6WsbAaV/jbxfviP0MRVhaqSWixyVG3+ 2VzpoJZe3kOjg== Date: Mon, 30 May 2022 09:47:40 +0900 From: Masami Hiramatsu (Google) To: Linyu Yuan Cc: Steven Rostedt , Tom Zanussi , Ingo Molnar , , Tzvetomir Stoyanov (VMware) Subject: Re: [PATCH v2 1/2] tracing: auto generate event name when create a group of events Message-Id: <20220530094740.322073e73471b636fa110d46@kernel.org> In-Reply-To: <1653795294-19764-2-git-send-email-quic_linyyuan@quicinc.com> References: <1653795294-19764-1-git-send-email-quic_linyyuan@quicinc.com> <1653795294-19764-2-git-send-email-quic_linyyuan@quicinc.com> X-Mailer: Sylpheed 3.7.0 (GTK+ 2.24.32; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-9.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Linyu, On Sun, 29 May 2022 11:34:53 +0800 Linyu Yuan wrote: > Currently when create a specific group of trace events, > take kprobe event as example, user must use the following format: > p:GRP/EVENT [MOD:]KSYM[+OFFS]|KADDR [FETCHARGS], > which means user must enter EVENT name, one example is: echo > 'p:usb_gadget/config_usb_cfg_link config_usb_cfg_link $arg1' >> > kprobe_events, it is not simple if there are too many entries > because the event name is same as symbol name. > > This change allows user to specify no EVENT name, format changed as: > p:GRP/ [MOD:]KSYM[+OFFS]|KADDR [FETCHARGS], > it will generate event name automatically and one example is: > echo 'p:usb_gadget/ config_usb_cfg_link $arg1' >> kprobe_events. > > Signed-off-by: Linyu Yuan > --- > v2: fix review comments in V1: > change TP_ENAME_EMPTTY to TP_ENAME_EMPTY, Thanks for update! And I think this return code is a bit redundant because those cases can be rephrased as follows; TP_ENAME_GROUP_EVENT : event != NULL && group != (default) TP_ENAME_GROUP : event == NULL && group != (default) TP_ENAME_EVENT : event != NULL && group == (default) TP_ENAME_EMPTY : event == NULL && group == (default) What about this (e.g. trace_kprobe.c)? if (event) { /* event and group will be updated in this function */ ret = traceprobe_parse_event_name(&event, &group, gbuf, event - argv[0]); if (ret) goto parse_error; } if (!event) { /* Make a new event name */ if (symbol) snprintf(buf, MAX_EVENT_NAME_LEN, "%c_%s_%ld", is_return ? 'r' : 'p', symbol, offset); else snprintf(buf, MAX_EVENT_NAME_LEN, "%c_0x%p", is_return ? 'r' : 'p', addr); sanitize_event_name(buf); event = buf; } This makes the code clearer. > add some space, > document the macros return by traceprobe_parse_event_name(), > updatea commit description. > > Documentation/trace/kprobetrace.rst | 8 ++++---- > Documentation/trace/uprobetracer.rst | 8 ++++---- > kernel/trace/trace_dynevent.c | 2 +- > kernel/trace/trace_eprobe.c | 20 ++++++++++++-------- > kernel/trace/trace_kprobe.c | 19 ++++++++++++------- > kernel/trace/trace_probe.c | 9 ++++++++- > kernel/trace/trace_probe.h | 4 ++++ > kernel/trace/trace_uprobe.c | 15 ++++++++++----- > 8 files changed, 55 insertions(+), 30 deletions(-) > > diff --git a/Documentation/trace/kprobetrace.rst b/Documentation/trace/kprobetrace.rst > index b175d88..4274cc6 100644 > --- a/Documentation/trace/kprobetrace.rst > +++ b/Documentation/trace/kprobetrace.rst > @@ -28,10 +28,10 @@ Synopsis of kprobe_events > ------------------------- > :: > > - p[:[GRP/]EVENT] [MOD:]SYM[+offs]|MEMADDR [FETCHARGS] : Set a probe > - r[MAXACTIVE][:[GRP/]EVENT] [MOD:]SYM[+0] [FETCHARGS] : Set a return probe > - p:[GRP/]EVENT] [MOD:]SYM[+0]%return [FETCHARGS] : Set a return probe > - -:[GRP/]EVENT : Clear a probe > + p[:[GRP/][EVENT]] [MOD:]SYM[+offs]|MEMADDR [FETCHARGS] : Set a probe > + r[MAXACTIVE][:[GRP/][EVENT]] [MOD:]SYM[+0] [FETCHARGS] : Set a return probe > + p[:[GRP/][EVENT]] [MOD:]SYM[+0]%return [FETCHARGS] : Set a return probe > + -:[GRP/][EVENT] : Clear a probe Could you also update 'readme_msg' in kernel/trace/trace.c in this patch? e.g. #if defined(CONFIG_KPROBE_EVENTS) || defined(CONFIG_UPROBE_EVENTS) "\t accepts: event-definitions (one definition per line)\n" "\t Format: p[:[/][]] []\n" "\t r[maxactive][:[/][]] []\n" #ifdef CONFIG_HIST_TRIGGERS "\t s:[synthetic/] []\n" #endif "\t e[:[/][]] . []\n" "\t -:[/]\n" And also, could you add *another patch* to update below testcases about dynevent to ensure this feature is working? tools/testing/selftests/ftrace/test.d/dynevent/add_remove_kprobe.tc and tools/testing/selftests/ftrace/test.d/dynevent/add_remove_eprobe.tc e.g. if grep -q '\[\]' README then (add your test...) fi Thank you, > > GRP : Group name. If omitted, use "kprobes" for it. > EVENT : Event name. If omitted, the event name is generated > diff --git a/Documentation/trace/uprobetracer.rst b/Documentation/trace/uprobetracer.rst > index a8e5938..3a1797d7 100644 > --- a/Documentation/trace/uprobetracer.rst > +++ b/Documentation/trace/uprobetracer.rst > @@ -26,10 +26,10 @@ Synopsis of uprobe_tracer > ------------------------- > :: > > - p[:[GRP/]EVENT] PATH:OFFSET [FETCHARGS] : Set a uprobe > - r[:[GRP/]EVENT] PATH:OFFSET [FETCHARGS] : Set a return uprobe (uretprobe) > - p[:[GRP/]EVENT] PATH:OFFSET%return [FETCHARGS] : Set a return uprobe (uretprobe) > - -:[GRP/]EVENT : Clear uprobe or uretprobe event > + p[:[GRP/][EVENT]] PATH:OFFSET [FETCHARGS] : Set a uprobe > + r[:[GRP/][EVENT]] PATH:OFFSET [FETCHARGS] : Set a return uprobe (uretprobe) > + p[:[GRP/][EVENT]] PATH:OFFSET%return [FETCHARGS] : Set a return uprobe (uretprobe) > + -:[GRP/][EVENT] : Clear uprobe or uretprobe event > > GRP : Group name. If omitted, "uprobes" is the default value. > EVENT : Event name. If omitted, the event name is generated based > diff --git a/kernel/trace/trace_dynevent.c b/kernel/trace/trace_dynevent.c > index e34e8182..033248d 100644 > --- a/kernel/trace/trace_dynevent.c > +++ b/kernel/trace/trace_dynevent.c > @@ -101,7 +101,7 @@ int dyn_event_release(const char *raw_command, struct dyn_event_operations *type > event = p + 1; > *p = '\0'; > } > - if (event[0] == '\0') { > + if (!system && event[0] == '\0') { > ret = -EINVAL; > goto out; > } > diff --git a/kernel/trace/trace_eprobe.c b/kernel/trace/trace_eprobe.c > index 7d44785..13cd7fc 100644 > --- a/kernel/trace/trace_eprobe.c > +++ b/kernel/trace/trace_eprobe.c > @@ -125,6 +125,7 @@ static bool eprobe_dyn_event_match(const char *system, const char *event, > * We match the following: > * event only - match all eprobes with event name > * system and event only - match all system/event probes > + * system only - match all system probes > * > * The below has the above satisfied with more arguments: > * > @@ -143,7 +144,7 @@ static bool eprobe_dyn_event_match(const char *system, const char *event, > return false; > > /* Must match the event name */ > - if (strcmp(trace_probe_name(&ep->tp), event) != 0) > + if (event[0] != '\0' && strcmp(trace_probe_name(&ep->tp), event) != 0) > return false; > > /* No arguments match all */ > @@ -848,7 +849,7 @@ static int __trace_eprobe_create(int argc, const char *argv[]) > { > /* > * Argument syntax: > - * e[:[GRP/]ENAME] SYSTEM.EVENT [FETCHARGS] > + * e[:[GRP/][ENAME]] SYSTEM.EVENT [FETCHARGS] > * Fetch args: > * =$[:TYPE] > */ > @@ -858,6 +859,7 @@ static int __trace_eprobe_create(int argc, const char *argv[]) > struct trace_eprobe *ep = NULL; > char buf1[MAX_EVENT_NAME_LEN]; > char buf2[MAX_EVENT_NAME_LEN]; > + char grp_buf[MAX_EVENT_NAME_LEN]; > int ret = 0; > int i; > > @@ -866,14 +868,17 @@ static int __trace_eprobe_create(int argc, const char *argv[]) > > trace_probe_log_init("event_probe", argc, argv); > > + ret = TP_ENAME_EMPTY; > event = strchr(&argv[0][1], ':'); > if (event) { > event++; > - ret = traceprobe_parse_event_name(&event, &group, buf1, > + ret = traceprobe_parse_event_name(&event, &group, grp_buf, > event - argv[0]); > - if (ret) > + if (ret < 0) > goto parse_error; > - } else { > + } > + > + if (ret == TP_ENAME_EMPTY || ret == TP_ENAME_GROUP) { > strscpy(buf1, argv[1], MAX_EVENT_NAME_LEN); > sanitize_event_name(buf1); > event = buf1; > @@ -882,9 +887,8 @@ static int __trace_eprobe_create(int argc, const char *argv[]) > goto parse_error; > > sys_event = argv[1]; > - ret = traceprobe_parse_event_name(&sys_event, &sys_name, buf2, > - sys_event - argv[1]); > - if (ret || !sys_name) > + ret = traceprobe_parse_event_name(&sys_event, &sys_name, buf2, 0); > + if (ret != TP_ENAME_GROUP_EVENT) > goto parse_error; > if (!is_good_name(sys_event) || !is_good_name(sys_name)) > goto parse_error; > diff --git a/kernel/trace/trace_kprobe.c b/kernel/trace/trace_kprobe.c > index 47cebef..55822b6 100644 > --- a/kernel/trace/trace_kprobe.c > +++ b/kernel/trace/trace_kprobe.c > @@ -163,7 +163,8 @@ static bool trace_kprobe_match(const char *system, const char *event, > { > struct trace_kprobe *tk = to_trace_kprobe(ev); > > - return strcmp(trace_probe_name(&tk->tp), event) == 0 && > + return (event[0] == '\0' || > + strcmp(trace_probe_name(&tk->tp), event) == 0) && > (!system || strcmp(trace_probe_group_name(&tk->tp), system) == 0) && > trace_kprobe_match_command_head(tk, argc, argv); > } > @@ -708,11 +709,11 @@ static int __trace_kprobe_create(int argc, const char *argv[]) > /* > * Argument syntax: > * - Add kprobe: > - * p[:[GRP/]EVENT] [MOD:]KSYM[+OFFS]|KADDR [FETCHARGS] > + * p[:[GRP/][EVENT]] [MOD:]KSYM[+OFFS]|KADDR [FETCHARGS] > * - Add kretprobe: > - * r[MAXACTIVE][:[GRP/]EVENT] [MOD:]KSYM[+0] [FETCHARGS] > + * r[MAXACTIVE][:[GRP/][EVENT]] [MOD:]KSYM[+0] [FETCHARGS] > * Or > - * p:[GRP/]EVENT] [MOD:]KSYM[+0]%return [FETCHARGS] > + * p[:[GRP/][EVENT]] [MOD:]KSYM[+0]%return [FETCHARGS] > * > * Fetch args: > * $retval : fetch return value > @@ -739,6 +740,7 @@ static int __trace_kprobe_create(int argc, const char *argv[]) > long offset = 0; > void *addr = NULL; > char buf[MAX_EVENT_NAME_LEN]; > + char grp_buf[MAX_EVENT_NAME_LEN]; > unsigned int flags = TPARG_FL_KERNEL; > > switch (argv[0][0]) { > @@ -832,12 +834,15 @@ static int __trace_kprobe_create(int argc, const char *argv[]) > } > > trace_probe_log_set_index(0); > + ret = TP_ENAME_EMPTY; > if (event) { > - ret = traceprobe_parse_event_name(&event, &group, buf, > + ret = traceprobe_parse_event_name(&event, &group, grp_buf, > event - argv[0]); > - if (ret) > + if (ret < 0) > goto parse_error; > - } else { > + } > + > + if (ret == TP_ENAME_EMPTY || ret == TP_ENAME_GROUP) { > /* Make a new event name */ > if (symbol) > snprintf(buf, MAX_EVENT_NAME_LEN, "%c_%s_%ld", > diff --git a/kernel/trace/trace_probe.c b/kernel/trace/trace_probe.c > index 80863c6..7fd50ab 100644 > --- a/kernel/trace/trace_probe.c > +++ b/kernel/trace/trace_probe.c > @@ -257,6 +257,9 @@ int traceprobe_parse_event_name(const char **pevent, const char **pgroup, > } > len = strlen(event); > if (len == 0) { > + if (slash) > + return TP_ENAME_GROUP; > + > trace_probe_log_err(offset, NO_EVENT_NAME); > return -EINVAL; > } else if (len > MAX_EVENT_NAME_LEN) { > @@ -267,7 +270,11 @@ int traceprobe_parse_event_name(const char **pevent, const char **pgroup, > trace_probe_log_err(offset, BAD_EVENT_NAME); > return -EINVAL; > } > - return 0; > + > + if (slash) > + return TP_ENAME_GROUP_EVENT; > + > + return TP_ENAME_EVENT; > } > > #define PARAM_MAX_STACK (THREAD_SIZE / sizeof(unsigned long)) > diff --git a/kernel/trace/trace_probe.h b/kernel/trace/trace_probe.h > index 92cc149..7390669 100644 > --- a/kernel/trace/trace_probe.h > +++ b/kernel/trace/trace_probe.h > @@ -364,6 +364,10 @@ extern void traceprobe_free_probe_arg(struct probe_arg *arg); > extern int traceprobe_split_symbol_offset(char *symbol, long *offset); > int traceprobe_parse_event_name(const char **pevent, const char **pgroup, > char *buf, int offset); > +#define TP_ENAME_GROUP_EVENT 0 /* GRP/EVENT format, user defined group and event name */ > +#define TP_ENAME_EVENT 1 /* EVENT format, user defined event name, default group */ > +#define TP_ENAME_GROUP 2 /* GRP/ format, user defined group name, auto event name */ > +#define TP_ENAME_EMPTY 3 /* default group and auto event name */ > > enum probe_print_type { > PROBE_PRINT_NORMAL, > diff --git a/kernel/trace/trace_uprobe.c b/kernel/trace/trace_uprobe.c > index 9711589..bc32361 100644 > --- a/kernel/trace/trace_uprobe.c > +++ b/kernel/trace/trace_uprobe.c > @@ -312,7 +312,8 @@ static bool trace_uprobe_match(const char *system, const char *event, > { > struct trace_uprobe *tu = to_trace_uprobe(ev); > > - return strcmp(trace_probe_name(&tu->tp), event) == 0 && > + return (event[0] == '\0' || > + strcmp(trace_probe_name(&tu->tp), event) == 0) && > (!system || strcmp(trace_probe_group_name(&tu->tp), system) == 0) && > trace_uprobe_match_command_head(tu, argc, argv); > } > @@ -532,7 +533,7 @@ static int register_trace_uprobe(struct trace_uprobe *tu) > > /* > * Argument syntax: > - * - Add uprobe: p|r[:[GRP/]EVENT] PATH:OFFSET[%return][(REF)] [FETCHARGS] > + * - Add uprobe: p|r[:[GRP/][EVENT]] PATH:OFFSET[%return][(REF)] [FETCHARGS] > */ > static int __trace_uprobe_create(int argc, const char **argv) > { > @@ -540,6 +541,7 @@ static int __trace_uprobe_create(int argc, const char **argv) > const char *event = NULL, *group = UPROBE_EVENT_SYSTEM; > char *arg, *filename, *rctr, *rctr_end, *tmp; > char buf[MAX_EVENT_NAME_LEN]; > + char grp_buf[MAX_EVENT_NAME_LEN]; > enum probe_print_type ptype; > struct path path; > unsigned long offset, ref_ctr_offset; > @@ -644,12 +646,15 @@ static int __trace_uprobe_create(int argc, const char **argv) > > /* setup a probe */ > trace_probe_log_set_index(0); > + ret = TP_ENAME_EMPTY; > if (event) { > - ret = traceprobe_parse_event_name(&event, &group, buf, > + ret = traceprobe_parse_event_name(&event, &group, grp_buf, > event - argv[0]); > - if (ret) > + if (ret < 0) > goto fail_address_parse; > - } else { > + } > + > + if (ret == TP_ENAME_EMPTY || ret == TP_ENAME_GROUP) { > char *tail; > char *ptr; > > -- > 2.7.4 > -- Masami Hiramatsu (Google)