From: Namhyung Kim <namhyung@kernel.org>
To: Ian Rogers <irogers@google.com>
Cc: Peter Zijlstra <peterz@infradead.org>,
Ingo Molnar <mingo@redhat.com>,
Arnaldo Carvalho de Melo <acme@kernel.org>,
Mark Rutland <mark.rutland@arm.com>,
Alexander Shishkin <alexander.shishkin@linux.intel.com>,
Jiri Olsa <jolsa@kernel.org>,
Adrian Hunter <adrian.hunter@intel.com>,
Kan Liang <kan.liang@linux.intel.com>,
John Garry <john.g.garry@oracle.com>,
Will Deacon <will@kernel.org>,
James Clark <james.clark@linaro.org>,
Mike Leach <mike.leach@linaro.org>, Leo Yan <leo.yan@linux.dev>,
Guo Ren <guoren@kernel.org>,
Paul Walmsley <paul.walmsley@sifive.com>,
Palmer Dabbelt <palmer@dabbelt.com>,
Albert Ou <aou@eecs.berkeley.edu>, Nick Terrell <terrelln@fb.com>,
Guilherme Amadio <amadio@gentoo.org>,
Changbin Du <changbin.du@huawei.com>,
"Steinar H. Gunderson" <sesse@google.com>,
"Masami Hiramatsu (Google)" <mhiramat@kernel.org>,
Aditya Gupta <adityag@linux.ibm.com>,
Athira Rajeev <atrajeev@linux.vnet.ibm.com>,
Masahiro Yamada <masahiroy@kernel.org>,
Huacai Chen <chenhuacai@kernel.org>,
Bibo Mao <maobibo@loongson.cn>, Kajol Jain <kjain@linux.ibm.com>,
Anup Patel <anup@brainfault.org>,
Shenlin Liang <liangshenlin@eswincomputing.com>,
Atish Patra <atishp@rivosinc.com>,
Oliver Upton <oliver.upton@linux.dev>,
Chen Pei <cp0613@linux.alibaba.com>,
Dima Kogan <dima@secretsauce.net>,
Alexander Lobakin <aleksander.lobakin@intel.com>,
"David S. Miller" <davem@davemloft.net>,
Przemek Kitszel <przemyslaw.kitszel@intel.com>,
linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org,
Yang Jihong <yangjihong@bytedance.com>
Subject: Re: [PATCH v1 07/11] perf probe: Move elfutils support check to libdw check
Date: Thu, 26 Sep 2024 12:35:36 -0700 [thread overview]
Message-ID: <ZvW3iIhvSesG5_SC@google.com> (raw)
In-Reply-To: <CAP-5=fWvCoDx66xJhZ+bB0jC4tYOjqZh=jCf+APNg+hGvfyMbA@mail.gmail.com>
On Thu, Sep 26, 2024 at 08:08:22AM -0700, Ian Rogers wrote:
> On Wed, Sep 25, 2024 at 5:30 PM Namhyung Kim <namhyung@kernel.org> wrote:
> >
> > On Tue, Sep 24, 2024 at 09:04:14AM -0700, Ian Rogers wrote:
> > > The test _ELFUTILS_PREREQ(0, 142) is false for elfutils before
> > > 2009-06-13, but that is 15 years ago and very unlikely. Add a test to
> > > test-libdw.c and assume the libdw version is at least 0.142 to
> > > simplify the build logic.
> > >
> > > Signed-off-by: Ian Rogers <irogers@google.com>
> > > ---
> > > tools/build/feature/test-libdw.c | 10 +++++++++-
> > > tools/perf/util/probe-finder.c | 2 --
> > > tools/perf/util/probe-finder.h | 2 --
> > > 3 files changed, 9 insertions(+), 5 deletions(-)
> > >
> > > diff --git a/tools/build/feature/test-libdw.c b/tools/build/feature/test-libdw.c
> > > index 71c6f8e3b0ee..2fb59479ab77 100644
> > > --- a/tools/build/feature/test-libdw.c
> > > +++ b/tools/build/feature/test-libdw.c
> > > @@ -41,8 +41,16 @@ int test_libdw_getcfi(void)
> > > return dwarf_getcfi(dwarf) == NULL;
> > > }
> > >
> > > +int test_elfutils(void)
> > > +{
> > > + Dwarf_CFI *cfi = NULL;
> > > +
> > > + dwarf_cfi_end(cfi);
> > > + return 0;
> > > +}
> >
> > I think it's the same as test_libdw_getcfi() and let's get rid of it.
>
> The point of doing the change this way, and I think what's being
> ignored, is that I am trying to simply replace an #if with a clearly
> equivalent feature test - clearly equivalent as the #if guards use of
> dwarf_cfi_end in the code. Merging test_elfutils with
> test_libdw_getcfi is another cognitive step and I think it is fine as
> follow up cleanup. Combining that step with the change here fails the
> minimal meaningful change and tbh I think this is just bike shedding.
Ok, I think it's ok to have a separate commit to combine equivalent
tests if you really want to. What I want in the end is not to have
unnecessary or duplicate code.
In order to have a clearly equivalent feature test, I think you can add
#if !_ELFUTILS_PREREQ(0, 142)
#error "elfutils version is too old"
#endif
Thanks,
Namhyung
> >
> > > +
> > > int main(void)
> > > {
> > > return test_libdw() + test_libdw_unwind() + test_libdw_getlocations() +
> > > - test_libdw_getcfi();
> > > + test_libdw_getcfi() + test_elfutils();
> > > }
> > > diff --git a/tools/perf/util/probe-finder.c b/tools/perf/util/probe-finder.c
> > > index 78f34fa0c391..7434b38596b9 100644
> > > --- a/tools/perf/util/probe-finder.c
> > > +++ b/tools/perf/util/probe-finder.c
> > > @@ -1379,10 +1379,8 @@ int debuginfo__find_trace_events(struct debuginfo *dbg,
> > > if (ret >= 0 && tf.pf.skip_empty_arg)
> > > ret = fill_empty_trace_arg(pev, tf.tevs, tf.ntevs);
> > >
> > > -#if _ELFUTILS_PREREQ(0, 142)
> > > dwarf_cfi_end(tf.pf.cfi_eh);
> > > dwarf_cfi_end(tf.pf.cfi_dbg);
> > > -#endif
> > >
> > > if (ret < 0 || tf.ntevs == 0) {
> > > for (i = 0; i < tf.ntevs; i++)
> > > diff --git a/tools/perf/util/probe-finder.h b/tools/perf/util/probe-finder.h
> > > index 3add5ff516e1..f0149d72310c 100644
> > > --- a/tools/perf/util/probe-finder.h
> > > +++ b/tools/perf/util/probe-finder.h
> > > @@ -63,12 +63,10 @@ struct probe_finder {
> > > struct intlist *lcache; /* Line cache for lazy match */
> > >
> > > /* For variable searching */
> > > -#if _ELFUTILS_PREREQ(0, 142)
> > > /* Call Frame Information from .eh_frame */
> > > Dwarf_CFI *cfi_eh;
> > > /* Call Frame Information from .debug_frame */
> > > Dwarf_CFI *cfi_dbg;
> > > -#endif
> > > Dwarf_Op *fb_ops; /* Frame base attribute */
> > > unsigned int machine; /* Target machine arch */
> > > struct perf_probe_arg *pvar; /* Current target variable */
> > > --
> > > 2.46.0.792.g87dc391469-goog
> > >
next prev parent reply other threads:[~2024-09-26 19:35 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-24 16:04 [PATCH v1 00/11] Libdw/dwarf build clean up Ian Rogers
2024-09-24 16:04 ` [PATCH v1 01/11] perf build: Rename NO_DWARF to NO_LIBDW Ian Rogers
2024-09-26 0:26 ` Namhyung Kim
2024-09-26 15:02 ` Ian Rogers
2024-09-26 19:28 ` Namhyung Kim
2024-09-29 2:01 ` Masami Hiramatsu
2024-09-29 2:01 ` Masami Hiramatsu
2024-09-24 16:04 ` [PATCH v1 02/11] perf build: Remove defined but never used variable Ian Rogers
2024-09-29 2:02 ` Masami Hiramatsu
2024-09-24 16:04 ` [PATCH v1 03/11] perf build: Rename test-dwarf to test-libdw Ian Rogers
2024-09-26 0:28 ` Namhyung Kim
2024-09-26 15:37 ` Ian Rogers
2024-09-26 18:23 ` Namhyung Kim
2024-09-29 2:06 ` Masami Hiramatsu
2024-09-24 16:04 ` [PATCH v1 04/11] perf build: Combine libdw-dwarf-unwind into libdw feature tests Ian Rogers
2024-09-24 16:04 ` [PATCH v1 05/11] perf build: Combine test-dwarf-getlocations into test-libdw Ian Rogers
2024-09-24 16:04 ` [PATCH v1 06/11] perf build: Combine test-dwarf-getcfi " Ian Rogers
2024-09-24 16:04 ` [PATCH v1 07/11] perf probe: Move elfutils support check to libdw check Ian Rogers
2024-09-26 0:29 ` Namhyung Kim
2024-09-26 15:08 ` Ian Rogers
2024-09-26 19:35 ` Namhyung Kim [this message]
2024-09-24 16:04 ` [PATCH v1 08/11] perf libdw: Remove unnecessary defines Ian Rogers
2024-09-29 2:10 ` Masami Hiramatsu
2024-09-24 16:04 ` [PATCH v1 09/11] perf build: Rename HAVE_DWARF_SUPPORT to HAVE_LIBDW_SUPPORT Ian Rogers
2024-09-26 0:34 ` Namhyung Kim
2024-09-26 15:10 ` Ian Rogers
2024-09-26 19:36 ` Namhyung Kim
2024-09-24 16:04 ` [PATCH v1 10/11] perf build: Rename CONFIG_DWARF to CONFIG_LIBDW Ian Rogers
2024-09-24 16:04 ` [PATCH v1 11/11] perf build: Rename PERF_HAVE_DWARF_REGS to PERF_HAVE_LIBDW_REGS Ian Rogers
2024-09-26 3:27 ` Namhyung Kim
2024-09-26 12:47 ` Ian Rogers
2024-09-26 19:39 ` Namhyung Kim
2024-09-26 19:55 ` Ian Rogers
2024-09-27 17:16 ` Namhyung Kim
2024-09-27 18:15 ` Ian Rogers
2024-09-29 2:35 ` Masami Hiramatsu
2024-10-01 4:02 ` Ian Rogers
2024-10-01 23:09 ` Namhyung Kim
2024-10-01 23:17 ` Ian Rogers
2024-10-01 23:28 ` Masami Hiramatsu
2024-10-02 1:31 ` Ian Rogers
2024-10-02 13:56 ` Masami Hiramatsu
2024-10-02 14:27 ` Ian Rogers
2024-10-03 22:48 ` Namhyung Kim
2024-10-04 0:58 ` Ian Rogers
2024-10-04 5:12 ` Namhyung Kim
2024-10-04 14:45 ` Masami Hiramatsu
2024-10-04 15:15 ` Ian Rogers
2024-10-04 19:23 ` Namhyung Kim
2024-10-04 14:32 ` Masami Hiramatsu
2024-09-24 19:44 ` [PATCH v1 00/11] Libdw/dwarf build clean up Leo Yan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ZvW3iIhvSesG5_SC@google.com \
--to=namhyung@kernel.org \
--cc=acme@kernel.org \
--cc=adityag@linux.ibm.com \
--cc=adrian.hunter@intel.com \
--cc=aleksander.lobakin@intel.com \
--cc=alexander.shishkin@linux.intel.com \
--cc=amadio@gentoo.org \
--cc=anup@brainfault.org \
--cc=aou@eecs.berkeley.edu \
--cc=atishp@rivosinc.com \
--cc=atrajeev@linux.vnet.ibm.com \
--cc=changbin.du@huawei.com \
--cc=chenhuacai@kernel.org \
--cc=cp0613@linux.alibaba.com \
--cc=davem@davemloft.net \
--cc=dima@secretsauce.net \
--cc=guoren@kernel.org \
--cc=irogers@google.com \
--cc=james.clark@linaro.org \
--cc=john.g.garry@oracle.com \
--cc=jolsa@kernel.org \
--cc=kan.liang@linux.intel.com \
--cc=kjain@linux.ibm.com \
--cc=leo.yan@linux.dev \
--cc=liangshenlin@eswincomputing.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-perf-users@vger.kernel.org \
--cc=maobibo@loongson.cn \
--cc=mark.rutland@arm.com \
--cc=masahiroy@kernel.org \
--cc=mhiramat@kernel.org \
--cc=mike.leach@linaro.org \
--cc=mingo@redhat.com \
--cc=oliver.upton@linux.dev \
--cc=palmer@dabbelt.com \
--cc=paul.walmsley@sifive.com \
--cc=peterz@infradead.org \
--cc=przemyslaw.kitszel@intel.com \
--cc=sesse@google.com \
--cc=terrelln@fb.com \
--cc=will@kernel.org \
--cc=yangjihong@bytedance.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.