Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp688546ybj; Tue, 5 May 2020 06:15:49 -0700 (PDT) X-Google-Smtp-Source: APiQypJU4x/Fc2WyaSgFwagdfl4nb7MKPtHHrirfTbAqREPLAlMfdRwwN0xl9z2/7l04wzURv3p0 X-Received: by 2002:aa7:d2cd:: with SMTP id k13mr2637806edr.116.1588684549719; Tue, 05 May 2020 06:15:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588684549; cv=none; d=google.com; s=arc-20160816; b=rSiSWo8oQYNohjT03lN7251UMGsx0jZur8g1rAqcbmmm9mJSo1kFO6Cw1ZvwQHNvl/ L+ZLIRgVVqrBGC4clkdtwi7Cucpa9ZMosCIZqkDsCDWnxBN9y+xGsaS1hlH1zxKrRh62 DSe4voLC6fsv02U3xkJsO6KBQkGEOScog1+J6AHaFnsspPMe0fnKzLyATVxeUOHvfthZ YFVi4qIKCO7xUMMuPoqcXsgFMcM/2okev/KiwMUq7BssC0eptrA7yRhS9WTSdRiY2qCD 8Xzs0nQDddHci+epS44kHQaac5J3dxHTyIHygVGPtJrioohjP/wgxWWqBmXV5Xll6JHT LkXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:date:message-id:from :references:cc:to:subject; bh=SFVXm1Byu/JHVla7sdnSafRM7s3Fo/kksyvhblYK+FE=; b=gItvdBdNRHJgTIJN8ilJq62K/M7H0WFaKzcfS/NXjPyqmWBqPf5MKmy7UQwFJh3+pB Y5q9PNxH3JFAhTYurFQGEzBTT/FqktsmIoH/n6mtd1uqVzFCccYsj1+49T4Ucs7ta+tf PzcbqHqg9Uj7FB0cOpLgfSIgZHpI225OgrMv+mP/EALPch3jKLqNvWlSw2OxrjD1kvrd zftDkSyMtAhLOzNzoNm/ASlL4i3q+a2J1uDPnUunJ7Co5IdIPPA0el3RhNwxuct9gbAz HyNZV5Vccmuut7Ran6GUEhVXtBIui2Iu1m6Ske4TGRj09lRZT0Zcq40kfymCbgd4q5/2 EFBg== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k16si1086488ejr.429.2020.05.05.06.15.19; Tue, 05 May 2020 06:15:49 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729038AbgEENLT (ORCPT + 99 others); Tue, 5 May 2020 09:11:19 -0400 Received: from mx1.yrkesakademin.fi ([85.134.45.194]:30294 "EHLO mx1.yrkesakademin.fi" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728512AbgEENLT (ORCPT ); Tue, 5 May 2020 09:11:19 -0400 Subject: Re: perf build error with gcc 10 on arm and aarch64 To: Leo Yan CC: , Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mathieu Poirier , Mike Leach , Suzuki Kuruppassery Poulose References: <2869c4f6-9adf-3d55-a41d-a42865ae56f2@mageia.org> <20200505041050.GA8131@leoy-ThinkPad-X240s> From: Thomas Backlund Message-ID: Date: Tue, 5 May 2020 16:11:14 +0300 MIME-Version: 1.0 In-Reply-To: <20200505041050.GA8131@leoy-ThinkPad-X240s> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Den 05-05-2020 kl. 07:10, skrev Leo Yan: > > Hi Thomas, > > [ + Mathieu/Mike/Suzuki ] > > On Mon, May 04, 2020 at 10:22:27PM +0300, Thomas Backlund wrote: >> This is building perf from kernel-5.6.10 on armv7hl and aarch64: >> >> Compiler is gcc 10.1.0-RC >> >> >> LD perf-in.o >> ld: arch/perf-in.o: in function `.LANCHOR0': >> /home/iurt/rpmbuild/BUILD/kernel-arm/linux-5.6/tools/perf/util/include/../../util/cs-etm.h:118: >> multiple definition of `traceid_list'; util/perf-in.o:/home/iurt/rpmbuild/BUILD/kernel-arm/linux-5.6/tools/perf/util/cs-etm.h:118: >> first defined here >> make[3]: *** [/home/iurt/rpmbuild/BUILD/kernel-arm/linux-5.6/tools/build/Makefile.build:145: >> perf-in.o] Error 1 >> >> LD perf-in.o >> ld: arch/perf-in.o:/home/iurt/rpmbuild/BUILD/kernel-aarch64/linux-5.6/tools/perf/util/include/../../util/cs-etm.h:118: >> multiple definition of `traceid_list'; util/perf-in.o:/home/iurt/rpmbuild/BUILD/kernel-aarch64/linux-5.6/tools/perf/util/cs-etm.h:118: >> first defined here >> make[3]: *** [/home/iurt/rpmbuild/BUILD/kernel-aarch64/linux-5.6/tools/build/Makefile.build:145: >> perf-in.o] Error 1 >> make[2]: *** [Makefile.perf:616: perf-in.o] Error 2 >> make[1]: *** [Makefile.perf:225: sub-make] Error 2 >> make: *** [Makefile:70: all] Error 2 >> >> >> The same build succeeds with gcc 9.3.0 > > Thanks for reporting the issue. > > Could you help confirm if below change can resolve this issue? Yes, fix confirmed on i586, x86_64, armv7hl and aarch64 builds so I guess you can add: Reported-by: Thomas Backlund Tested-by: Thomas Backlund > > Thanks, > Leo > > ---8<--- > > Subject: [PATCH] perf cs-etm: Move defined of traceid_list > > The variable 'traceid_list' is defined in the header file cs-etm.h, > if multiple C files include cs-etm.h the compiler might complaint for > multiple definition of 'traceid_list'. > > To fix multiple definition error, move the definition of 'traceid_list' > into cs-etm.c. > > Signed-off-by: Leo Yan > --- > tools/perf/util/cs-etm.c | 3 +++ > tools/perf/util/cs-etm.h | 3 --- > 2 files changed, 3 insertions(+), 3 deletions(-) > > diff --git a/tools/perf/util/cs-etm.c b/tools/perf/util/cs-etm.c > index 62d2f9b9ce1b..381d9708e9bd 100644 > --- a/tools/perf/util/cs-etm.c > +++ b/tools/perf/util/cs-etm.c > @@ -94,6 +94,9 @@ struct cs_etm_queue { > struct cs_etm_traceid_queue **traceid_queues; > }; > > +/* RB tree for quick conversion between traceID and metadata pointers */ > +static struct intlist *traceid_list; > + > static int cs_etm__update_queues(struct cs_etm_auxtrace *etm); > static int cs_etm__process_queues(struct cs_etm_auxtrace *etm); > static int cs_etm__process_timeless_queues(struct cs_etm_auxtrace *etm, > diff --git a/tools/perf/util/cs-etm.h b/tools/perf/util/cs-etm.h > index 650ecc2a6349..4ad925d6d799 100644 > --- a/tools/perf/util/cs-etm.h > +++ b/tools/perf/util/cs-etm.h > @@ -114,9 +114,6 @@ enum cs_etm_isa { > CS_ETM_ISA_T32, > }; > > -/* RB tree for quick conversion between traceID and metadata pointers */ > -struct intlist *traceid_list; > - > struct cs_etm_queue; > > struct cs_etm_packet { > -- > 2.17.1 >