Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7041391ybi; Mon, 22 Jul 2019 06:11:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqy+wQdICxLbhGh57PeaDcjnOV1GJWAMsJ0bwgVj+MT20Rc9fJUAmiuUPcfBMH3ujXX2P1Bt X-Received: by 2002:a17:90a:bd0b:: with SMTP id y11mr73477214pjr.141.1563801065061; Mon, 22 Jul 2019 06:11:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563801065; cv=none; d=google.com; s=arc-20160816; b=JuK9VUbWdDXn2sP9TBsi8aHu/lD85MB9Yxcbc6rdsskLBq1pJVLqKZ4ujFqP0mXDxX O0JMKsHvAByPsvkMZvm5TDDa4jR0e56VGxD1TK2brWSMFsgU2zaOsvyf7mbNjfubimBP Ng0i7b+92PWJJK9Te/gAEV3LFGyC7lAxP/Wj7uVXH/Wqo4VkD5uzl3BnW4DX7sFvi0LA 5ruVK3SuP9Q3ZKfBqTCABifVARAreAQz3hWiR6+8qS8T9kInnA8KvW/DsBDP7YKsE3OB Kyza+fOQ3Wh/vJ/oWCxOy7KCWy2QcMoGbuq84JNz5DtEfwwQejNsPVU3K49R1j7edkzU inNg== 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-disposition:mime-version:references:message-id:subject:cc :to:date:from:dkim-signature; bh=Faod2kCUc/4GMJcGjJghIiQaSrXiR6ib8/UR7NGCCvc=; b=byAsj0Ple5vHdJh6FZAVGMB9rwrpbWg6m8DF+q7o8305ZZNB4dZiDXaFPKnnWmee7z DrmJxtzQ84z+/2I1AZPAducS7NrpX6B9G/ANKispGNczqpNHQ+j+OFVa4nd+rgK2D32c d+snodOFgZ3Sm/aBJOXmAgnXCS5wVpvygiW6aS/R6+WKMqoY7XCoIlnzxthtvrLww3pi PJZoQ1xVigvSrAFJ+R6FhYATRYnrohSiWwFeQ5L1AnnbfcyzKIpNMjINP37yMofYnK1f 8iPWR/WsMQacZve6dZcmkpOxg0qlAs4zscQy02LQQdDnptnqROkeGBhU9R+Ec+rzYUym pX6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=XwUggrX5; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h8si7416367plt.16.2019.07.22.06.10.49; Mon, 22 Jul 2019 06:11:05 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=XwUggrX5; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728576AbfGVMjb (ORCPT + 99 others); Mon, 22 Jul 2019 08:39:31 -0400 Received: from mail-qt1-f194.google.com ([209.85.160.194]:37067 "EHLO mail-qt1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727547AbfGVMja (ORCPT ); Mon, 22 Jul 2019 08:39:30 -0400 Received: by mail-qt1-f194.google.com with SMTP id y26so38305288qto.4 for ; Mon, 22 Jul 2019 05:39:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:date:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=Faod2kCUc/4GMJcGjJghIiQaSrXiR6ib8/UR7NGCCvc=; b=XwUggrX5NnXnPI6FuhpMYmWpXggLbMdq4Pl/bwaqYuejKAJnCxDgAsVHh2hTnAPv+G s4cJuuwutZxCJftTH3kmxXVHeqWDA/wVzlkjxFR4UDfNDLNRCE027roIX9XtilfN1o7b aKTPpRCs3XawiqMY0bBC6qG0xt0xASvqBThvyubrwS4eEfB9a7YJeaINCjwFwNRdPf7i wyHEPMQ4lP3IZQrY1GJME9acPh8uvsvN5qb+In4nhH9XsKikV2FteWax5i20UIgnNYCW zvRk53Uhq8dfV8/nfSsX0D4gLESCuM7WQMACf5OKHPAKlwzSkFiDiO4ZBnobjxNPEvPm 9O1g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:date:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=Faod2kCUc/4GMJcGjJghIiQaSrXiR6ib8/UR7NGCCvc=; b=dCqxdYg4zDbuWLsAvL9QP04p6as9YR+y2LOWwVaT7eOL1oBCTlanDT3LqF1fa5FlFp nSSrQRwmJ/25443hWPKegc6rbG2yryy4bP9iFwAQ4FgDAhTrLTYevqVg9J9efx/BvyOP 3lzyErL0gLJxye3RXXnVTtOeDyPqopZbD0UWA6PKOcQvxEQWjjW0vQRkNMluQw2H+rAr tr9FCHCHYv3XcOopWtHSjl+ZjbDTN0G6HAdp7CJw/z8NUuboTnXcClQbkc7RsV4J4MA+ gmdiMwnM0TE1U/kIGiikg2A+mXyyg8adUVLmIAMlP06h6X9fnNGI080Aayyk1lppcViL XDHQ== X-Gm-Message-State: APjAAAU63upIfMspFc98pevP76tIrzgEdq3Kv9XBQKxzhgVqkNp9bT/7 xsZU6M/ifKPWkvhXKSOBL5s= X-Received: by 2002:ad4:5311:: with SMTP id y17mr50339552qvr.1.1563799169296; Mon, 22 Jul 2019 05:39:29 -0700 (PDT) Received: from quaco.ghostprotocols.net ([179.97.35.11]) by smtp.gmail.com with ESMTPSA id p59sm19263819qtd.75.2019.07.22.05.39.26 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Mon, 22 Jul 2019 05:39:27 -0700 (PDT) From: Arnaldo Carvalho de Melo X-Google-Original-From: Arnaldo Carvalho de Melo Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id 4E3DE40340; Mon, 22 Jul 2019 09:39:24 -0300 (-03) Date: Mon, 22 Jul 2019 09:39:24 -0300 To: Jiri Olsa Cc: lkml , Ingo Molnar , Namhyung Kim , Alexander Shishkin , Peter Zijlstra , Andi Kleen , Alexey Budankov , Michael Petlan Subject: Re: [PATCH 23/79] libperf: Make libperf.a part of the build Message-ID: <20190722123924.GA28864@kernel.org> References: <20190721112506.12306-1-jolsa@kernel.org> <20190721112506.12306-24-jolsa@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190721112506.12306-24-jolsa@kernel.org> X-Url: http://acmel.wordpress.com User-Agent: Mutt/1.12.0 (2019-05-25) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Sun, Jul 21, 2019 at 01:24:10PM +0200, Jiri Olsa escreveu: > Adding empty libperf.a under toos/perf/lib and > linking it with perf. So, I noticed you created a subdirectory under tools/perf/, while I first thought you would have it in tools/lib/perf/, why not move it there? - Arnaldo > It can also be built separately with: > > $ cd tools/perf/lib && make > CC core.o > LD libperf-in.o > AR libperf.a > LINK libperf.so > > Link: http://lkml.kernel.org/n/tip-lzrlfu3hutepbeqyntjks3za@git.kernel.org > Signed-off-by: Jiri Olsa > --- > tools/perf/Makefile.config | 1 + > tools/perf/Makefile.perf | 30 ++++++++-------- > tools/perf/lib/Build | 1 + > tools/perf/lib/Makefile | 74 ++++++++++++++++++++++++++++++++++++++ > tools/perf/lib/core.c | 0 > 5 files changed, 92 insertions(+), 14 deletions(-) > create mode 100644 tools/perf/lib/Build > create mode 100644 tools/perf/lib/Makefile > create mode 100644 tools/perf/lib/core.c > > diff --git a/tools/perf/Makefile.config b/tools/perf/Makefile.config > index 89ac5a1f1550..e4988f49ea79 100644 > --- a/tools/perf/Makefile.config > +++ b/tools/perf/Makefile.config > @@ -277,6 +277,7 @@ ifeq ($(DEBUG),0) > endif > endif > > +INC_FLAGS += -I$(src-perf)/lib/include > INC_FLAGS += -I$(src-perf)/util/include > INC_FLAGS += -I$(src-perf)/arch/$(SRCARCH)/include > INC_FLAGS += -I$(srctree)/tools/include/uapi > diff --git a/tools/perf/Makefile.perf b/tools/perf/Makefile.perf > index 0fffd2bb6cd9..6e7e7d44ffac 100644 > --- a/tools/perf/Makefile.perf > +++ b/tools/perf/Makefile.perf > @@ -224,6 +224,7 @@ LIB_DIR = $(srctree)/tools/lib/api/ > TRACE_EVENT_DIR = $(srctree)/tools/lib/traceevent/ > BPF_DIR = $(srctree)/tools/lib/bpf/ > SUBCMD_DIR = $(srctree)/tools/lib/subcmd/ > +LIBPERF_DIR = $(srctree)/tools/perf/lib/ > > # Set FEATURE_TESTS to 'all' so all possible feature checkers are executed. > # Without this setting the output feature dump file misses some features, for > @@ -272,6 +273,7 @@ ifneq ($(OUTPUT),) > TE_PATH=$(OUTPUT) > BPF_PATH=$(OUTPUT) > SUBCMD_PATH=$(OUTPUT) > + LIBPERF_PATH=$(OUTPUT) > ifneq ($(subdir),) > API_PATH=$(OUTPUT)/../lib/api/ > else > @@ -282,6 +284,7 @@ else > API_PATH=$(LIB_DIR) > BPF_PATH=$(BPF_DIR) > SUBCMD_PATH=$(SUBCMD_DIR) > + LIBPERF_PATH=$(LIBPERF_DIR) > endif > > LIBTRACEEVENT = $(TE_PATH)libtraceevent.a > @@ -303,6 +306,8 @@ LIBBPF = $(BPF_PATH)libbpf.a > > LIBSUBCMD = $(SUBCMD_PATH)libsubcmd.a > > +LIBPERF = $(LIBPERF_PATH)libperf.a > + > # python extension build directories > PYTHON_EXTBUILD := $(OUTPUT)python_ext_build/ > PYTHON_EXTBUILD_LIB := $(PYTHON_EXTBUILD)lib/ > @@ -348,9 +353,7 @@ endif > > export PERL_PATH > > -LIBPERF_A=$(OUTPUT)libperf.a > - > -PERFLIBS = $(LIBAPI) $(LIBTRACEEVENT) $(LIBSUBCMD) > +PERFLIBS = $(LIBAPI) $(LIBTRACEEVENT) $(LIBSUBCMD) $(LIBPERF) > ifndef NO_LIBBPF > PERFLIBS += $(LIBBPF) > endif > @@ -583,8 +586,6 @@ JEVENTS_IN := $(OUTPUT)pmu-events/jevents-in.o > > PMU_EVENTS_IN := $(OUTPUT)pmu-events/pmu-events-in.o > > -LIBPERF_IN := $(OUTPUT)libperf-in.o > - > export JEVENTS > > build := -f $(srctree)/tools/build/Makefile.build dir=. obj > @@ -601,12 +602,9 @@ $(JEVENTS): $(JEVENTS_IN) > $(PMU_EVENTS_IN): $(JEVENTS) FORCE > $(Q)$(MAKE) -f $(srctree)/tools/build/Makefile.build dir=pmu-events obj=pmu-events > > -$(LIBPERF_IN): prepare FORCE > - $(Q)$(MAKE) $(build)=libperf > - > -$(OUTPUT)perf: $(PERFLIBS) $(PERF_IN) $(PMU_EVENTS_IN) $(LIBPERF_IN) $(LIBTRACEEVENT_DYNAMIC_LIST) > +$(OUTPUT)perf: $(PERFLIBS) $(PERF_IN) $(PMU_EVENTS_IN) $(LIBTRACEEVENT_DYNAMIC_LIST) > $(QUIET_LINK)$(CC) $(CFLAGS) $(LDFLAGS) $(LIBTRACEEVENT_DYNAMIC_LIST_LDFLAGS) \ > - $(PERF_IN) $(PMU_EVENTS_IN) $(LIBPERF_IN) $(LIBS) -o $@ > + $(PERF_IN) $(PMU_EVENTS_IN) $(LIBS) -o $@ > > $(GTK_IN): FORCE > $(Q)$(MAKE) $(build)=gtk > @@ -727,9 +725,6 @@ endif > > $(patsubst perf-%,%.o,$(PROGRAMS)): $(wildcard */*.h) > > -$(LIBPERF_A): $(LIBPERF_IN) > - $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIBPERF_IN) $(LIB_OBJS) > - > LIBTRACEEVENT_FLAGS += plugin_dir=$(plugindir_SQ) 'EXTRA_CFLAGS=$(EXTRA_CFLAGS)' 'LDFLAGS=$(LDFLAGS)' > > $(LIBTRACEEVENT): FORCE > @@ -762,6 +757,13 @@ $(LIBBPF)-clean: > $(call QUIET_CLEAN, libbpf) > $(Q)$(MAKE) -C $(BPF_DIR) O=$(OUTPUT) clean >/dev/null > > +$(LIBPERF): FORCE > + $(Q)$(MAKE) -C $(LIBPERF_DIR) O=$(OUTPUT) $(OUTPUT)libperf.a > + > +$(LIBPERF)-clean: > + $(call QUIET_CLEAN, libperf) > + $(Q)$(MAKE) -C $(LIBPERF_DIR) O=$(OUTPUT) clean >/dev/null > + > $(LIBSUBCMD): FORCE > $(Q)$(MAKE) -C $(SUBCMD_DIR) O=$(OUTPUT) $(OUTPUT)libsubcmd.a > > @@ -948,7 +950,7 @@ config-clean: > python-clean: > $(python-clean) > > -clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clean config-clean fixdep-clean python-clean > +clean:: $(LIBTRACEEVENT)-clean $(LIBAPI)-clean $(LIBBPF)-clean $(LIBSUBCMD)-clean $(LIBPERF)-clean config-clean fixdep-clean python-clean > $(call QUIET_CLEAN, core-objs) $(RM) $(LIBPERF_A) $(OUTPUT)perf-archive $(OUTPUT)perf-with-kcore $(LANG_BINDINGS) > $(Q)find $(if $(OUTPUT),$(OUTPUT),.) -name '*.o' -delete -o -name '\.*.cmd' -delete -o -name '\.*.d' -delete > $(Q)$(RM) $(OUTPUT).config-detected > diff --git a/tools/perf/lib/Build b/tools/perf/lib/Build > new file mode 100644 > index 000000000000..5196958cec01 > --- /dev/null > +++ b/tools/perf/lib/Build > @@ -0,0 +1 @@ > +libperf-y += core.o > diff --git a/tools/perf/lib/Makefile b/tools/perf/lib/Makefile > new file mode 100644 > index 000000000000..e6f2eb702aaa > --- /dev/null > +++ b/tools/perf/lib/Makefile > @@ -0,0 +1,74 @@ > +# SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause) > +# Most of this file is copied from tools/lib/bpf/Makefile > + > +MAKEFLAGS += --no-print-directory > + > +ifeq ($(srctree),) > +srctree := $(patsubst %/,%,$(dir $(CURDIR))) > +srctree := $(patsubst %/,%,$(dir $(srctree))) > +srctree := $(patsubst %/,%,$(dir $(srctree))) > +#$(info Determined 'srctree' to be $(srctree)) > +endif > + > +include $(srctree)/tools/scripts/Makefile.include > +include $(srctree)/tools/scripts/Makefile.arch > + > +ifeq ("$(origin V)", "command line") > + VERBOSE = $(V) > +endif > +ifndef VERBOSE > + VERBOSE = 0 > +endif > + > +ifeq ($(VERBOSE),1) > + Q = > +else > + Q = @ > +endif > + > +# Set compile option CFLAGS > +ifdef EXTRA_CFLAGS > + CFLAGS := $(EXTRA_CFLAGS) > +else > + CFLAGS := -g -Wall > +endif > + > +INCLUDES = -I. -Iinclude -I$(srctree)/tools/include -I$(srctree)/tools/arch/$(ARCH)/include/ > + > +# Append required CFLAGS > +override CFLAGS += $(EXTRA_WARNINGS) > +override CFLAGS += -Werror -Wall > +override CFLAGS += -fPIC > +override CFLAGS += $(INCLUDES) > +override CFLAGS += -fvisibility=hidden > + > +all: > + > +export srctree OUTPUT CC LD CFLAGS V > +include $(srctree)/tools/build/Makefile.include > + > +LIBPERF_SO := $(OUTPUT)libperf.so > +LIBPERF_A := $(OUTPUT)libperf.a > +LIBPERF_IN := $(OUTPUT)libperf-in.o > + > +$(LIBPERF_IN): FORCE > + $(Q)$(MAKE) $(build)=libperf > + > +$(LIBPERF_A): $(LIBPERF_IN) > + $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIBPERF_IN) > + > +$(LIBPERF_SO): $(LIBPERF_IN) > + $(QUIET_LINK)$(CC) --shared -Wl,-soname,libperf.so $^ -o $@ > + > +libs: $(LIBPERF_A) $(LIBPERF_SO) > + > +all: fixdep > + $(Q)$(MAKE) libs > + > +clean: > + $(call QUIET_CLEAN, libperf) $(RM) $(LIBPERF_A) \ > + *.o *~ *.a *.so .*.d .*.cmd LIBPERF-CFLAGS > + > +FORCE: > + > +.PHONY: all install clean FORCE > diff --git a/tools/perf/lib/core.c b/tools/perf/lib/core.c > new file mode 100644 > index 000000000000..e69de29bb2d1 > -- > 2.21.0 -- - Arnaldo