Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp4483123rwb; Tue, 20 Sep 2022 14:51:36 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4bZUDCfMHv6qttl/LG/+Vy78En/qycAjDp2t+XQ3Q9ToKoNrbvHh0qKIapRDGff1T6QTHe X-Received: by 2002:a17:902:c952:b0:176:bb2c:5459 with SMTP id i18-20020a170902c95200b00176bb2c5459mr1523449pla.165.1663710695756; Tue, 20 Sep 2022 14:51:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663710695; cv=none; d=google.com; s=arc-20160816; b=zy9Q6AaGEt/lFmVzEZO9DvIwaJKfBC1u+Div01yUFwvU01MzNw97O1mXiU2MduKpkL 8Emnnn4RdUI/fMrGk6nB1oQW7U44miuVb8YEzBtw4lJfIxvYvOG69tEHue466yWbmcSE w3VA85e2oVW79jPRxrgCRcUdD1fXSZzLnyy8AeJy7sGU5h4OotK+a7IYj2PfCX+xETBY LzrQ1yu558UXIz74kS3Zg9cvvBa+snggAq1r3dII/fAHIvpFFDBxJ9FSFtrLtI7uUx8p jfF8+p+XlmQ4u2mTNaEWmR4oZDCrKdpGkOYkWzCg8nieNwYR7HfvPjolDVfC2shwWk+O Ru5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version; bh=nNOJO5Rfau/4P4r51NLfOvsWPmiGi6ydKZx53FmD4Qg=; b=ii+VIvUskSaA+MEIfwN5dO5rNnRQgzYPzeyb5unknxinNDpIcR4GN0f1gKyKmq3hRw FEHICv4dw85AteXgai/kEXBSki5MyxJfxkmh1NJDiOXXo13d9wjnv47W44N4MWAQ6XVs Y8C5oCA2gadsI9iXrzBViEvTHyT3ty2DThCpDH3lI7aLyd/MIv7W6gQJlRck8GUV5mkn DdY32kx36zk+9Cc97qrlZXIsEO7iezAYVljktIOmhQHCwLA6YM8kEGEoYUTyEqpvlIhh o2GZiuVlI1Pcol9SQ3zdj004a3j8zW5C6rPkbhsMVBTr8NHuEu2d6N9P6KomZm2dtbAf G+qA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ck14-20020a056a00328e00b0053848a57f85si756946pfb.277.2022.09.20.14.51.23; Tue, 20 Sep 2022 14:51:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S230392AbiITVrV (ORCPT + 99 others); Tue, 20 Sep 2022 17:47:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44728 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230379AbiITVrT (ORCPT ); Tue, 20 Sep 2022 17:47:19 -0400 Received: from mail-oi1-f175.google.com (mail-oi1-f175.google.com [209.85.167.175]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 91C3361D50; Tue, 20 Sep 2022 14:47:18 -0700 (PDT) Received: by mail-oi1-f175.google.com with SMTP id t62so5523004oie.10; Tue, 20 Sep 2022 14:47:18 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date; bh=nNOJO5Rfau/4P4r51NLfOvsWPmiGi6ydKZx53FmD4Qg=; b=Rh3m7qcSZw6oAUS+pp9BvgQma6bYAIHAwizVeVSkac6gOxHqTgmkosG5d5I7UWL/Us Z2JqzBAJxiB32AjsgOxFF+56PGM8kQiCwdWOlumaU/U+OUSNwVXLmwv21eolZWpji9ak NhiGran4nraUsMt8z7BcrKRYeqUa1DejiEK6rpleUwl1tpL8q9qbiTgwNmtCu9GjFVOZ K8oyCUhdjiLECaPZIiRj7r0UltgDbQWKtTJ5rJrSLx4BVMd2nvS3Kxc+dwwuW52cpFr3 u81prG7I7cVs7d/Gism2Uq3RxvXb15a7vFy8dNjZCfRDNvsJK4GbaagmyZG5BVRz1RSZ t1Ag== X-Gm-Message-State: ACrzQf0zXsGYgsQcQqVXMovzS6rwEM9OTGj4+qOhAZs1NPMwGHJl5cvG pto7lBQsyz10HS1Wjf/EnvSrl78dz3vMjjYD8bE= X-Received: by 2002:aca:d882:0:b0:34d:49bf:3587 with SMTP id p124-20020acad882000000b0034d49bf3587mr2506665oig.209.1663710436869; Tue, 20 Sep 2022 14:47:16 -0700 (PDT) MIME-Version: 1.0 References: <20220918031524.26719-1-leo.yan@linaro.org> <20220918031524.26719-3-leo.yan@linaro.org> In-Reply-To: <20220918031524.26719-3-leo.yan@linaro.org> From: Namhyung Kim Date: Tue, 20 Sep 2022 14:47:05 -0700 Message-ID: Subject: Re: [PATCH v2 2/2] perf test: Introduce script for java symbol testing To: Leo Yan Cc: Arnaldo Carvalho de Melo , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , linux-kernel , linux-perf-users , Ian Rogers Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-1.4 required=5.0 tests=BAYES_00, FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Leo, On Sat, Sep 17, 2022 at 8:15 PM Leo Yan wrote: > > This commit introduces a script for testing java symbols. > > The test records java program, inject samples with JIT samples, check > specific JIT symbols in the report, the test will pass only when these > two symbols are detected. > > Suggested-by: Ian Rogers > Signed-off-by: Leo Yan > --- > tools/perf/tests/shell/test_java_symbol.sh | 69 ++++++++++++++++++++++ > 1 file changed, 69 insertions(+) > create mode 100755 tools/perf/tests/shell/test_java_symbol.sh > > diff --git a/tools/perf/tests/shell/test_java_symbol.sh b/tools/perf/tests/shell/test_java_symbol.sh > new file mode 100755 > index 000000000000..d96fea405ea9 > --- /dev/null > +++ b/tools/perf/tests/shell/test_java_symbol.sh > @@ -0,0 +1,69 @@ > +#!/bin/bash > +# Test java symbol > + > +# SPDX-License-Identifier: GPL-2.0 > +# Leo Yan , 2022 > + > +PERF_DATA=$(mktemp /tmp/__perf_test.perf.data.XXXXX) > +PERF_INJ_DATA=$(mktemp /tmp/__perf_test.perf.data.inj.XXXXX) > + > +cleanup_files() > +{ > + echo "Cleaning up files..." > + rm -f ${PERF_DATA} > + rm -f ${PERF_INJ_DATA} > +} > + > +trap cleanup_files exit term int > + > +if [ -e "$PWD/tools/perf/libperf-jvmti.so" ]; then > + LIBJVMTI=$PWD/tools/perf/libperf-jvmti.so > +elif [ -e "$PWD/libperf-jvmti.so" ]; then > + LIBJVMTI=$PWD/libperf-jvmti.so > +elif [ -e "$PREFIX/lib64/libperf-jvmti.so" ]; then > + LIBJVMTI=$PREFIX/lib64/libperf-jvmti.so > +elif [ -e "$PREFIX/lib/libperf-jvmti.so" ]; then > + LIBJVMTI=$PREFIX/lib/libperf-jvmti.so > +if [ -e "/usr/lib/linux-tools-$(uname -a | awk '{ print $3 }' | sed -r 's/-generic//')/libperf-jvmti.so" ]; then s/if/elif/ ? > + LIBJVMTI=/usr/lib/linux-tools-$(uname -a | awk '{ print $3 }' | sed -r 's/-generic//')/libperf-jvmti.so > +else > + echo "Fail to find libperf-jvmti.so" > + # JVMTI is a build option, skip the test if fail to find lib > + exit 2 > +fi > + > +cat < +int fib(int x) { > + return x > 1 ? fib(x - 2) + fib(x - 1) : 1; > +} > + > +int q = 0; > + > +for (int i = 0; i < 10; i++) > + q += fib(i); > + > +System.out.println(q); > +EOF > + > +if [ $? -ne 0 ]; then > + echo "Fail to record for java program" > + exit 1 > +fi > + > +if ! perf inject -i $PERF_DATA -o $PERF_INJ_DATA -j; then > + echo "Fail to inject samples" > + exit 1 > +fi > + > +# Below is an example of the instruction samples reporting: > +# 8.18% jshell jitted-50116-29.so [.] Interpreter > +# 0.75% Thread-1 jitted-83602-1670.so [.] jdk.internal.jimage.BasicImageReader.getString(int) > +perf report --stdio -i ${PERF_INJ_DATA} 2>&1 | \ > + egrep " +[0-9]+\.[0-9]+% .* (Interpreter|jdk\.internal).*" > /dev/null 2>&1 > + > +if [ $? -ne 0 ]; then > + echo "Fail to find java symbols" > + exit 1 > +fi > + > +exit 0 > -- > 2.34.1 >