[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <d0ab6e2e-cd57-4477-8171-77b4c2d364f7@linaro.org>
Date: Tue, 7 Jan 2025 16:51:31 +0000
From: James Clark <james.clark@...aro.org>
To: Leo Yan <leo.yan@....com>
Cc: Jing Zhang <renyu.zj@...ux.alibaba.com>,
Guilherme Amadio <amadio@...too.org>,
Arnaldo Carvalho de Melo <acme@...nel.org>,
Namhyung Kim <namhyung@...nel.org>, Mark Rutland <mark.rutland@....com>,
Alexander Shishkin <alexander.shishkin@...ux.intel.com>,
Jiri Olsa <jolsa@...nel.org>, Ian Rogers <irogers@...gle.com>,
Adrian Hunter <adrian.hunter@...el.com>,
"Liang, Kan" <kan.liang@...ux.intel.com>,
Thomas Richter <tmricht@...ux.ibm.com>,
Athira Rajeev <atrajeev@...ux.vnet.ibm.com>,
linux-perf-users@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH v2] perf test record+probe_libc_inet_pton: Make test
resilient
On 02/12/2024 11:19 am, Leo Yan wrote:
> The test failed back and forth due to the call chain being heavily
> impacted by the libc, which varies across different architectures and
> distros.
>
> The libc contains the symbols for "gaih_inet" and "getaddrinfo" in some
> cases, but not always. Moreover, these symbols can be either normal
> symbols or dynamic symbols, making it difficult to decide the call chain
> entries due to the symbols are inconsistent.
>
> To fix the issue, this commit identifies three call chain entries are
> always present. These entries are matched by iterating through the
> lines in the "perf script" result. The recording attribute max-stack is
> set to 4 for the possible maximum call chain depth.
>
> After:
>
> # perf test -vF pton
> --- start ---
> Pattern: ping[][0-9 \.:]+probe_libc:inet_pton: \([[:xdigit:]]+\)
> Matching: ping 285058 [025] 1219802.466939: probe_libc:inet_pton: (ffffa14b7cf0)
> Pattern: .*inet_pton\+0x[[:xdigit:]]+[[:space:]]\(/usr/lib/aarch64-linux-gnu/libc-2.31.so|inlined\)$
> Matching: ping 285058 [025] 1219802.466939: probe_libc:inet_pton: (ffffa14b7cf0)
> Matching: ffffa14b7cf0 __GI___inet_pton+0x0 (/usr/lib/aarch64-linux-gnu/libc-2.31.so)
> Pattern: .*(\+0x[[:xdigit:]]+|\[unknown\])[[:space:]]\(.*/bin/ping.*\)$
> Matching: ping 285058 [025] 1219802.466939: probe_libc:inet_pton: (ffffa14b7cf0)
> Matching: ffffa14b7cf0 __GI___inet_pton+0x0 (/usr/lib/aarch64-linux-gnu/libc-2.31.so)
> Matching: ffffa1488040 getaddrinfo+0xe8 (/usr/lib/aarch64-linux-gnu/libc-2.31.so)
> Matching: aaaab8672da4 [unknown] (/usr/bin/ping)
> ---- end ----
> 82: probe libc's inet_pton & backtrace it with ping : Ok
>
> Reported-by: Jing Zhang <renyu.zj@...ux.alibaba.com>
> Closes: https://lore.kernel.org/linux-perf-users/1728978807-81116-1-git-send-email-renyu.zj@linux.alibaba.com/
> Reported-by: Guilherme Amadio <amadio@...too.org>
> Closes: https://lore.kernel.org/linux-perf-users/Z0X3AYUWkAgfPpWj@x1/T/#m57327e135b156047e37d214a0d453af6ae1e02be
> Signed-off-by: Leo Yan <leo.yan@....com>
> ---
> Changes from v1: Fixed a typo s/Seatch/Search.
>
> .../shell/record+probe_libc_inet_pton.sh | 34 ++++++++++---------
> 1 file changed, 18 insertions(+), 16 deletions(-)
>
Reviewed-by: James Clark <james.clark@...aro.org>
> diff --git a/tools/perf/tests/shell/record+probe_libc_inet_pton.sh b/tools/perf/tests/shell/record+probe_libc_inet_pton.sh
> index 47a26f25db9f..3fbc7a7409af 100755
> --- a/tools/perf/tests/shell/record+probe_libc_inet_pton.sh
> +++ b/tools/perf/tests/shell/record+probe_libc_inet_pton.sh
> @@ -43,17 +43,8 @@ trace_libc_inet_pton_backtrace() {
> echo "((__GI_)?getaddrinfo|text_to_binary_address)\+0x[[:xdigit:]]+[[:space:]]\($libc|inlined\)$" >> $expected
> echo "(gaih_inet|main)\+0x[[:xdigit:]]+[[:space:]]\(inlined|.*/bin/ping.*\)$" >> $expected
> ;;
> - ppc64|ppc64le)
> - eventattr='max-stack=4'
> - # Add gaih_inet to expected backtrace only if it is part of libc.
> - if nm $libc | grep -F -q gaih_inet.; then
> - echo "gaih_inet.*\+0x[[:xdigit:]]+[[:space:]]\($libc\)$" >> $expected
> - fi
> - echo "getaddrinfo\+0x[[:xdigit:]]+[[:space:]]\($libc\)$" >> $expected
> - echo ".*(\+0x[[:xdigit:]]+|\[unknown\])[[:space:]]\(.*/bin/ping.*\)$" >> $expected
> - ;;
> *)
> - eventattr='max-stack=3'
> + eventattr='max-stack=4'
> echo ".*(\+0x[[:xdigit:]]+|\[unknown\])[[:space:]]\(.*/bin/ping.*\)$" >> $expected
> ;;
> esac
> @@ -76,14 +67,25 @@ trace_libc_inet_pton_backtrace() {
> fi
> perf script -i $perf_data | tac | grep -m1 ^ping -B9 | tac > $perf_script
>
> - exec 3<$perf_script
> exec 4<$expected
> - while read line <&3 && read -r pattern <&4; do
> + while read -r pattern <&4; do
> + echo "Pattern: $pattern"
> [ -z "$pattern" ] && break
> - echo $line
> - echo "$line" | grep -E -q "$pattern"
> - if [ $? -ne 0 ] ; then
> - printf "FAIL: expected backtrace entry \"%s\" got \"%s\"\n" "$pattern" "$line"
> +
> + found=0
> +
> + # Search lines in the perf script result
> + exec 3<$perf_script
> + while read line <&3; do
> + [ -z "$line" ] && break
> + echo " Matching: $line"
> + ! echo "$line" | grep -E -q "$pattern"
> + found=$?
> + [ $found -eq 1 ] && break
> + done
> +
> + if [ $found -ne 1 ] ; then
> + printf "FAIL: Didn't find the expected backtrace entry \"%s\"\n" "$pattern"
> return 1
> fi
> done
Powered by blists - more mailing lists