Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp1614608iog; Tue, 14 Jun 2022 09:25:30 -0700 (PDT) X-Google-Smtp-Source: AGRyM1t72MCfHCzXVPolb3sFy5RzPs7NDQRsj+E4ZOqCdEk4fRWgAqUP3gKCgEBRdTuOsDRA+28p X-Received: by 2002:a17:902:d584:b0:167:6ab9:b094 with SMTP id k4-20020a170902d58400b001676ab9b094mr5362830plh.16.1655223930344; Tue, 14 Jun 2022 09:25:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655223930; cv=none; d=google.com; s=arc-20160816; b=FqOQrPgB1fL2oYip7m3ORXWO8s8YiWumeXLLKp4tWecPsKdXoDCPUat3zjmXCR/UnV vp5+R3yVC0IqJDKXloFuIagDkJfvlCgd6uHv1yN9SK8xN4d4BBQN6uAri7l95+QXOKho Of6mc9nmSKPC0HZxSjc0pydNDLFZrGKMf98m6M545gSGqKXtOHIZ0FwuRuH3OZ1l+wWh tyrZ41YW3ZcHYEqepEhbjmf87QZtclADcEQjcRXd/Ygm6IvCKGEntov12AQ05pokGlYT btlE8y1B0ZKdL9uZbyApJbmS0XVA1C8tyTE7telgcq6Izwrtmy0lEVKvCOplzmTUiHRe 0HhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:subject:user-agent:mime-version:date:message-id; bh=N5OP1uiN+i43NPrDXJNEvmOs0Jti1Ei9WGOeykMzI8Y=; b=s0ciLqGjhVPgjnT/9Pp3JCfxGeYyWFxeO3cLcIMbXuOMKUKhN2ibL0EIWumrMsAaZY +mz65nc8XWXmGAr95CW0+ED60fSVu4ckyhtFVB6yK+lrmB8TGEkRz5fp1rqiwycSacPI rdFvzKxa8u3GmgrMk96T7jqTrQkEa++k8RUGTQIGCIQn9/SBOFXkywYelmr4gUKLEnvt 15K5kLNAlJlFduveizZtu00QlwGZq6im3lIPRpw0QmvRn/2iBl/RgTnSAwZ9fSqyMcWu xdbiwejT0UJkDNJEcdpkalOGWiueCu31PTYOQeG8qWcq99R67+qAS/WU0bG0pbIxleoS lgiQ== 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y20-20020a056a00181400b0050d8195100bsi14166132pfa.7.2022.06.14.09.25.17; Tue, 14 Jun 2022 09:25:30 -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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344527AbiFNPuF (ORCPT + 99 others); Tue, 14 Jun 2022 11:50:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60122 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344068AbiFNPt5 (ORCPT ); Tue, 14 Jun 2022 11:49:57 -0400 Received: from frasgout.his.huawei.com (frasgout.his.huawei.com [185.176.79.56]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9AC86369C3; Tue, 14 Jun 2022 08:49:55 -0700 (PDT) Received: from fraeml712-chm.china.huawei.com (unknown [172.18.147.226]) by frasgout.his.huawei.com (SkyGuard) with ESMTP id 4LMtDF2Cvtz68Bfb; Tue, 14 Jun 2022 23:49:49 +0800 (CST) Received: from lhreml724-chm.china.huawei.com (10.201.108.75) by fraeml712-chm.china.huawei.com (10.206.15.61) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Tue, 14 Jun 2022 17:49:52 +0200 Received: from [10.195.33.253] (10.195.33.253) by lhreml724-chm.china.huawei.com (10.201.108.75) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Tue, 14 Jun 2022 16:49:51 +0100 Message-ID: Date: Tue, 14 Jun 2022 16:52:58 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.6.1 Subject: Re: [PATCH v3 0/3] Rewrite jevents program in python To: Ian Rogers CC: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , "Namhyung Kim" , Kan Liang , Andi Kleen , Zhengjun Xing , "Felix Fietkau" , Qi Liu , Like Xu , , , Nick Forrington , Kajol Jain , James Clark , Andrew Kilroy , "Paul A . Clarke" , Will Deacon , Mathieu Poirier , , , , , Caleb Biggers , Perry Taylor , Kshipra Bopardikar , Stephane Eranian References: <20220527185426.240235-1-irogers@google.com> From: John Garry In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.195.33.253] X-ClientProxiedBy: lhreml746-chm.china.huawei.com (10.201.108.196) To lhreml724-chm.china.huawei.com (10.201.108.75) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-3.8 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_LOW,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham 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 On 01/06/2022 23:43, Ian Rogers wrote: > On Wed, Jun 1, 2022 at 9:17 AM John Garry wrote: >> On 27/05/2022 19:54, Ian Rogers wrote: >>> New architectures bring new complexity, such as Intel's hybrid >>> models. jevents provides an alternative to specifying events in the >>> kernel and exposing them through sysfs, however, it is difficult to >>> work with. For example, an error in the json input would yield an >>> error message but no json file or location. It is also a challenge to >>> update jsmn.c given its forked nature. >>> >>> The changes here switch from jevents.c to a rewrite in python called >>> jevents.py. This means there is a build time dependency on python, but >>> such a dependency already exists for asciidoc (used to generate perf's >>> man pages). If the build detects that python isn't present or is older >>> than version 3.6 (released Dec. 2016) then an empty file is >>> substituted for the generated one. >>> >>> A challenge with this code is in avoiding regressions. For this reason >>> the jevents.py produces identical output to jevents.c, validated with a >>> test script and build target. >>> >> Hi Ian, >> >> I still see this: >> >> ... >> Makefile.config:906: Python interpreter too old (older than 3.6) >> disabling jevent generation >> Makefile.config:939: Old version of libbfd/binutils things like PE >> executable profiling will not be available >> Makefile.config:1127: No openjdk development package found, please >> install JDK package, e.g. openjdk-8-jdk, java-1.8.0-openjdk-devel >> >> Auto-detecting system features: >> ... dwarf: [ on ] >> ... dwarf_getlocations: [ on ] >> ... glibc: [ on ] >> ... libbfd: [ OFF ] >> ... libbfd-buildid: [ OFF ] >> ... libcap: [ on ] >> ... libelf: [ on ] >> ... libnuma: [ on ] >> ... numa_num_possible_cpus: [ on ] >> ... libperl: [ on ] >> ... libpython: [ on ] >> ... libcrypto: [ on ] >> ... libunwind: [ on ] >> ... libdw-dwarf-unwind: [ on ] >> ... zlib: [ on ] >> ... lzma: [ on ] >> ... get_cpuid: [ on ] >> ... bpf: [ on ] >> ... libaio: [ on ] >> ... libzstd: [ on ] >> ... disassembler-four-args: [ on ] >> >> >> make[3]: Nothing to be done for 'install_headers'. >> john@localhost:~/acme/tools/perf> python --version >> Python 3.6.12 >> >> I need to figure out what is going wrong... > Thanks for testing John! Could you try adding something like this: > ``` > diff --git a/tools/perf/Makefile.config b/tools/perf/Makefile.config > index 9538d737d655..c23f39e21a70 100644 > --- a/tools/perf/Makefile.config > +++ b/tools/perf/Makefile.config > @@ -901,6 +901,8 @@ ifneq ($(NO_JEVENTS),1) > NO_JEVENTS := 1 > else > # jevents.py uses f-strings present in Python 3.6 released in Dec. 2016. > + PYTHON_VERSION=$(shell $(PYTHON) -c 'import sys;print(sys.version_info)') > + $(error $(PYTHON_VERSION)) > JEVENTS_PYTHON_GOOD := $(shell $(PYTHON) -c 'import sys;print("1" > if(sys.version_info.major >= > 3 and sys.version_info.minor >= 6) else "0")') > ifneq ($(JEVENTS_PYTHON_GOOD), 1) > $(warning Python interpreter too old (older than 3.6) disabling > jevent generation) > ``` That gives: Makefile.config:459: No libdw DWARF unwind found, Please install elfutils-devel/libdw-dev >= 0.158 and/or set LIBDW_DIR Makefile.config:464: No libdw.h found or old libdw.h found or elfutils is older than 0.138, disables dwarf support. Please install new elfutils-devel/libdw-dev Makefile.config:617: DWARF support is off, BPF prologue is disabled Makefile.config:667: No debug_frame support found in libunwind-aarch64 Makefile.config:738: No debug_frame support found in libunwind Makefile.config:906: *** sys.version_info(major=2, minor=7, micro=13, releaselevel='final', serial=0).Stop. Makefile.perf:239: recipe for target 'sub-make' failed make[1]: *** [sub-make] Error 2 Makefile:69: recipe for target 'all' failed make: *** [all] Error 2 john@debian:~/linux/tools/perf$ python --version Python 3.6.9 john@debian:~/linux/tools/perf$ > You can also specify which python you want on the make command line, > for example adding PYTHON=`which python` at the end of your make > command. diff -u tools/perf/trace/beauty/include/linux/socket.h include/linux/socket.h Makefile.config:259: *** which python-config not found. Stop. Makefile.perf:239: recipe for target 'sub-make' failed make[1]: *** [sub-make] Error 2 Makefile:69: recipe for target 'all' failed make: *** [all] Error 2 john@debian:~/linux/tools/perf$ JFYI, this is my alternatives: sudo update-alternatives --config python There are 3 choices for the alternative python (providing /usr/bin/python). Selection Path Priority Status ------------------------------------------------------------ 0 /usr/local/bin/python3.6 50 auto mode 1 /usr/bin/python2.7 1 manual mode 2 /usr/bin/python3.5 2 manual mode * 3 /usr/local/bin/python3.6 50 manual mode Press to keep the current choice[*], or type selection number: Can someone else try this? Arnaldo? Sorry for being useless with this....