From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wi0-f177.google.com (mail-wi0-f177.google.com [209.85.212.177]) by dpdk.org (Postfix) with ESMTP id 3F468B0A6 for ; Fri, 9 May 2014 12:32:26 +0200 (CEST) Received: by mail-wi0-f177.google.com with SMTP id f8so1088837wiw.4 for ; Fri, 09 May 2014 03:32:32 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=s4i8kar14H1V6m7NCULDRHgpe+kGH84wx8gROMenaEE=; b=drwZIo/7j/sEqfj+L47sPM5VvFR5myJyUinpD7Vmes5IKCHvbAYpFOeymmdiB3t0YB OBtM9VXgrrWcBV2GfNvxBv4dO8dvf1wsd/OsPZVyB19PLU0BiCPZ4ZdftiRfpRlq7Lav +RlFDuoDuT1mdf1IeHF4hkt6CjSH8hwzd1SQ3ou+du035oxjaNS4Z5SvjjWdw9A3OHak lKB9G56YU0zUib3iXH9ihvmSieXlqEfWnUjwOXG/o6qXtuOB0vPL539/4OdiN9l2Tx6D TcwcZE2qSWjrubH6ioiZFCUCSmSb9xNU1unJt2ZyHydLu/BFfh6DMbk0WJA3oozvp3Xo LAcQ== X-Gm-Message-State: ALoCoQkeHe+ETZGEv2lRyPrZVoWhOwyrLGUzRZEgIa+XRbMWv7OgZl1/CaIxHsRR6YrYSjjNN9Oq X-Received: by 10.180.105.72 with SMTP id gk8mr2712259wib.32.1399631552546; Fri, 09 May 2014 03:32:32 -0700 (PDT) Received: from glumotte.dev.6wind.com (6wind.net2.nerim.net. [213.41.180.237]) by mx.google.com with ESMTPSA id by1sm4936710wjc.26.2014.05.09.03.32.30 for (version=TLSv1.2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Fri, 09 May 2014 03:32:31 -0700 (PDT) From: Olivier Matz To: dev@dpdk.org Date: Fri, 9 May 2014 12:32:10 +0200 Message-Id: <1399631530-24956-7-git-send-email-olivier.matz@6wind.com> X-Mailer: git-send-email 1.9.2 In-Reply-To: <1399631530-24956-1-git-send-email-olivier.matz@6wind.com> References: <1399631530-24956-1-git-send-email-olivier.matz@6wind.com> Subject: [dpdk-dev] [PATCH v2 6/6] mk: add "make examples" target in root makefile X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: patches and discussions about DPDK List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 09 May 2014 10:32:26 -0000 It is now possible to build all projects from the examples/ directory using one command from root directory. Some illustration of what is possible: - build examples in the DPDK tree for one target # install the x86_64-default-linuxapp-gcc in # ${RTE_SDK}/x86_64-default-linuxapp-gcc directory user@droids:~/dpdk.org$ make install T=x86_64-default-linuxapp-gcc # build examples for this new installation in # ${RTE_SDK}/examples directory user@droids:~/dpdk.org$ make examples T=x86_64-default-linuxapp-gcc - build examples outside DPDK tree for several targets # install all targets matching x86_64-*-linuxapp-gcc in # ${RTE_SDK}/x86_64-*-linuxapp-gcc directories user@droids:~/dpdk.org$ make install T=x86_64-*-linuxapp-gcc # build examples for these installations in /tmp/foobar user@droids:~/dpdk.org$ make examples T=x86_64-*-linuxapp-gcc O=/tmp/foobar Signed-off-by: Olivier Matz --- doc/build-sdk-quick.txt | 14 +++++---- mk/rte.sdkexamples.mk | 79 +++++++++++++++++++++++++++++++++++++++++++++++++ mk/rte.sdkroot.mk | 4 +++ 3 files changed, 91 insertions(+), 6 deletions(-) create mode 100644 mk/rte.sdkexamples.mk diff --git a/doc/build-sdk-quick.txt b/doc/build-sdk-quick.txt index 8989a32..d768c44 100644 --- a/doc/build-sdk-quick.txt +++ b/doc/build-sdk-quick.txt @@ -1,12 +1,14 @@ Basic build make config T=x86_64-default-linuxapp-gcc && make Build commands - config get configuration from target template (T=) - all same as build (default rule) - build build in a configured directory - clean remove files but keep configuration - install build many targets (wildcard allowed) and install in DESTDIR - uninstall remove all installed targets + config get configuration from target template (T=) + all same as build (default rule) + build build in a configured directory + clean remove files but keep configuration + install build many targets (wildcard allowed) and install in DESTDIR + uninstall remove all installed targets + examples build examples for given targets (T=) + examples_clean clean examples for given targets (T=) Build variables EXTRA_CPPFLAGS preprocessor options EXTRA_CFLAGS compiler options diff --git a/mk/rte.sdkexamples.mk b/mk/rte.sdkexamples.mk new file mode 100644 index 0000000..a76570e --- /dev/null +++ b/mk/rte.sdkexamples.mk @@ -0,0 +1,79 @@ +# BSD LICENSE +# +# Copyright(c) 2014 6WIND S.A. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions +# are met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# * Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in +# the documentation and/or other materials provided with the +# distribution. +# * Neither the name of 6WIND S.A. nor the names of its +# contributors may be used to endorse or promote products derived +# from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +# examples application are seen as external applications which are +# not part of SDK. +BUILDING_RTE_SDK := +export BUILDING_RTE_SDK + +# Build directory is given with O= +ifndef O +O = $(RTE_SDK)/examples +endif + +# Target for which examples should be built. +ifndef T +T = * +endif + +# list all available configurations +EXAMPLES_CONFIGS := $(patsubst $(RTE_SRCDIR)/config/defconfig_%,%,\ + $(wildcard $(RTE_SRCDIR)/config/defconfig_$(T))) +EXAMPLES_TARGETS := $(addsuffix _examples,\ + $(filter-out %~,$(EXAMPLES_CONFIGS))) + +.PHONY: examples +examples: $(EXAMPLES_TARGETS) + +%_examples: + @echo ================== Build examples for $* + $(Q)if [ ! -d "${RTE_SDK}/${*}" ]; then \ + echo "Target ${*} does not exist in ${RTE_SDK}/${*}." ; \ + echo -n "Please install DPDK first (make install) or use another " ; \ + echo "target argument (T=target)." ; \ + else \ + $(MAKE) -C examples O=$(O) RTE_TARGET=$(*); \ + fi + +EXAMPLES_CLEAN_TARGETS := $(addsuffix _examples_clean,\ + $(filter-out %~,$(EXAMPLES_CONFIGS))) + +.PHONY: examples_clean +examples_clean: $(EXAMPLES_CLEAN_TARGETS) + +%_examples_clean: + @echo ================== Clean examples for $* + $(Q)if [ ! -d "${RTE_SDK}/${*}" ]; then \ + echo "Target ${*} does not exist in ${RTE_SDK}/${*}." ; \ + echo -n "Please install DPDK first (make install) or use another " ; \ + echo "target argument (T=target)." ; \ + else \ + $(MAKE) -C examples O=$(O) RTE_TARGET=$(*) clean; \ + fi diff --git a/mk/rte.sdkroot.mk b/mk/rte.sdkroot.mk index 28e404b..54aa204 100644 --- a/mk/rte.sdkroot.mk +++ b/mk/rte.sdkroot.mk @@ -115,6 +115,10 @@ depdirs depgraph: gcov gcovclean: $(Q)$(MAKE) -f $(RTE_SDK)/mk/rte.sdkgcov.mk $@ +.PHONY: examples examples_clean +examples examples_clean: + $(Q)$(MAKE) -f $(RTE_SDK)/mk/rte.sdkexamples.mk $@ + # all other build targets %: $(Q)$(MAKE) -f $(RTE_SDK)/mk/rte.sdkconfig.mk checkconfig -- 1.9.2