Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp598647pxa; Wed, 12 Aug 2020 09:13:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzIv8T26GMRRS7zqDX/vbWXyv0lsCmigI3PfMdQ+lbZIfBMTKRRolFXfIBcpv/2FKyM8W7d X-Received: by 2002:a50:e70e:: with SMTP id a14mr618182edn.93.1597248836628; Wed, 12 Aug 2020 09:13:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597248836; cv=none; d=google.com; s=arc-20160816; b=IRDuaSU/yZLO85M+kqA+yp7Jsla1hRbBCq6axu7mmxH2C5DU2U+erm6E/wydCyu/VW 5z8TZFIuBh2MPWdqdHu+eq7gFm4ajWWGvIgA2JCDyNt1TcIXm0TxzyQyXHeHD6gJc5L3 CAFERM897JbASQpazrzxQrEJ2ig0PGCaJizwGLK52PUvEC6r4gYPqbq+NagJQxR6gR+m zmoaDyPweQPzmCErNQx8R2nzWPAt1SEmkA+KxYKkMcEopw/MTsHe/+WuIMt1FauD7+x/ sq/wsYDvnXzRTV3q03VbpI390SwXd4EfCpdBZlswoFASPXsvdzBbnTZPVfmPO9syUd63 3Yrg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=PjT/JF8m1m+YZ0EjSihaQ0RrTHM0ACFZ4T8ItHQNbfk=; b=WQzu0/BmFsYiFpGNo++MGXBiZ8gMDILv5ff62gcatMIYTkqKIgs0Q74v+kRNn1fjb3 KNx/+enRtx81NoT1kG+5ekWvNAvrahpwGqdwvShuTE88QrgKlbeDYSz69MOsvGOrR6ZU EEKa4+o6K/UtXfnDU5lplCOvhIjy3BxU9zLR9wVi4bWDecIEOZRtxG1o8oVksCd6+vRI +3TFsMOkcBS1yMY9JjMQY0TfzVV2vgyb+nSYNtiFxzxBXYFXbRCUsLbjWdaO5RF/JpxH aMbpuvSouYB5klaz/tA8ks8OGkscvdoI/NDuFphk7OoNX7mmtDjSQzvvIwvEY8mg1pl0 WH/w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=XJ9fmbfc; 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=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 38si1701660edq.297.2020.08.12.09.13.32; Wed, 12 Aug 2020 09:13:56 -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; dkim=pass header.i=@linaro.org header.s=google header.b=XJ9fmbfc; 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=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726547AbgHLQMz (ORCPT + 99 others); Wed, 12 Aug 2020 12:12:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34234 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726394AbgHLQMy (ORCPT ); Wed, 12 Aug 2020 12:12:54 -0400 Received: from mail-io1-xd42.google.com (mail-io1-xd42.google.com [IPv6:2607:f8b0:4864:20::d42]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4B52AC061383 for ; Wed, 12 Aug 2020 09:12:54 -0700 (PDT) Received: by mail-io1-xd42.google.com with SMTP id s189so3385625iod.2 for ; Wed, 12 Aug 2020 09:12:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=PjT/JF8m1m+YZ0EjSihaQ0RrTHM0ACFZ4T8ItHQNbfk=; b=XJ9fmbfcHiklhGFEDi/ajiFMlHJiPG60B1g/qd4B/aeTuAHmADdORHW+8hCo1ikS40 xbh7ofzEE697gvnH2uyIknNLwj7ZlUnA19uBkT99Gp31ADr/LY/h/gdZH2DqDTmNu39D QKdNxLZVtTAUO7Zb5PxrhZNLjNpkGwbBlFxe5D10WoeJosooXNE0u3yLH4mq7DQbJwE/ OPjoIoWKn1iNQbFEAVTYU+uo6lLcDc7iz/g1KqvD4ugpMqS1bajyQ+SbYD7uQYPkMNjm NtcIP94QKZVteeHwNGQXcSC1UlYRNlDVarprfV+xWrpBU9zpqFBIjwlSGJfjzvUQbxre HdcQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=PjT/JF8m1m+YZ0EjSihaQ0RrTHM0ACFZ4T8ItHQNbfk=; b=FGm63fiH/Z4OnkZzmzRLm7ArLBJcu+V9JGaI0OOcsWvMgVRuGCImIjEutE/4ZYRCsN 80m77nLD4mov38lOq7HWi4tIjRKEY8hhMAr9xNCqCp4f+35DuvxvuBcciipj0YkmKXKf uh6znMOgNvS3Z2HYbm7Dl8pgRSaTDcLl+8PsvhHMsy6rg1lD7RQiwwAJDNowJIDZw6zM OEVFEeV6VNPFn0m40eNcqSiJ08otO71r+9QtWNNvAc+AveLWQVj2/8xd/ZeCAymIRGFt byZxOUj2Ok9w8pI+944a1nghLIHcKkwRLsP0uNYjmmJyt8rVCmpY+8sN1NyyyVtFJBlX o4Fw== X-Gm-Message-State: AOAM533rRBh03XIrn0n0iciJIYhVAwfL/CZsmpqj4FNOllNopekzGVlB jOutsNgagAPnzULSlcrMbmfoTQvRG5YhzyxfRzeW0Q== X-Received: by 2002:a05:6602:2503:: with SMTP id i3mr486264ioe.165.1597248773520; Wed, 12 Aug 2020 09:12:53 -0700 (PDT) MIME-Version: 1.0 References: <20200806070213.7386-1-leo.yan@linaro.org> In-Reply-To: <20200806070213.7386-1-leo.yan@linaro.org> From: Mathieu Poirier Date: Wed, 12 Aug 2020 10:12:42 -0600 Message-ID: Subject: Re: [PATCH v4] perf test: Introduce script for Arm CoreSight testing To: Leo Yan Cc: Arnaldo Carvalho de Melo , Mike Leach , Suzuki Kuruppassery Poulose , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Leo and Arnaldo, On Thu, 6 Aug 2020 at 01:02, Leo Yan wrote: > > We need a simple method to test Perf with Arm CoreSight drivers, this > could be used for smoke testing when new patch is coming for perf or > CoreSight drivers, and we also can use the test to confirm if the > CoreSight has been enabled successfully on new platforms. > I have a lot of patches to review - getting to this one will take a while. Thanks for the patience, Mathieu > This patch introduces the shell script test_arm_coresight.sh which is > under the 'pert test' framework. This script provides three testing > scenarios: > > Test scenario 1: traverse all possible paths between source and sink > > For traversing possible paths, simply to say, the testing rationale > is source oriented testing, it traverses every source (now only refers > to ETM device) and test its all possible sinks. To search the complete > paths from one specific source to its sinks, this patch relies on the > sysfs '/sys/bus/coresight/devices/devX/out:Y' for depth-first search > (DFS) for iteration connected device nodes, if the output device is > detected as one of ETR, ETF, or ETB types then it will test trace data > recording and decoding for this PMU device. > > The script runs three output testings for every trace data: > - Test branch samples dumping with 'perf script' command; > - Test branch samples reporting with 'perf report' command; > - Use option '--itrace=i1000i' to insert synthesized instructions events > and the script will check if perf can output the percentage value > successfully based on the instruction samples. > > Test scenario 2: CPU wide mode test > > For CPU wide mode testing, it passes option '-a' to perf tool to enable > tracing on all CPUs, so it's hard to say which program will be traced. > But perf tool itself contributes much overload in this case, so it will > parse trace data and check if process 'perf' can be detected or not. > > Test scenario 3: snapshot mode test. > > For snapshot mode testing, it uses 'dd' command to launch a long running > program, so this can give chance to send signal -USR2; it will check the > captured trace data contains 'dd' related thread info or not. > > If any test fails, it will report failure and directly exit with error. > This test will be only applied on a platform with PMU event 'cs_etm//', > otherwise will skip the testing. > > Below is detailed usage for it: > > # cd $linux/tools/perf -> This is important so can use shell script > # perf test list > [...] > 65: probe libc's inet_pton & backtrace it with ping > 66: Check Arm CoreSight trace data recording and branch samples > 67: Check open filename arg using perf trace + vfs_getname > 68: Zstd perf.data compression/decompression > 69: Add vfs_getname probe to get syscall args filenames > 70: Use vfs_getname probe to get syscall args filenames > > # perf test 66 > 66: Check Arm CoreSight trace data recording and branch samples: Ok > > Signed-off-by: Leo Yan > --- > tools/perf/tests/shell/test_arm_coresight.sh | 172 +++++++++++++++++++ > 1 file changed, 172 insertions(+) > create mode 100755 tools/perf/tests/shell/test_arm_coresight.sh > > diff --git a/tools/perf/tests/shell/test_arm_coresight.sh b/tools/perf/tests/shell/test_arm_coresight.sh > new file mode 100755 > index 000000000000..73b973bada26 > --- /dev/null > +++ b/tools/perf/tests/shell/test_arm_coresight.sh > @@ -0,0 +1,172 @@ > +#!/bin/sh > +# Check Arm CoreSight trace data recording and branch samples > + > +# Uses the 'perf record' to record trace data with Arm CoreSight sinks; > +# then verify if there have any branch samples and instruction samples > +# are generated by CoreSight with 'perf script' and 'perf report' > +# commands. > + > +# SPDX-License-Identifier: GPL-2.0 > +# Leo Yan , 2020 > + > +perfdata=$(mktemp /tmp/__perf_test.perf.data.XXXXX) > +file=$(mktemp /tmp/temporary_file.XXXXX) > + > +skip_if_no_cs_etm_event() { > + perf list | grep -q 'cs_etm//' && return 0 > + > + # cs_etm event doesn't exist > + return 2 > +} > + > +skip_if_no_cs_etm_event || exit 2 > + > +record_touch_file() { > + echo "Recording trace (only user mode) with path: CPU$2 => $1" > + perf record -o ${perfdata} -e cs_etm/@$1/u --per-thread \ > + -- taskset -c $2 touch $file > +} > + > +perf_script_branch_samples() { > + echo "Looking at perf.data file for dumping branch samples:" > + > + # Below is an example of the branch samples dumping: > + # touch 6512 1 branches:u: ffffb220824c strcmp+0xc (/lib/aarch64-linux-gnu/ld-2.27.so) > + # touch 6512 1 branches:u: ffffb22082e0 strcmp+0xa0 (/lib/aarch64-linux-gnu/ld-2.27.so) > + # touch 6512 1 branches:u: ffffb2208320 strcmp+0xe0 (/lib/aarch64-linux-gnu/ld-2.27.so) > + perf script -F,-time -i ${perfdata} | \ > + egrep " +$1 +[0-9]+ .* +branches:([u|k]:)? +" > +} > + > +perf_report_branch_samples() { > + echo "Looking at perf.data file for reporting branch samples:" > + > + # Below is an example of the branch samples reporting: > + # 73.04% 73.04% touch libc-2.27.so [.] _dl_addr > + # 7.71% 7.71% touch libc-2.27.so [.] getenv > + # 2.59% 2.59% touch ld-2.27.so [.] strcmp > + perf report --stdio -i ${perfdata} | \ > + egrep " +[0-9]+\.[0-9]+% +[0-9]+\.[0-9]+% +$1 " > +} > + > +perf_report_instruction_samples() { > + echo "Looking at perf.data file for instruction samples:" > + > + # Below is an example of the instruction samples reporting: > + # 68.12% touch libc-2.27.so [.] _dl_addr > + # 5.80% touch libc-2.27.so [.] getenv > + # 4.35% touch ld-2.27.so [.] _dl_fixup > + perf report --itrace=i1000i --stdio -i ${perfdata} | \ > + egrep " +[0-9]+\.[0-9]+% +$1" > +} > + > +arm_cs_iterate_devices() { > + for dev in $1/connections/out\:*; do > + > + # Skip testing if it's not a directory > + ! [ -d $dev ] && continue; > + > + # Read out its symbol link file name > + path=`readlink -f $dev` > + > + # Extract device name from path, e.g. > + # path = '/sys/devices/platform/20010000.etf/tmc_etf0' > + # `> device_name = 'tmc_etf0' > + device_name=`echo $path | awk -F/ '{print $(NF)}'` > + > + echo $device_name | egrep -q "etr|etb|etf" > + > + # Only test if the output device is ETR/ETB/ETF > + if [ $? -eq 0 ]; then > + > + pmu_dev="/sys/bus/event_source/devices/cs_etm/sinks/$device_name" > + > + # Exit if PMU device node doesn't exist > + if ! [ -f $pmu_dev ]; then > + echo "PMU device $pmu_dev doesn't exist" > + exit 1 > + fi > + > + record_touch_file $device_name $2 && > + perf_script_branch_samples touch && > + perf_report_branch_samples touch && > + perf_report_instruction_samples touch > + > + err=$? > + > + # Exit when find failure > + [ $err != 0 ] && exit $err > + > + rm -f ${perfdata} > + rm -f ${file} > + fi > + > + arm_cs_iterate_devices $dev $2 > + done > +} > + > +arm_cs_etm_traverse_path_test() { > + # Iterate for every ETM device > + for dev in /sys/bus/coresight/devices/etm*; do > + > + # Find the ETM device belonging to which CPU > + cpu=`cat $dev/cpu` > + > + echo $dev > + echo $cpu > + > + # Use depth-first search (DFS) to iterate outputs > + arm_cs_iterate_devices $dev $cpu > + done > +} > + > +arm_cs_etm_cpu_wide_test() { > + echo "Recording trace with CPU wide mode" > + perf record -o ${perfdata} -e cs_etm// -a -- ls > + > + perf_script_branch_samples perf && > + perf_report_branch_samples perf && > + perf_report_instruction_samples perf > + > + err=$? > + > + # Exit when find failure > + [ $err != 0 ] && exit $err > + > + rm -f ${perfdata} > + rm -f ${file} > +} > + > +arm_cs_etm_snapshot_test() { > + echo "Recording trace with snapshot mode" > + perf record -o ${perfdata} -e cs_etm// -S --per-thread \ > + -- dd if=/dev/zero of=/dev/null & > + 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_branch_samples dd && > + perf_report_branch_samples dd && > + perf_report_instruction_samples dd > + > + err=$? > + > + # Exit when find failure > + [ $err != 0 ] && exit $err > + > + rm -f ${perfdata} > + rm -f ${file} > +} > + > +arm_cs_etm_traverse_path_test > +arm_cs_etm_cpu_wide_test > +arm_cs_etm_snapshot_test > +exit 0 > -- > 2.17.1 >