Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1598480pxb; Wed, 20 Oct 2021 08:12:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwQoqNaVuldr0YkPu7ONzQX36UQN5ea5eSG9v+wHEIKzAVjsNr5PTqoYFR+saaTbc2Kq3pV X-Received: by 2002:a17:906:ae54:: with SMTP id lf20mr132452ejb.195.1634742724911; Wed, 20 Oct 2021 08:12:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634742724; cv=none; d=google.com; s=arc-20160816; b=SzIQNMABMneHvYezcu6z/vAopUDfFznhPlZ84+r/Y5YozViDHkZAaBPwN+YvQyCchk +e0CqVBuSkAQy/iZARhzkckHFz5FltIntsundiq0Oa5uy93EOvtNKSUACwiN1IRXuqFd 2p+mB7XIK/gaHb8WAL5LDr5t9EPIOFRb4OF4OwoQ98qpM6domPVm6jC8PkQLOsj7gtyI YeuF1hYcxKfT5tmDb8nQbQOG5x1C+P8p1tJ4ke2LFu7oGAZ5QGJPe2vOcUE0N+iTDUpO mYv5pn6BMOVZ8GKEFXxNmxur5hMi3EJtujUuePYW2VzgtEeMgkARkEIVXkuaTpOyKC5N 1dfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=yLJhQQs51Uxpdmn2zlDR7fAhicqeE4YnDjWh4vfatZw=; b=Jci26+lj8ipqZwP8Lg3fJsKbcxp2wErzbQ1og+5kGT3u5TziKNU1+2HO3UJ5TH40ta IYfS3w14n+JvO3MrVaUoj+2HXVDLZJ5yqoyFROZ0kZq9qTMVD6hgCBqt3uyRFHR0Wd5h nQebJeKWZiNyTTS/EzQ4tmMocXm9NrrtOxxk1jxEmp4yFTJaRQcSjBTbuZF3s0ag4rAC cV8fBxLpcd4yx1zt4whMcxse685tty9snPKnEtWCwvrh+xff/iY1o/CmPENEHGu/IQNi 8+z7xG9Crx02Ka2Sr9gQHxiIzZKQW8Ju1IgGZovvEJ1pdRcn/mZbVKDaS9QlmIRmCi2f Jglw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 16si3112075ejd.275.2021.10.20.08.11.40; Wed, 20 Oct 2021 08:12:04 -0700 (PDT) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230272AbhJTPJL (ORCPT + 99 others); Wed, 20 Oct 2021 11:09:11 -0400 Received: from foss.arm.com ([217.140.110.172]:32924 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229570AbhJTPJK (ORCPT ); Wed, 20 Oct 2021 11:09:10 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id A911BED1; Wed, 20 Oct 2021 08:06:55 -0700 (PDT) Received: from [10.1.37.134] (e127744.cambridge.arm.com [10.1.37.134]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 146473F73D; Wed, 20 Oct 2021 08:06:52 -0700 (PDT) Subject: Re: [PATCH 5/5] perf arm-spe: Snapshot mode test To: Leo Yan Cc: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, John Garry , Will Deacon , Mathieu Poirier , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Mike Leach , linux-arm-kernel@lists.infradead.org, coresight@lists.linaro.org References: <20210916154635.1525-1-german.gomez@arm.com> <20210916154635.1525-5-german.gomez@arm.com> <20211020131339.GG49614@leoy-ThinkPad-X240s> From: German Gomez Message-ID: <4f3c3964-3448-586b-4199-764236938536@arm.com> Date: Wed, 20 Oct 2021 16:06:51 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <20211020131339.GG49614@leoy-ThinkPad-X240s> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Leo, I'm unable to reproduce. I've tried on top of the most recent perf/core branch but I still get exit code 0 consistently:     $ git log     commit be8ecc57f180415e8a7c1cc5620c5236be2a7e56 (grafted, origin/perf/core)     Author: Tony Garnock-Jones     Date:   Thu Sep 16 14:09:39 2021 +0200     $ ./perf test 88 -v     Couldn't bump rlimit(MEMLOCK), failures may take place when creating BPF maps, etc     88: Check Arm SPE trace data recording and synthesized samples      :     --- start ---     test child forked, pid 18700     Recording trace with snapshot mode /tmp/__perf_test.perf.data.xgsUt     Looking at perf.data file for dumping samples:     Looking at perf.data file for reporting samples:     SPE snapshot testing: PASS     test child finished with 0     ---- end ----     Check Arm SPE trace data recording and synthesized samples: Ok On 20/10/2021 14:13, Leo Yan wrote: > On Thu, Sep 16, 2021 at 04:46:35PM +0100, German Gomez wrote: >> Shell script test_arm_spe.sh has been added to test the recording of SPE >> tracing events in snapshot mode. >> >> Reviewed-by: James Clark >> Signed-off-by: German Gomez >> --- >> tools/perf/tests/shell/test_arm_spe.sh | 91 ++++++++++++++++++++++++++ >> 1 file changed, 91 insertions(+) >> create mode 100755 tools/perf/tests/shell/test_arm_spe.sh >> >> diff --git a/tools/perf/tests/shell/test_arm_spe.sh b/tools/perf/tests/shell/test_arm_spe.sh >> new file mode 100755 >> index 000000000000..9ed817e76f95 >> --- /dev/null >> +++ b/tools/perf/tests/shell/test_arm_spe.sh >> @@ -0,0 +1,91 @@ >> +#!/bin/sh >> +# Check Arm SPE trace data recording and synthesized samples >> + >> +# Uses the 'perf record' to record trace data of Arm SPE events; >> +# then verify if any SPE event samples are generated by SPE with >> +# 'perf script' and 'perf report' commands. >> + >> +# SPDX-License-Identifier: GPL-2.0 >> +# German Gomez , 2021 >> + >> +skip_if_no_arm_spe_event() { >> + perf list | egrep -q 'arm_spe_[0-9]+//' && return 0 >> + >> + # arm_spe event doesn't exist >> + return 2 >> +} >> + >> +skip_if_no_arm_spe_event || exit 2 >> + >> +perfdata=$(mktemp /tmp/__perf_test.perf.data.XXXXX) >> +glb_err=0 >> + >> +cleanup_files() >> +{ >> + rm -f ${perfdata} >> + trap - exit term int >> + kill -2 $$ # Forward sigint to parent > I understand you copy this code from Arm cs-etm testing, but I found > the sentence 'kill -2 $$' will cause a failure at my side with the > command: > > root@ubuntu:/home/leoy/linux/tools/perf# ./perf test 85 -v > 85: Check Arm SPE trace data recording and synthesized samples : > --- start --- > test child forked, pid 29053 > Recording trace with snapshot mode /tmp/__perf_test.perf.data.uughb > Looking at perf.data file for dumping samples: > Looking at perf.data file for reporting samples: > SPE snapshot testing: PASS > test child finished with -1 > ---- end ---- > Check Arm SPE trace data recording and synthesized samples: FAILED! > > I changed to use below code and looks it works for me: > > if [[ "$1" == "int" ]]; then > kill -SIGINT $$ > fi > if [[ "$1" == "term" ]]; then > kill -SIGTERM $$ > fi > > Thanks, > Leo > >> + exit $glb_err >> +} >> + >> +trap cleanup_files exit term int >> + >> +arm_spe_report() { >> + if [ $2 != 0 ]; then >> + echo "$1: FAIL" >> + glb_err=$2 >> + else >> + echo "$1: PASS" >> + fi >> +} >> + >> +perf_script_samples() { >> + echo "Looking at perf.data file for dumping samples:" >> + >> + # from arm-spe.c/arm_spe_synth_events() >> + events="(ld1-miss|ld1-access|llc-miss|lld-access|tlb-miss|tlb-access|branch-miss|remote-access|memory)" >> + >> + # Below is an example of the samples dumping: >> + # dd 3048 [002] 1 l1d-access: ffffaa64999c __GI___libc_write+0x3c (/lib/aarch64-linux-gnu/libc-2.27.so) >> + # dd 3048 [002] 1 tlb-access: ffffaa64999c __GI___libc_write+0x3c (/lib/aarch64-linux-gnu/libc-2.27.so) >> + # dd 3048 [002] 1 memory: ffffaa64999c __GI___libc_write+0x3c (/lib/aarch64-linux-gnu/libc-2.27.so) >> + perf script -F,-time -i ${perfdata} 2>&1 | \ >> + egrep " +$1 +[0-9]+ .* +${events}:(.*:)? +" > /dev/null 2>&1 >> +} >> + >> +perf_report_samples() { >> + echo "Looking at perf.data file for reporting samples:" >> + >> + # Below is an example of the samples reporting: >> + # 73.04% 73.04% dd libc-2.27.so [.] _dl_addr >> + # 7.71% 7.71% dd libc-2.27.so [.] getenv >> + # 2.59% 2.59% dd ld-2.27.so [.] strcmp >> + perf report --stdio -i ${perfdata} 2>&1 | \ >> + egrep " +[0-9]+\.[0-9]+% +[0-9]+\.[0-9]+% +$1 " > /dev/null 2>&1 >> +} >> + >> +arm_spe_snapshot_test() { >> + echo "Recording trace with snapshot mode $perfdata" >> + perf record -o ${perfdata} -e arm_spe// -S \ >> + -- dd if=/dev/zero of=/dev/null > /dev/null 2>&1 & >> + PERFPID=$! >> + >> + # Wait for perf program >> + sleep 1 >> + >> + # Send signal to snapshot trace data >> + kill -USR2 $PERFPID >> + >> + # Stop perf program >> + kill $PERFPID >> + wait $PERFPID >> + >> + perf_script_samples dd && >> + perf_report_samples dd >> + >> + err=$? >> + arm_spe_report "SPE snapshot testing" $err >> +} >> + >> +arm_spe_snapshot_test >> +exit $glb_err >> \ No newline at end of file >> -- >> 2.17.1 >>