Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp3295544pxb; Tue, 19 Jan 2021 20:26:22 -0800 (PST) X-Google-Smtp-Source: ABdhPJzTam343rtIUA99ittSkgw8+1xStPgSQfz9VuHspk1lwOSOBwrZvMzBV9swXoG93CrQxQ5l X-Received: by 2002:a17:906:958e:: with SMTP id r14mr5166179ejx.319.1611116782288; Tue, 19 Jan 2021 20:26:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611116782; cv=none; d=google.com; s=arc-20160816; b=B7ghYSzqzWx22Hi4sC2ctpFflMtjTviOVmMN81yRHeSh9AYup01qxvUl6zHWxFWTq8 Qqk7rmMsJAR/Hx7dikmUclrZ0CpLUSI6nssVRvZgsw8q5itsKg5sHNxTT1rG7elSBNJt u2sXR23woWP924ZlAxNVIFRHHF3K4Xe2sG0w5G+9eX04JVB3hhiqudYTQRGvXlKhqmk0 rTcnGCLXBxtZLdX+Cs4eAyRlCAJ6Yfip8g8OYObEcUrmGMub92HngN3Vd2zta9kb67+F h6OQt04W2wge08AY962VpM/hR33+gQzF7sx9TYg1H/VkqTfwxA3FQ2ZaKVgCenqtkQ7a 42AQ== 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=P85lye/NxIui9GX7mPLXpyS2FXow7RN3AUfCrEvrNwg=; b=nfND0ubdTwxenV7gR1OIxoMirNTKMdmGkYAWLO1JuAXhU0tP9uKmBmzop60QLLRmRh xiI37BssDr/33YGerwUfFpMIsbJtzV0rqoXd/iaJYmyQ30GzvUxF1Eubwbnl7ibdUzHc D70DA5prIJlY5+vvrE47fsFfokRlV4SYAO3Jc1IA51wIzLBPZNvTloSi3kNJmXCU9aIm snm83yJk11Jhvm045VHMujDy/ON9TnsIFgVAHyCABaUfv6Upq92cEEQzNT3cJ7Xeqps1 SCkkWB7K0KeTi+aT65qCXhxi3GR/RqePzOXtaEC3dTu9cQHsDDC7D0dU6G2bi+q4nZGv rmvg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=DwjLbCBO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f6si363579edq.152.2021.01.19.20.25.59; Tue, 19 Jan 2021 20:26:22 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=DwjLbCBO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1728756AbhATETx (ORCPT + 99 others); Tue, 19 Jan 2021 23:19:53 -0500 Received: from mail.kernel.org ([198.145.29.99]:47994 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730784AbhATEOv (ORCPT ); Tue, 19 Jan 2021 23:14:51 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 9C4532312D; Wed, 20 Jan 2021 04:14:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1611116050; bh=3ePYciKZe3v9kuW41JjidNDqr1nlrNykqTEuwNB1IL0=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=DwjLbCBOdNNktFj/uoJZxURFfmA5Mh7PI0PiR/Vy510SSVEf1N9yw6zimSXnxYCao Ajf6/4Wbg2QdRnJAmNZ8tontWlp7tRIov7ciR+3EnXJmQOo3NEGgwkk8WhCMyUUENT w4Adg2la3cDBWmomcgtn3kg0CRNSjuMrRph9f+vqbZUyZkDtJ570JqBXbVkHW5YnbX xWcfrDlpTjdelxdggw0u/AqZTbSXbcX0DZG81K02ycr0dLZ6ypMWgfBxFSgh8v4Aen uItMqPdOGdvMKmFnTmZxNQHYSry4LbopZ3DdSSuM94cLqW+98BXWeR/IUUlOOJu8sC fprguD7kNllfQ== Date: Wed, 20 Jan 2021 13:14:06 +0900 From: Masami Hiramatsu To: Masami Hiramatsu Cc: Steven Rostedt , Jianlin Lv , mingo@redhat.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH] tracing: precise log info for kretprobe addr err Message-Id: <20210120131406.5a992c1e434681750a0cd5d4@kernel.org> In-Reply-To: <20210120122415.76fa3539ce031bfb90e1c862@kernel.org> References: <20210119151014.3822465-1-Jianlin.Lv@arm.com> <20210119104106.2213a49c@gandalf.local.home> <20210120122415.76fa3539ce031bfb90e1c862@kernel.org> 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 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 20 Jan 2021 12:24:15 +0900 Masami Hiramatsu wrote: > Hi, > > On Tue, 19 Jan 2021 10:41:06 -0500 > Steven Rostedt wrote: > > > Masami, > > > > Looks fine to me. What do you think? > > Agreed. Since register_kretprobe() checks the address by kprobe_on_func_entry(), > if it is not passed, it should always fail to register at last. > > Acked-by: Masami Hiramatsu Oops, sorry I missed one case. Since kprobe_events can accept a symbol with module name (MOD:symbol) If the given symbol is on a module which is not loaded, kprobe_on_func_entry(NULL, symbol, offset) may return false too. (But that kretprobe must be enabled after the target module is loaded) To confirm it correctly, add !strchr(symbol, ':') there to check it is really bad symbol or not. diff --git a/kernel/trace/trace_kprobe.c b/kernel/trace/trace_kprobe.c index 5fff39541b8a..0170f8e6430b 100644 --- a/kernel/trace/trace_kprobe.c +++ b/kernel/trace/trace_kprobe.c @@ -830,7 +830,7 @@ static int trace_kprobe_create(int argc, const char *argv[]) flags |= TPARG_FL_RETURN; if (kprobe_on_func_entry(NULL, symbol, offset)) flags |= TPARG_FL_FENTRY; - if (offset && is_return && !(flags & TPARG_FL_FENTRY)) { + if (!strchr(symbol, ':') && is_return && !(flags & TPARG_FL_FENTRY)) { trace_probe_log_err(0, BAD_RETPROBE); goto parse_error; } Thank you, > > Thank you! > > > > > -- Steve > > > > > > On Tue, 19 Jan 2021 23:10:14 +0800 > > Jianlin Lv wrote: > > > > > When trying to create kretprobe with the wrong function symbol in tracefs; > > > The error is triggered in the register_trace_kprobe() and recorded as > > > FAIL_REG_PROBE issue, > > > > > > Example: > > > $ cd /sys/kernel/debug/tracing > > > $ echo 'r:myprobe ERROR_SYMBOL_XXX ret=%x0' >> kprobe_events > > > bash: echo: write error: Invalid argument > > > $ cat error_log > > > [142797.347877] trace_kprobe: error: Failed to register probe event > > > Command: r:myprobe ERROR_SYMBOL_XXX ret=%x0 > > > ^ > > > > > > This error can be detected in the parameter parsing stage, the effect of > > > applying this patch is as follows: > > > > > > $ echo 'r:myprobe ERROR_SYMBOL_XXX ret=%x0' >> kprobe_events > > > bash: echo: write error: Invalid argument > > > $ cat error_log > > > [415.89]trace_kprobe: error: Retprobe address must be an function entry > > > Command: r:myprobe ERROR_SYMBOL_XXX ret=%x0 > > > ^ > > > > > > Signed-off-by: Jianlin Lv > > > --- > > > kernel/trace/trace_kprobe.c | 2 +- > > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > > > diff --git a/kernel/trace/trace_kprobe.c b/kernel/trace/trace_kprobe.c > > > index e6fba1798771..3dfd1b6711a3 100644 > > > --- a/kernel/trace/trace_kprobe.c > > > +++ b/kernel/trace/trace_kprobe.c > > > @@ -830,7 +830,7 @@ static int trace_kprobe_create(int argc, const char *argv[]) > > > flags |= TPARG_FL_RETURN; > > > if (kprobe_on_func_entry(NULL, symbol, offset)) > > > flags |= TPARG_FL_FENTRY; > > > - if (offset && is_return && !(flags & TPARG_FL_FENTRY)) { > > > + if (is_return && !(flags & TPARG_FL_FENTRY)) { > > > trace_probe_log_err(0, BAD_RETPROBE); > > > goto parse_error; > > > } > > > > > -- > Masami Hiramatsu -- Masami Hiramatsu