Received: by 2002:a05:7412:bb8d:b0:d7:7d3a:4fe2 with SMTP id js13csp2083486rdb; Thu, 17 Aug 2023 10:11:33 -0700 (PDT) X-Google-Smtp-Source: AGHT+IE9Pvx/X5rY/gS1jZJROmkuPpRXyPm2R4EXQgudBHBz54WHKpWpldK+YMFHkGOqLf91zkq/ X-Received: by 2002:a05:6512:312a:b0:4fb:7cea:882a with SMTP id p10-20020a056512312a00b004fb7cea882amr4338787lfd.3.1692292293651; Thu, 17 Aug 2023 10:11:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692292293; cv=none; d=google.com; s=arc-20160816; b=mf7SoWHuTVtN912r2qQuolPcqxgyXQYaBKsv51KufH0Nrw0gqmJTOjjwGhOaEDAIQU RzXS84hyNCzKjH/K7GzJmMHqgRXq4OhTq5OVQlwlgaIJnZtjkF6h48dWaEOAlnVNb39c kDuspj5M0KEKIGd3o6zdvnJn7dSUU+tEmgQD4KQ95rmk9D2vPiMbf+1hoDlSW1RhjFpb CWJ7zhSXcAj8nv+bfOefi4EV33MZRe8eGeUAFk9Z1BsZ/uzFy7Gx5QtfJds7JPFjabaI 0X++RJ5ZMYtaIqn6QxqU5264T4mEw+pCmGRvy1QCUFLvYS+MwBLDUMVicMru69qI6/D8 llMw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=mZdydCidZXFJb9y9DR3Oz92wcs8I7ilo2/AI5V/H+40=; fh=T+ZxMumrCRoc4qrmzrm/kbvrpu4fQDs5IP1k9TFGUMY=; b=cW3a9dH29pYj5rjvkp5SorEQY8qfwJvTOlszCM0stSgAhcmMq46gLjkG5vkx73GCjA kxWow5iOf+BtvIEBcX5a2nnvlv35leA10hU3dgmlU/OAcjIDRiOBPHkqvjhjA7TAFRTF 47TTildI2QuJPc29ev+RJt4LeBQmSq5nTMNkpyyBpen1IXigPlZC3SBTwNMP/lgmouUV kRLcJWd82n9ZN6lV9CCC2+RyuiHuWemuxrAU0keRf8mfB6cGMOWvUHMaXkFGRV3kDsXJ 9PXMKHSzmuy+ktlWaqgTx1GBKnh97vE4ILEHYdyHdH4NuL5bu0XslPUOU1YONzj5FMg9 K2pQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=kIQ+3GZq; 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 d3-20020a1709063ec300b00997d315d050si13111184ejj.84.2023.08.17.10.10.56; Thu, 17 Aug 2023 10:11:33 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=kIQ+3GZq; 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 S244759AbjHPLs6 (ORCPT + 99 others); Wed, 16 Aug 2023 07:48:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37548 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244774AbjHPLsg (ORCPT ); Wed, 16 Aug 2023 07:48:36 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5B3B3E68; Wed, 16 Aug 2023 04:48:35 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id E7D9C666EE; Wed, 16 Aug 2023 11:48:34 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id E4427C433C8; Wed, 16 Aug 2023 11:48:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1692186514; bh=v2m2BK3GGd11X74j40insUcmDxokoIf6Czvuxm4GLe0=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=kIQ+3GZqZqX0YR2G3PxIKU4z7PLWBtwM1cFVVGQ7TYpvNN9lOIKya5TYcEllvV5/r +W8yXiXqVRP/pyu1E7I1vsZS3Jmp1oPKegOA3D++BcgVc2hV56aJ/5pykDa8EoW5RM pn1sIBsV+LvX31A82MRtST79dD+bQ4uCQ6zuHoF9bLeJWYVhMYnHiEsAM3ZE+A5xhP OlEOpJtaeMdzzlm7S5bBj8a/ri7rIyXml8SPM1N3iPUt7Pr4hNL9zEtmTp2QT6Jsj7 o/nDUGMASQ/yVc/jLwynWG2VYzo1rluHDyXfJ0BrGMmMW0oFDUNL9ETcMIMJlZfEuF sn8f0KkVIYj8A== Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id 00D32404DF; Wed, 16 Aug 2023 08:48:30 -0300 (-03) Date: Wed, 16 Aug 2023 08:48:30 -0300 From: Arnaldo Carvalho de Melo To: Leo Yan Cc: Ian Rogers , John Garry , Will Deacon , James Clark , Mike Leach , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Adrian Hunter , Guo Ren , Paul Walmsley , Palmer Dabbelt , Albert Ou , Huacai Chen , Ming Wang , Eric Lin , Kan Liang , Sandipan Das , Ivan Babrou , Fangrui Song , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-perf-users@vger.kernel.org, linux-csky@vger.kernel.org, linux-riscv@lists.infradead.org Subject: Re: [PATCH v2 0/6] perf parse-regs: Refactor architecture functions Message-ID: References: <20230606014559.21783-1-leo.yan@linaro.org> <20230816020715.GA135657@leoy-huanghe.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Url: http://acmel.wordpress.com X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED 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 Em Wed, Aug 16, 2023 at 08:46:23AM -0300, Arnaldo Carvalho de Melo escreveu: > Em Wed, Aug 16, 2023 at 10:07:15AM +0800, Leo Yan escreveu: > > On Tue, Aug 15, 2023 at 03:57:17PM -0300, Arnaldo Carvalho de Melo wrote: > > > Em Tue, Aug 15, 2023 at 03:52:38PM -0300, Arnaldo Carvalho de Melo escreveu: > > > > Em Tue, Aug 15, 2023 at 03:45:27PM -0300, Arnaldo Carvalho de Melo escreveu: > > > > > > Agreed, applied to perf-tools-next, sorry for the delay. > > > > > > > > > > Had to add this to make 'perf test python' to work. Please run 'perf > > > > > test' before sending patches. > > > > > > > > One more, please also do a 'make -C tools/perf build-test', with it I > > > > caught this: > > > > > > > > make_no_libunwind_O: cd . && make NO_LIBUNWIND=1 FEATURES_DUMP=/var/home/acme/git/perf-tools-next/tools/perf/BUILD_TEST_FEATURE_DUMP -j32 O=/tmp/tmp.yeEGyQq2HR DESTDIR=/tmp/tmp.ITgoO16jjH > > > > cd . && make NO_LIBUNWIND=1 FEATURES_DUMP=/var/home/acme/git/perf-tools-next/tools/perf/BUILD_TEST_FEATURE_DUMP -j32 O=/tmp/tmp.yeEGyQq2HR DESTDIR=/tmp/tmp.ITgoO16jjH > > > > > > +#include "util/env.h" > > > > > > As now we need it for perf_env__arch(ui->machine->env) > > > > Sorry for inconvenience. > > > > I saw this patch series has been picked into the branch: > > https://git.kernel.org/pub/scm/linux/kernel/git/acme/linux.git/log/?h=tmp.perf-tools-next > > > > If want me to follow up, let me know. Thank you! > > Right, I'll fix this ones: > > [perfbuilder@five ~]$ grep "unused variable" dm.log/*:* > dm.log/ubuntu:18.04-x-m68k:util/evsel.c:848:14: error: unused variable 'arch' [-Werror=unused-variable] > dm.log/ubuntu:18.04-x-riscv64:util/evsel.c:848:14: error: unused variable 'arch' [-Werror=unused-variable] > dm.log/ubuntu:18.04-x-sh4:util/evsel.c:848:14: error: unused variable 'arch' [-Werror=unused-variable] > dm.log/ubuntu:18.04-x-sparc64:util/evsel.c:848:14: error: unused variable 'arch' [-Werror=unused-variable] > [perfbuilder@five ~]$ > > And move that to perf-tools-next, we can go on from there. > > The above is because we don't define CONFIG_PERF_REGS for these > architectures and thus that variable ends up not being used, so I'm > fixing up like below, in the cset where you made DWARF_MINIMAL_REGS > receive the arch parameter. I added this to the cset commit message: Committer notes: Make DWARF_MINIMAL_REGS() an inline function, so that we can use the __maybe_unused attribute for the 'arch' parameter, as this will avoid a build failure when that variable is unused in the callers. That happens when building on unsupported architectures, the ones without HAVE_PERF_REGS_SUPPORT defined. > Also I haven't checked how gracefully we react when processing a > perf.data collected in one of those unsupported arches, can you please > check? > > - Arnaldo > > diff --git a/tools/perf/util/perf_regs.h b/tools/perf/util/perf_regs.h > index 790c1a26bbfe9b4b..de1673057e502de9 100644 > --- a/tools/perf/util/perf_regs.h > +++ b/tools/perf/util/perf_regs.h > @@ -32,9 +32,6 @@ extern const struct sample_reg sample_reg_masks[]; > > #include > > -#define DWARF_MINIMAL_REGS(arch) \ > - ((1ULL << perf_arch_reg_ip(arch)) | (1ULL << perf_arch_reg_sp(arch))) > - > const char *perf_reg_name(int id, const char *arch); > int perf_reg_value(u64 *valp, struct regs_dump *regs, int id); > uint64_t perf_arch_reg_ip(const char *arch); > @@ -67,11 +64,19 @@ const char *__perf_reg_name_x86(int id); > uint64_t __perf_reg_ip_x86(void); > uint64_t __perf_reg_sp_x86(void); > > +static inline uint64_t DWARF_MINIMAL_REGS(const char *arch) > +{ > + return (1ULL << perf_arch_reg_ip(arch)) | (1ULL << perf_arch_reg_sp(arch)); > +} > + > #else > #define PERF_REGS_MASK 0 > #define PERF_REGS_MAX 0 > > -#define DWARF_MINIMAL_REGS(arch) PERF_REGS_MASK > +static inline uint64_t DWARF_MINIMAL_REGS(const char *arch __maybe_unused) > +{ > + return PERF_REGS_MASK; > +} > > static inline const char *perf_reg_name(int id __maybe_unused, const char *arch __maybe_unused) > { > > > > > CC /tmp/tmp.yeEGyQq2HR/util/expr-flex.o > > > > util/unwind-libdw.c: In function ‘memory_read’: > > > > util/unwind-libdw.c:173:28: error: implicit declaration of function ‘perf_env__arch’ [-Werror=implicit-function-declaration] > > > > 173 | const char *arch = perf_env__arch(ui->machine->env); > > > > | ^~~~~~~~~~~~~~ > > > > util/unwind-libdw.c:173:28: error: initialization of ‘const char *’ from ‘int’ makes pointer from integer without a cast [-Werror=int-conversion] > > > > util/unwind-libdw.c: In function ‘unwind__get_entries’: > > > > util/unwind-libdw.c:258:28: error: initialization of ‘const char *’ from ‘int’ makes pointer from integer without a cast [-Werror=int-conversion] > > > > 258 | const char *arch = perf_env__arch(ui_buf.machine->env); > > > > | ^~~~~~~~~~~~~~ > > > > cc1: all warnings being treated as errors > > > > make[6]: *** [/var/home/acme/git/perf-tools-next/tools/build/Makefile.build:98: /tmp/tmp.yeEGyQq2HR/util/unwind-libdw.o] Error 1 > > > > make[6]: *** Waiting for unfinished jobs.... > > > > make[5]: *** [/var/home/acme/git/perf-tools-next/tools/build/Makefile.build:150: util] Error 2 > > > > make[4]: *** [Makefile.perf:662: /tmp/tmp.yeEGyQq2HR/perf-in.o] Error 2 > > > > make[4]: *** Waiting for unfinished jobs.... > > > > CC /tmp/tmp.yeEGyQq2HR/pmu-events/pmu-events.o > > > > LD /tmp/tmp.yeEGyQq2HR/pmu-events/pmu-events-in.o > > > > make[3]: *** [Makefile.perf:238: sub-make] Error 2 > > > > make[2]: *** [Makefile:70: all] Error 2 > > > > make[1]: *** [tests/make:337: make_no_libunwind_O] Error 1 > > > > make: *** [Makefile:103: build-test] Error 2 > > > > make: Leaving directory '/var/home/acme/git/perf-tools-next/tools/perf' > > > > > > > > real 1m29.784s > > > > user 10m41.597s > > > > sys 2m55.948s > > > > ⬢[acme@toolbox perf-tools-next]$ > > > > > > > > I'm trying to fix > > > > > > -- > > > > > > - Arnaldo > > -- > > - Arnaldo -- - Arnaldo