From nobody Tue Jun 30 03:34:17 2026 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 4E81DC433F5 for ; Fri, 28 Jan 2022 20:08:36 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351115AbiA1UIf (ORCPT ); Fri, 28 Jan 2022 15:08:35 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236700AbiA1UIe (ORCPT ); Fri, 28 Jan 2022 15:08:34 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E807AC061714 for ; Fri, 28 Jan 2022 12:08:33 -0800 (PST) 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 dfw.source.kernel.org (Postfix) with ESMTPS id 81F6861DBF for ; Fri, 28 Jan 2022 20:08:33 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 88268C340E7; Fri, 28 Jan 2022 20:08:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643400512; bh=Ng5lD8gq9k8/TN+0eDDm3alPdjwfyAK3wLNSagvKgdQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:In-Reply-To: References:From; b=Sbp0/6y5FFhWim+N27W/ug2O6vOVgJgpAKMH600ylbVPb+wxDFhdmi1i4CpbhJ4D+ 6MbDeh2LxLCLVTxWY8B96XsKoCH6vcVBs556mCISpx0vjaQgrF3/wWnl9TL2UXHt4e XXiIeLojCpjK3PqhLMwjkh4ZLLGBR7nU73K2uSE3sb0AwcfHKSXLG68/IfdUZ9SElo X/O5XredoaSBsNjOU6TmlzY8ceVbCbdmgdJ52P0L148o2QTXz2pgj69acAC2SQ/+ct 8687tZvhnHJrndulwbncOGsS4IbgYzlTKA3yzAxuIInG+MPiazVUplzOf9SKitQMbC hxJvjBfm+L3jA== From: Tom Zanussi To: rostedt@goodmis.org Cc: mhiramat@kernel.org, linux-kernel@vger.kernel.org, Tom Zanussi Subject: [PATCH v2 1/2] tracing: Remove size restriction on hist trigger cmd error logging Date: Fri, 28 Jan 2022 14:08:26 -0600 Message-Id: <0f9d46407222eaf6632cd3b417bc50a11f401b71.1643399022.git.zanussi@kernel.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: References: In-Reply-To: References: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Currently, hist trigger command error strings are restricted to a length of MAX_FILTER_STR_VAL (256), which is too short for some commands already seen in the wild (with cmd strings longer than that showing up truncated in err_log). Remove the restriction so that no hist trigger command error string is ever truncated. Signed-off-by: Tom Zanussi --- kernel/trace/trace_events_hist.c | 30 +++++++++++++++++++++++------- 1 file changed, 23 insertions(+), 7 deletions(-) diff --git a/kernel/trace/trace_events_hist.c b/kernel/trace/trace_events_h= ist.c index ada87bfb5bb8..5e8970624bce 100644 --- a/kernel/trace/trace_events_hist.c +++ b/kernel/trace/trace_events_hist.c @@ -727,11 +727,16 @@ static struct track_data *track_data_alloc(unsigned i= nt key_len, return data; } =20 -static char last_cmd[MAX_FILTER_STR_VAL]; +#define HIST_PREFIX "hist:" + +static char *last_cmd; static char last_cmd_loc[MAX_FILTER_STR_VAL]; =20 static int errpos(char *str) { + if (!str || !last_cmd) + return 0; + return err_pos(last_cmd, str); } =20 @@ -739,12 +744,19 @@ static void last_cmd_set(struct trace_event_file *fil= e, char *str) { const char *system =3D NULL, *name =3D NULL; struct trace_event_call *call; + int len =3D 0; =20 if (!str) return; =20 - strcpy(last_cmd, "hist:"); - strncat(last_cmd, str, MAX_FILTER_STR_VAL - 1 - sizeof("hist:")); + len +=3D sizeof(HIST_PREFIX) + strlen(str) + 1; + kfree(last_cmd); + last_cmd =3D kzalloc(len, GFP_KERNEL); + if (!last_cmd) + return; + + strcpy(last_cmd, HIST_PREFIX); + strncat(last_cmd, str, len - sizeof(HIST_PREFIX)); =20 if (file) { call =3D file->event_call; @@ -757,18 +769,22 @@ static void last_cmd_set(struct trace_event_file *fil= e, char *str) } =20 if (system) - snprintf(last_cmd_loc, MAX_FILTER_STR_VAL, "hist:%s:%s", system, name); + snprintf(last_cmd_loc, MAX_FILTER_STR_VAL, HIST_PREFIX "%s:%s", system, = name); } =20 -static void hist_err(struct trace_array *tr, u8 err_type, u8 err_pos) +static void hist_err(struct trace_array *tr, u8 err_type, u16 err_pos) { + if (!last_cmd) + return; + tracing_log_err(tr, last_cmd_loc, last_cmd, err_text, err_type, err_pos); } =20 static void hist_err_clear(void) { - last_cmd[0] =3D '\0'; + if (last_cmd) + last_cmd[0] =3D '\0'; last_cmd_loc[0] =3D '\0'; } =20 @@ -5610,7 +5626,7 @@ static int event_hist_trigger_print(struct seq_file *= m, bool have_var =3D false; unsigned int i; =20 - seq_puts(m, "hist:"); + seq_puts(m, HIST_PREFIX); =20 if (data->name) seq_printf(m, "%s:", data->name); --=20 2.17.1 From nobody Tue Jun 30 03:34:17 2026 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id B9469C433FE for ; Fri, 28 Jan 2022 20:08:37 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351136AbiA1UIh (ORCPT ); Fri, 28 Jan 2022 15:08:37 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36770 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351109AbiA1UIf (ORCPT ); Fri, 28 Jan 2022 15:08:35 -0500 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2B410C06173B for ; Fri, 28 Jan 2022 12:08:35 -0800 (PST) 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 dfw.source.kernel.org (Postfix) with ESMTPS id C03B361DCA for ; Fri, 28 Jan 2022 20:08:34 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id CF54BC340EB; Fri, 28 Jan 2022 20:08:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643400514; bh=4K4IWRbcZ254e2H50ie9lOC9n8GLTP1rVEIdNgWO43w=; h=From:To:Cc:Subject:Date:In-Reply-To:References:In-Reply-To: References:From; b=BBNDEXBEQbf+6n9IWqTgisEvB+ZnZD6Wg5xB/iHrZ/YY1RNG2D0oRAfdykvviIHpq YG3+mXHvF9UkIjSQnAeA4niBiOGaxKdrad/ovigZHcM5+vOYKpWIZYTtdqWWtS9DES dITLbMTvY1V0PoAP1KRZYjY8hkVD7CV8bVkqTaA4Os/WaHp6+d55Od2SY9/IH00xS/ EIcRDHEpIzINwfRSan0oQdJ8L905xrTifieVT8HpEy2ofTv1UiQgl2T/3kSdC8/bKg XeLMVyYy9MqrOVTWBHhFZHxH/MrvdHemohbe/Lv5TQE+lsLAbLU1sqEvrQVd6+T+C+ BLCLgTlous+Kg== From: Tom Zanussi To: rostedt@goodmis.org Cc: mhiramat@kernel.org, linux-kernel@vger.kernel.org, Tom Zanussi Subject: [PATCH v2 2/2] tracing: Remove size restriction on synthetic event cmd error logging Date: Fri, 28 Jan 2022 14:08:27 -0600 Message-Id: <0376692396a81d0b795127c66ea92ca5bf60f481.1643399022.git.zanussi@kernel.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: References: In-Reply-To: References: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Currently, synthetic event command error strings are restricted to a length of MAX_FILTER_STR_VAL (256), which is too short for some commands already seen in the wild (with cmd strings longer than that showing up truncated in err_log). Remove the restriction so that no synthetic event command error string is ever truncated. Signed-off-by: Tom Zanussi --- kernel/trace/trace_events_synth.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/kernel/trace/trace_events_synth.c b/kernel/trace/trace_events_= synth.c index 149011e34ad9..d3d9cd677f9a 100644 --- a/kernel/trace/trace_events_synth.c +++ b/kernel/trace/trace_events_synth.c @@ -42,10 +42,13 @@ enum { ERRORS }; =20 static const char *err_text[] =3D { ERRORS }; =20 -static char last_cmd[MAX_FILTER_STR_VAL]; +static char *last_cmd; =20 static int errpos(const char *str) { + if (!str || !last_cmd) + return 0; + return err_pos(last_cmd, str); } =20 @@ -54,11 +57,19 @@ static void last_cmd_set(const char *str) if (!str) return; =20 - strncpy(last_cmd, str, MAX_FILTER_STR_VAL - 1); + kfree(last_cmd); + last_cmd =3D kzalloc(strlen(str) + 1, GFP_KERNEL); + if (!last_cmd) + return; + + strncpy(last_cmd, str, strlen(str) + 1); } =20 -static void synth_err(u8 err_type, u8 err_pos) +static void synth_err(u8 err_type, u16 err_pos) { + if (!last_cmd) + return; + tracing_log_err(NULL, "synthetic_events", last_cmd, err_text, err_type, err_pos); } --=20 2.17.1