Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp7143574ybi; Thu, 13 Jun 2019 10:17:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqzmbstWnx/UodCg6vOGPpjt8GTm/ft5mfm07Kw8mrVWIHFe56f3oeR0cBYjFvqOt4jRvvmu X-Received: by 2002:a17:90a:9291:: with SMTP id n17mr6554772pjo.66.1560446222382; Thu, 13 Jun 2019 10:17:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560446222; cv=none; d=google.com; s=arc-20160816; b=M5py7ZoaM17Kr6HAeBZRH2dQrARhhMaXrvfHNjfdeAbsZi9rGhcJkHx+TfrH1kvVMR sjQyUhSbabbQIy+ZFb9d3zuY1Ynrc8M0FEmrqFrlGGHF7XttGk3i4IvJLiWsEM1/YFmU lLKdzIZG316pe0+iy3jHzGReRCDgN2LF9cClUZFZ/mF9uZX8PaPeZomhowGfkfNYxccE ulzCnbc9QxiSAqnugCtp/W3DqweA9Jv0M8smz1kQwH35LIB8HS/7naTYwN2xTq1tEuoz fWSgArQm/gydcPdJwPgWkfhXAYcvYK0dRUkgmsc32bB1PEpJsxoDUmNqFryWBGTXS7XC XXoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=Y6XeTvsL52Q0VCT6wBrBxtjgLZo/xCw2+bBaGQm+Lgg=; b=iXqHiujKcp0qBv6UVd1qmsPt11YYf8Qz8nlKj5qCDoGSUJQXLZBBtiUlJY4zz1WhBS 3BAg7xNwc5tXkPGCjJsO08cyB4ehdyFahXp2jWGkpNSpmUeNL7Rm0aWYFEJx2cauJgwf RZ4Lg7VjFbbPiaa9FffCGx4sGVkJ05Hf2HUfey4Vvkwh83g0luEH2OVGPlEkFgaZBG4V b6sVhpYqktiQl7y3JB5bD3FiHI3DE+HcP3NyCeKwN4P04y2qxFcbi/4/lbbAYi0d+Lxc vVwoAGS3jZ3w7fqndu3pIZnGAO4+iKwFdB20/DzPWQL9gohQi9ARgNDMFrTxckOoji3F TUXA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 70si159094pla.2.2019.06.13.10.16.47; Thu, 13 Jun 2019 10:17:02 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728216AbfFMRQe (ORCPT + 99 others); Thu, 13 Jun 2019 13:16:34 -0400 Received: from mx1.redhat.com ([209.132.183.28]:46146 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726244AbfFLV32 (ORCPT ); Wed, 12 Jun 2019 17:29:28 -0400 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 803E42F8BC8; Wed, 12 Jun 2019 21:29:28 +0000 (UTC) Received: from krava (ovpn-204-42.brq.redhat.com [10.40.204.42]) by smtp.corp.redhat.com (Postfix) with ESMTP id D907A600CC; Wed, 12 Jun 2019 21:29:26 +0000 (UTC) Date: Wed, 12 Jun 2019 23:29:25 +0200 From: Jiri Olsa To: Arnaldo Carvalho de Melo Cc: Laura Abbott , Jiri Olsa , Stephane Eranian , Florian Weimer , Linux Kernel Mailing List Subject: Re: perf build failure with newer glibc headers Message-ID: <20190612212925.GB14171@krava> References: <4c0a4264-7142-2e6d-540d-aa354700e0bb@redhat.com> <20190612205611.GA2149@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20190612205611.GA2149@redhat.com> User-Agent: Mutt/1.11.4 (2019-03-13) X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.38]); Wed, 12 Jun 2019 21:29:28 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jun 12, 2019 at 05:56:11PM -0300, Arnaldo Carvalho de Melo wrote: > Em Wed, Jun 12, 2019 at 03:23:12PM -0400, Laura Abbott escreveu: > > Hi, > > > > While doing some build experiments, I found a compile failure with perf and jvmti: > > > > BUILDSTDERR: gcc -Wp,-MD,./.xsk.o.d -Wp,-MT,xsk.o -O2 -g -pipe -Wall -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS -fexceptions -fstack-protector-strong -grecord-gcc-jvmti/jvmti_agent.c:48:21: error: static declaration of 'gettid' follows non-static declaration > > BUILDSTDERR: 48 | static inline pid_t gettid(void) > > BUILDSTDERR: | ^~~~~~ > > BUILDSTDERR: In file included from /usr/include/unistd.h:1170, > > BUILDSTDERR: from jvmti/jvmti_agent.c:33: > > BUILDSTDERR: /usr/include/bits/unistd_ext.h:40:16: note: previous declaration of 'gettid' was here > > BUILDSTDERR: 40 | extern __pid_t gettid (void) __THROW; > > BUILDSTDERR: | ^~~~~~ > > > > > > This is with the newer glibc headers that came into Fedora earlier this week > > (glibc-2.29.9000-27.fc31) It looks like the newer headers now define gettid > > so the in file gettid no longer works. Note this was a custom build with > > jvmti enabled as regular Fedora doesn't have it enabled which is why this > > wasn't reported elsewhere. > > > > I don't know enough about either the glibc headers or perf to make a suggestion > > on how to fix this but I'm happy to test. > > Bummer, I haven't noticed this because my fedora:rawhide perf build test > container wasn't building the jvmti code: > > Makefile.config:925: No openjdk development package found, please install JDK package, e.g. openjdk-8-jdk, java-1.8.0-openjdk-devel > > i.e.: > > [perfbuilder@c0326e8b6511 perf]$ cat /tmp/build/perf/feature/test-jvmti.make.output > test-jvmti.c:2:10: fatal error: jvmti.h: No such file or directory > 2 | #include > | ^~~~~~~~~ > compilation terminated. > [perfbuilder@c0326e8b6511 perf]$ > > Installing it I get: > > [root@2d7fe307ad20 perf]# rpm -qa | grep openjdk > java-1.8.0-openjdk-1.8.0.212.b04-4.fc31.x86_64 > java-1.8.0-openjdk-headless-1.8.0.212.b04-4.fc31.x86_64 > java-1.8.0-openjdk-devel-1.8.0.212.b04-4.fc31.x86_64 > [root@2d7fe307ad20 perf]# cat > /tmp/build/perf/feature/test-jvmti.make.output > [root@2d7fe307ad20 perf]# ls -la /tmp/build/perf/feature/test-jvmti.bin > -rwxr-xr-x. 1 root root 21592 Jun 12 20:48 > /tmp/build/perf/feature/test-jvmti.bin > [root@2d7fe307ad20 perf]# > > And reproduce the problem you reported: > > jvmti/jvmti_agent.c:48:21: error: static declaration of ‘gettid’ follows > non-static declaration > 48 | static inline pid_t gettid(void) > | ^~~~~~ > In file included from /usr/include/unistd.h:1170, > from jvmti/jvmti_agent.c:33: > > So, we'll have to have a feature test, that defines some HAVE_GETTID > that then ifdefs out our inline copy, working on it. ok, I did not see your email before I posted my reply, feature test is better, of course ;-) jirka