]> rtime.felk.cvut.cz Git - coffee/buildroot.git/blob - Makefile
Update for 2017.02.9
[coffee/buildroot.git] / Makefile
1 # Makefile for buildroot
2 #
3 # Copyright (C) 1999-2005 by Erik Andersen <andersen@codepoet.org>
4 # Copyright (C) 2006-2014 by the Buildroot developers <buildroot@uclibc.org>
5 # Copyright (C) 2014-2017 by the Buildroot developers <buildroot@buildroot.org>
6 #
7 # This program is free software; you can redistribute it and/or modify
8 # it under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 2 of the License, or
10 # (at your option) any later version.
11 #
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 # General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License
18 # along with this program; if not, write to the Free Software
19 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 #
21
22 #--------------------------------------------------------------
23 # Just run 'make menuconfig', configure stuff, then run 'make'.
24 # You shouldn't need to mess with anything beyond this point...
25 #--------------------------------------------------------------
26
27 # Delete default rules. We don't use them. This saves a bit of time.
28 .SUFFIXES:
29
30 # we want bash as shell
31 SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
32          else if [ -x /bin/bash ]; then echo /bin/bash; \
33          else echo sh; fi; fi)
34
35 # Set O variable if not already done on the command line;
36 # or avoid confusing packages that can use the O=<dir> syntax for out-of-tree
37 # build by preventing it from being forwarded to sub-make calls.
38 ifneq ("$(origin O)", "command line")
39 O := $(CURDIR)/output
40 endif
41
42 # Check if the current Buildroot execution meets all the pre-requisites.
43 # If they are not met, Buildroot will actually do its job in a sub-make meeting
44 # its pre-requisites, which are:
45 #  1- Permissive enough umask:
46 #       Wrong or too restrictive umask will prevent Buildroot and packages from
47 #       creating files and directories.
48 #  2- Absolute canonical CWD (i.e. $(CURDIR)):
49 #       Otherwise, some packages will use CWD as-is, others will compute its
50 #       absolute canonical path. This makes harder tracking and fixing host
51 #       machine path leaks.
52 #  3- Absolute canonical output location (i.e. $(O)):
53 #       For the same reason as the one for CWD.
54
55 # Remove the trailing '/.' from $(O) as it can be added by the makefile wrapper
56 # installed in the $(O) directory.
57 # Also remove the trailing '/' the user can set when on the command line.
58 override O := $(patsubst %/,%,$(patsubst %.,%,$(O)))
59 # Make sure $(O) actually exists before calling realpath on it; this is to
60 # avoid empty CANONICAL_O in case on non-existing entry.
61 CANONICAL_O := $(shell mkdir -p $(O) >/dev/null 2>&1)$(realpath $(O))
62
63 CANONICAL_CURDIR = $(realpath $(CURDIR))
64
65 REQ_UMASK = 0022
66
67 # Make sure O= is passed (with its absolute canonical path) everywhere the
68 # toplevel makefile is called back.
69 EXTRAMAKEARGS := O=$(CANONICAL_O)
70
71 # Check Buildroot execution pre-requisites here.
72 ifneq ($(shell umask):$(CURDIR):$(O),$(REQ_UMASK):$(CANONICAL_CURDIR):$(CANONICAL_O))
73 .PHONY: _all $(MAKECMDGOALS)
74
75 $(MAKECMDGOALS): _all
76         @:
77
78 _all:
79         @umask $(REQ_UMASK) && \
80                 $(MAKE) -C $(CANONICAL_CURDIR) --no-print-directory \
81                         $(MAKECMDGOALS) $(EXTRAMAKEARGS)
82
83 else # umask / $(CURDIR) / $(O)
84
85 # This is our default rule, so must come first
86 all:
87
88 # Set and export the version string
89 export BR2_VERSION := 2017.02.9
90 # Actual time the release is cut (for reproducible builds)
91 BR2_VERSION_EPOCH = 1514805000
92
93 # Save running make version since it's clobbered by the make package
94 RUNNING_MAKE_VERSION := $(MAKE_VERSION)
95
96 # Check for minimal make version (note: this check will break at make 10.x)
97 MIN_MAKE_VERSION = 3.81
98 ifneq ($(firstword $(sort $(RUNNING_MAKE_VERSION) $(MIN_MAKE_VERSION))),$(MIN_MAKE_VERSION))
99 $(error You have make '$(RUNNING_MAKE_VERSION)' installed. GNU make >= $(MIN_MAKE_VERSION) is required)
100 endif
101
102 # Parallel execution of this Makefile is disabled because it changes
103 # the packages building order, that can be a problem for two reasons:
104 # - If a package has an unspecified optional dependency and that
105 #   dependency is present when the package is built, it is used,
106 #   otherwise it isn't (but compilation happily proceeds) so the end
107 #   result will differ if the order is swapped due to parallel
108 #   building.
109 # - Also changing the building order can be a problem if two packages
110 #   manipulate the same file in the target directory.
111 #
112 # Taking into account the above considerations, if you still want to execute
113 # this top-level Makefile in parallel comment the ".NOTPARALLEL" line and
114 # use the -j<jobs> option when building, e.g:
115 #      make -j$((`getconf _NPROCESSORS_ONLN`+1))
116 .NOTPARALLEL:
117
118 # absolute path
119 TOPDIR := $(CURDIR)
120 CONFIG_CONFIG_IN = Config.in
121 CONFIG = support/kconfig
122 DATE := $(shell date +%Y%m%d)
123
124 # Compute the full local version string so packages can use it as-is
125 # Need to export it, so it can be got from environment in children (eg. mconf)
126 export BR2_VERSION_FULL := $(BR2_VERSION)$(shell $(TOPDIR)/support/scripts/setlocalversion)
127
128 noconfig_targets := menuconfig nconfig gconfig xconfig config oldconfig randconfig \
129         defconfig %_defconfig allyesconfig allnoconfig silentoldconfig release \
130         randpackageconfig allyespackageconfig allnopackageconfig \
131         print-version olddefconfig distclean manual manual-html manual-split-html \
132         manual-pdf manual-text manual-epub
133
134 # Some global targets do not trigger a build, but are used to collect
135 # metadata, or do various checks. When such targets are triggered,
136 # some packages should not do their configuration sanity
137 # checks. Provide them a BR_BUILDING variable set to 'y' when we're
138 # actually building and they should do their sanity checks.
139 #
140 # We're building in two situations: when MAKECMDGOALS is empty
141 # (default target is to build), or when MAKECMDGOALS contains
142 # something else than one of the nobuild_targets.
143 nobuild_targets := source %-source source-check \
144         legal-info %-legal-info external-deps _external-deps \
145         clean distclean help show-targets graph-depends \
146         %-graph-depends %-show-depends %-show-version \
147         graph-build graph-size list-defconfigs \
148         savedefconfig printvars
149 ifeq ($(MAKECMDGOALS),)
150 BR_BUILDING = y
151 else ifneq ($(filter-out $(nobuild_targets),$(MAKECMDGOALS)),)
152 BR_BUILDING = y
153 endif
154
155 # We call make recursively to build packages. The command-line overrides that
156 # are passed to Buildroot don't apply to those package build systems. In
157 # particular, we don't want to pass down the O=<dir> option for out-of-tree
158 # builds, because the value specified on the command line will not be correct
159 # for packages.
160 MAKEOVERRIDES :=
161
162 # Include some helper macros and variables
163 include support/misc/utils.mk
164
165 # Set variables related to in-tree or out-of-tree build.
166 # Here, both $(O) and $(CURDIR) are absolute canonical paths.
167 ifeq ($(O),$(CURDIR)/output)
168 CONFIG_DIR := $(CURDIR)
169 NEED_WRAPPER =
170 else
171 CONFIG_DIR := $(O)
172 NEED_WRAPPER = y
173 endif
174
175 # bash prints the name of the directory on 'cd <dir>' if CDPATH is
176 # set, so unset it here to not cause problems. Notice that the export
177 # line doesn't affect the environment of $(shell ..) calls.
178 export CDPATH :=
179
180 BASE_DIR := $(CANONICAL_O)
181 $(if $(BASE_DIR),, $(error output directory "$(O)" does not exist))
182
183
184 # Handling of BR2_EXTERNAL.
185 #
186 # The value of BR2_EXTERNAL is stored in .br-external in the output directory.
187 # The location of the external.mk makefile fragments is computed in that file.
188 # On subsequent invocations of make, this file is read in. BR2_EXTERNAL can
189 # still be overridden on the command line, therefore the file is re-created
190 # every time make is run.
191
192 BR2_EXTERNAL_FILE = $(BASE_DIR)/.br-external.mk
193 -include $(BR2_EXTERNAL_FILE)
194 $(shell support/scripts/br2-external \
195         -m -o '$(BR2_EXTERNAL_FILE)' $(BR2_EXTERNAL))
196 BR2_EXTERNAL_ERROR =
197 include $(BR2_EXTERNAL_FILE)
198 ifneq ($(BR2_EXTERNAL_ERROR),)
199 $(error $(BR2_EXTERNAL_ERROR))
200 endif
201
202 # To make sure that the environment variable overrides the .config option,
203 # set this before including .config.
204 ifneq ($(BR2_DL_DIR),)
205 DL_DIR := $(BR2_DL_DIR)
206 endif
207 ifneq ($(BR2_CCACHE_DIR),)
208 BR_CACHE_DIR := $(BR2_CCACHE_DIR)
209 endif
210
211 # Need that early, before we scan packages
212 # Avoids doing the $(or...) everytime
213 BR_GRAPH_OUT := $(or $(BR2_GRAPH_OUT),pdf)
214
215 BUILD_DIR := $(BASE_DIR)/build
216 BINARIES_DIR := $(BASE_DIR)/images
217 TARGET_DIR := $(BASE_DIR)/target
218 # initial definition so that 'make clean' works for most users, even without
219 # .config. HOST_DIR will be overwritten later when .config is included.
220 HOST_DIR := $(BASE_DIR)/host
221 GRAPHS_DIR := $(BASE_DIR)/graphs
222
223 LEGAL_INFO_DIR = $(BASE_DIR)/legal-info
224 REDIST_SOURCES_DIR_TARGET = $(LEGAL_INFO_DIR)/sources
225 REDIST_SOURCES_DIR_HOST = $(LEGAL_INFO_DIR)/host-sources
226 LICENSE_FILES_DIR_TARGET = $(LEGAL_INFO_DIR)/licenses
227 LICENSE_FILES_DIR_HOST = $(LEGAL_INFO_DIR)/host-licenses
228 LEGAL_MANIFEST_CSV_TARGET = $(LEGAL_INFO_DIR)/manifest.csv
229 LEGAL_MANIFEST_CSV_HOST = $(LEGAL_INFO_DIR)/host-manifest.csv
230 LEGAL_WARNINGS = $(LEGAL_INFO_DIR)/.warnings
231 LEGAL_REPORT = $(LEGAL_INFO_DIR)/README
232
233 ################################################################################
234 #
235 # staging and target directories do NOT list these as
236 # dependencies anywhere else
237 #
238 ################################################################################
239 $(BUILD_DIR) $(TARGET_DIR) $(HOST_DIR) $(BINARIES_DIR) $(LEGAL_INFO_DIR) $(REDIST_SOURCES_DIR_TARGET) $(REDIST_SOURCES_DIR_HOST):
240         @mkdir -p $@
241
242 BR2_CONFIG = $(CONFIG_DIR)/.config
243
244 # Pull in the user's configuration file
245 ifeq ($(filter $(noconfig_targets),$(MAKECMDGOALS)),)
246 -include $(BR2_CONFIG)
247 endif
248
249 # timezone and locale may affect build output
250 ifeq ($(BR2_REPRODUCIBLE),y)
251 export TZ = UTC
252 export LANG = C
253 export LC_ALL = C
254 export GZIP = -n
255 BR2_VERSION_GIT_EPOCH = $(shell GIT_DIR=$(TOPDIR)/.git $(GIT) log -1 --format=%at)
256 export SOURCE_DATE_EPOCH ?= $(if $(wildcard $(TOPDIR)/.git),$(BR2_VERSION_GIT_EPOCH),$(BR2_VERSION_EPOCH))
257 DEPENDENCIES_HOST_PREREQ += host-fakedate
258 endif
259
260 # To put more focus on warnings, be less verbose as default
261 # Use 'make V=1' to see the full commands
262 ifeq ("$(origin V)", "command line")
263   KBUILD_VERBOSE = $(V)
264 endif
265 ifndef KBUILD_VERBOSE
266   KBUILD_VERBOSE = 0
267 endif
268
269 ifeq ($(KBUILD_VERBOSE),1)
270   Q =
271 ifndef VERBOSE
272   VERBOSE = 1
273 endif
274 export VERBOSE
275 else
276   Q = @
277 endif
278
279 # kconfig uses CONFIG_SHELL
280 CONFIG_SHELL := $(SHELL)
281
282 export SHELL CONFIG_SHELL Q KBUILD_VERBOSE
283
284 ifndef HOSTAR
285 HOSTAR := ar
286 endif
287 ifndef HOSTAS
288 HOSTAS := as
289 endif
290 ifndef HOSTCC
291 HOSTCC := gcc
292 HOSTCC := $(shell which $(HOSTCC) || type -p $(HOSTCC) || echo gcc)
293 endif
294 HOSTCC_NOCCACHE := $(HOSTCC)
295 ifndef HOSTCXX
296 HOSTCXX := g++
297 HOSTCXX := $(shell which $(HOSTCXX) || type -p $(HOSTCXX) || echo g++)
298 endif
299 HOSTCXX_NOCCACHE := $(HOSTCXX)
300 ifndef HOSTCPP
301 HOSTCPP := cpp
302 endif
303 ifndef HOSTLD
304 HOSTLD := ld
305 endif
306 ifndef HOSTLN
307 HOSTLN := ln
308 endif
309 ifndef HOSTNM
310 HOSTNM := nm
311 endif
312 ifndef HOSTOBJCOPY
313 HOSTOBJCOPY := objcopy
314 endif
315 ifndef HOSTRANLIB
316 HOSTRANLIB := ranlib
317 endif
318 HOSTAR := $(shell which $(HOSTAR) || type -p $(HOSTAR) || echo ar)
319 HOSTAS := $(shell which $(HOSTAS) || type -p $(HOSTAS) || echo as)
320 HOSTCPP := $(shell which $(HOSTCPP) || type -p $(HOSTCPP) || echo cpp)
321 HOSTLD := $(shell which $(HOSTLD) || type -p $(HOSTLD) || echo ld)
322 HOSTLN := $(shell which $(HOSTLN) || type -p $(HOSTLN) || echo ln)
323 HOSTNM := $(shell which $(HOSTNM) || type -p $(HOSTNM) || echo nm)
324 HOSTOBJCOPY := $(shell which $(HOSTOBJCOPY) || type -p $(HOSTOBJCOPY) || echo objcopy)
325 HOSTRANLIB := $(shell which $(HOSTRANLIB) || type -p $(HOSTRANLIB) || echo ranlib)
326 SED := $(shell which sed || type -p sed) -i -e
327
328 export HOSTAR HOSTAS HOSTCC HOSTCXX HOSTLD
329 export HOSTCC_NOCCACHE HOSTCXX_NOCCACHE
330
331 # Determine the userland we are running on.
332 #
333 # Note that, despite its name, we are not interested in the actual
334 # architecture name. This is mostly used to determine whether some
335 # of the binary tools (e.g. pre-built external toolchains) can run
336 # on the current host. So we need to know if the userland we're
337 # running on can actually run those toolchains.
338 #
339 # For example, a 64-bit prebuilt toolchain will not run on a 64-bit
340 # kernel if the userland is 32-bit (e.g. in a chroot for example).
341 #
342 # So, we extract the first part of the tuple the host gcc was
343 # configured to generate code for; we assume this is our userland.
344 #
345 export HOSTARCH := $(shell LC_ALL=C $(HOSTCC_NOCCACHE) -v 2>&1 | \
346         sed -e '/^Target: \([^-]*\).*/!d' \
347             -e 's//\1/' \
348             -e 's/i.86/x86/' \
349             -e 's/sun4u/sparc64/' \
350             -e 's/arm.*/arm/' \
351             -e 's/sa110/arm/' \
352             -e 's/ppc64/powerpc64/' \
353             -e 's/ppc/powerpc/' \
354             -e 's/macppc/powerpc/' \
355             -e 's/sh.*/sh/' )
356
357 HOSTCC_VERSION := $(shell $(HOSTCC_NOCCACHE) --version | \
358         sed -n -r 's/^.* ([0-9]*)\.([0-9]*)\.([0-9]*)[ ]*.*/\1 \2/p')
359
360 # For gcc >= 5.x, we only need the major version.
361 ifneq ($(firstword $(HOSTCC_VERSION)),4)
362 HOSTCC_VERSION := $(firstword $(HOSTCC_VERSION))
363 endif
364
365 # Make sure pkg-config doesn't look outside the buildroot tree
366 HOST_PKG_CONFIG_PATH := $(PKG_CONFIG_PATH)
367 unexport PKG_CONFIG_PATH
368 unexport PKG_CONFIG_SYSROOT_DIR
369 unexport PKG_CONFIG_LIBDIR
370
371 # Having DESTDIR set in the environment confuses the installation
372 # steps of some packages.
373 unexport DESTDIR
374
375 # Causes breakage with packages that needs host-ruby
376 unexport RUBYOPT
377
378 include package/pkg-utils.mk
379 include package/doc-asciidoc.mk
380
381 ifeq ($(BR2_HAVE_DOT_CONFIG),y)
382
383 ################################################################################
384 #
385 # Hide troublesome environment variables from sub processes
386 #
387 ################################################################################
388 unexport CROSS_COMPILE
389 unexport ARCH
390 unexport CC
391 unexport LD
392 unexport AR
393 unexport CXX
394 unexport CPP
395 unexport RANLIB
396 unexport CFLAGS
397 unexport CXXFLAGS
398 unexport GREP_OPTIONS
399 unexport TAR_OPTIONS
400 unexport CONFIG_SITE
401 unexport QMAKESPEC
402 unexport TERMINFO
403 unexport MACHINE
404 unexport O
405 unexport GCC_COLORS
406
407 GNU_HOST_NAME := $(shell support/gnuconfig/config.guess)
408
409 PACKAGES :=
410 PACKAGES_ALL :=
411
412 # silent mode requested?
413 QUIET := $(if $(findstring s,$(filter-out --%,$(MAKEFLAGS))),-q)
414
415 # Strip off the annoying quoting
416 ARCH := $(call qstrip,$(BR2_ARCH))
417
418 KERNEL_ARCH := $(shell echo "$(ARCH)" | sed -e "s/-.*//" \
419         -e s/i.86/i386/ -e s/sun4u/sparc64/ \
420         -e s/arcle/arc/ \
421         -e s/arceb/arc/ \
422         -e s/arm.*/arm/ -e s/sa110/arm/ \
423         -e s/aarch64.*/arm64/ \
424         -e s/bfin/blackfin/ \
425         -e s/or1k/openrisc/ \
426         -e s/parisc64/parisc/ \
427         -e s/powerpc64.*/powerpc/ \
428         -e s/ppc.*/powerpc/ -e s/mips.*/mips/ \
429         -e s/sh.*/sh/ \
430         -e s/microblazeel/microblaze/)
431
432 ZCAT := $(call qstrip,$(BR2_ZCAT))
433 BZCAT := $(call qstrip,$(BR2_BZCAT))
434 XZCAT := $(call qstrip,$(BR2_XZCAT))
435 LZCAT := $(call qstrip,$(BR2_LZCAT))
436 TAR_OPTIONS = $(call qstrip,$(BR2_TAR_OPTIONS)) -xf
437
438 # packages compiled for the host go here
439 HOST_DIR := $(call qstrip,$(BR2_HOST_DIR))
440
441 # Quotes are needed for spaces and all in the original PATH content.
442 BR_PATH = "$(HOST_DIR)/bin:$(HOST_DIR)/sbin:$(HOST_DIR)/usr/bin:$(HOST_DIR)/usr/sbin:$(PATH)"
443
444 # Location of a file giving a big fat warning that output/target
445 # should not be used as the root filesystem.
446 TARGET_DIR_WARNING_FILE = $(TARGET_DIR)/THIS_IS_NOT_YOUR_ROOT_FILESYSTEM
447
448 ifeq ($(BR2_CCACHE),y)
449 CCACHE := $(HOST_DIR)/usr/bin/ccache
450 BR_CACHE_DIR ?= $(call qstrip,$(BR2_CCACHE_DIR))
451 export BR_CACHE_DIR
452 HOSTCC := $(CCACHE) $(HOSTCC)
453 HOSTCXX := $(CCACHE) $(HOSTCXX)
454 else
455 export BR_NO_CCACHE
456 endif
457
458 # Scripts in support/ or post-build scripts may need to reference
459 # these locations, so export them so it is easier to use
460 export BR2_CONFIG
461 export BR2_REPRODUCIBLE
462 export TARGET_DIR
463 export STAGING_DIR
464 export HOST_DIR
465 export BINARIES_DIR
466 export BASE_DIR
467
468 ################################################################################
469 #
470 # You should probably leave this stuff alone unless you know
471 # what you are doing.
472 #
473 ################################################################################
474
475 all: world
476
477 # Include legacy before the other things, because package .mk files
478 # may rely on it.
479 include Makefile.legacy
480
481 include package/Makefile.in
482 include support/dependencies/dependencies.mk
483
484 PACKAGES += $(DEPENDENCIES_HOST_PREREQ)
485
486 include $(sort $(wildcard toolchain/*.mk))
487 include $(sort $(wildcard toolchain/*/*.mk))
488
489 # Include the package override file if one has been provided in the
490 # configuration.
491 PACKAGE_OVERRIDE_FILE = $(call qstrip,$(BR2_PACKAGE_OVERRIDE_FILE))
492 ifneq ($(PACKAGE_OVERRIDE_FILE),)
493 -include $(PACKAGE_OVERRIDE_FILE)
494 endif
495
496 include $(sort $(wildcard package/*/*.mk))
497
498 include boot/common.mk
499 include linux/linux.mk
500 include fs/common.mk
501
502 # If using a br2-external tree, the BR2_EXTERNAL_$(NAME)_PATH variables
503 # are also present in the .config file. Since .config is included after
504 # we defined them in the Makefile, the values for those variables are
505 # quoted. We just include the generated Makefile fragment .br2-external.mk
506 # a third time, which will set those variables to the un-quoted values.
507 include $(BR2_EXTERNAL_FILE)
508
509 # Nothing to include if no BR2_EXTERNAL tree in use
510 include $(BR2_EXTERNAL_MKS)
511
512 # Now we are sure we have all the packages scanned and defined. We now
513 # check for each package in the list of enabled packages, that all its
514 # dependencies are indeed enabled.
515 #
516 # Only trigger the check for default builds. If the user forces building
517 # a package, even if not enabled in the configuration, we want to accept
518 # it.
519 #
520 ifeq ($(MAKECMDGOALS),)
521
522 define CHECK_ONE_DEPENDENCY
523 ifeq ($$($(2)_TYPE),target)
524 ifeq ($$($(2)_IS_VIRTUAL),)
525 ifneq ($$($$($(2)_KCONFIG_VAR)),y)
526 $$(error $$($(2)_NAME) is in the dependency chain of $$($(1)_NAME) that \
527 has added it to its _DEPENDENCIES variable without selecting it or \
528 depending on it from Config.in)
529 endif
530 endif
531 endif
532 endef
533
534 $(foreach pkg,$(call UPPERCASE,$(PACKAGES)),\
535         $(foreach dep,$(call UPPERCASE,$($(pkg)_FINAL_ALL_DEPENDENCIES)),\
536                 $(eval $(call CHECK_ONE_DEPENDENCY,$(pkg),$(dep))$(sep))))
537
538 endif
539
540 dirs: $(BUILD_DIR) $(STAGING_DIR) $(TARGET_DIR) \
541         $(HOST_DIR) $(BINARIES_DIR)
542
543 $(BUILD_DIR)/buildroot-config/auto.conf: $(BR2_CONFIG)
544         $(MAKE1) $(EXTRAMAKEARGS) HOSTCC="$(HOSTCC_NOCCACHE)" HOSTCXX="$(HOSTCXX_NOCCACHE)" silentoldconfig
545
546 prepare: $(BUILD_DIR)/buildroot-config/auto.conf
547
548 world: target-post-image
549
550 .PHONY: all world toolchain dirs clean distclean source outputmakefile \
551         legal-info legal-info-prepare legal-info-clean printvars help \
552         list-defconfigs target-finalize target-post-image source-check
553
554 # Populating the staging with the base directories is handled by the skeleton package
555 $(STAGING_DIR):
556         @mkdir -p $(STAGING_DIR)
557         @ln -snf $(STAGING_DIR) $(BASE_DIR)/staging
558
559 RSYNC_VCS_EXCLUSIONS = \
560         --exclude .svn --exclude .git --exclude .hg --exclude .bzr \
561         --exclude CVS
562
563 STRIP_FIND_CMD = find $(TARGET_DIR)
564 ifneq (,$(call qstrip,$(BR2_STRIP_EXCLUDE_DIRS)))
565 STRIP_FIND_CMD += \( $(call finddirclauses,$(TARGET_DIR),$(call qstrip,$(BR2_STRIP_EXCLUDE_DIRS))) \) -prune -o
566 endif
567 STRIP_FIND_CMD += -type f \( -perm /111 -o -name '*.so*' \)
568 # file exclusions:
569 # - libpthread.so: a non-stripped libpthread shared library is needed for
570 #   proper debugging of pthread programs using gdb.
571 # - ld.so: a non-stripped dynamic linker library is needed for valgrind
572 # - kernel modules (*.ko): do not function properly when stripped like normal
573 #   applications and libraries. Normally kernel modules are already excluded
574 #   by the executable permission check above, so the explicit exclusion is only
575 #   done for kernel modules with incorrect permissions.
576 STRIP_FIND_CMD += -not \( $(call findfileclauses,libpthread*.so* ld-*.so* *.ko $(call qstrip,$(BR2_STRIP_EXCLUDE_FILES))) \) -print0
577
578 ifeq ($(BR2_ECLIPSE_REGISTER),y)
579 define TOOLCHAIN_ECLIPSE_REGISTER
580         ./support/scripts/eclipse-register-toolchain `readlink -f $(O)` \
581                 $(notdir $(TARGET_CROSS)) $(BR2_ARCH)
582 endef
583 TARGET_FINALIZE_HOOKS += TOOLCHAIN_ECLIPSE_REGISTER
584 endif
585
586 # Generate locale data. Basically, we call the localedef program
587 # (built by the host-localedef package) for each locale. The input
588 # data comes preferably from the toolchain, or if the toolchain does
589 # not have them (Linaro toolchains), we use the ones available on the
590 # host machine.
591 ifeq ($(BR2_TOOLCHAIN_USES_GLIBC),y)
592 GLIBC_GENERATE_LOCALES = $(call qstrip,$(BR2_GENERATE_LOCALE))
593 ifneq ($(GLIBC_GENERATE_LOCALES),)
594 PACKAGES += host-localedef
595
596 define GENERATE_GLIBC_LOCALES
597         $(Q)mkdir -p $(TARGET_DIR)/usr/lib/locale/
598         $(Q)for locale in $(GLIBC_GENERATE_LOCALES) ; do \
599                 inputfile=`echo $${locale} | cut -f1 -d'.'` ; \
600                 charmap=`echo $${locale} | cut -f2 -d'.' -s` ; \
601                 if test -z "$${charmap}" ; then \
602                         charmap="UTF-8" ; \
603                 fi ; \
604                 echo "Generating locale $${inputfile}.$${charmap}" ; \
605                 I18NPATH=$(STAGING_DIR)/usr/share/i18n:/usr/share/i18n \
606                 $(HOST_DIR)/usr/bin/localedef \
607                         --prefix=$(TARGET_DIR) \
608                         --$(call LOWERCASE,$(BR2_ENDIAN))-endian \
609                         -i $${inputfile} -f $${charmap} \
610                         $${locale} ; \
611         done
612 endef
613 TARGET_FINALIZE_HOOKS += GENERATE_GLIBC_LOCALES
614 endif
615 endif
616
617 ifeq ($(BR2_ENABLE_LOCALE_PURGE),y)
618 LOCALE_WHITELIST = $(BUILD_DIR)/locales.nopurge
619 LOCALE_NOPURGE = $(call qstrip,$(BR2_ENABLE_LOCALE_WHITELIST))
620
621 # This piece of junk does the following:
622 # First collect the whitelist in a file.
623 # Then go over all the locale dirs and for each subdir, check if it exists
624 # in the whitelist file. If it doesn't, kill it.
625 # Finally, specifically for X11, regenerate locale.dir from the whitelist.
626 define PURGE_LOCALES
627         rm -f $(LOCALE_WHITELIST)
628         for i in $(LOCALE_NOPURGE) locale-archive; do echo $$i >> $(LOCALE_WHITELIST); done
629
630         for dir in $(wildcard $(addprefix $(TARGET_DIR),/usr/share/locale /usr/share/X11/locale /usr/lib/locale)); \
631         do \
632                 for langdir in $$dir/*; \
633                 do \
634                         if [ -e "$${langdir}" ]; \
635                         then \
636                                 grep -qx "$${langdir##*/}" $(LOCALE_WHITELIST) || rm -rf $$langdir; \
637                         fi \
638                 done; \
639         done
640         if [ -d $(TARGET_DIR)/usr/share/X11/locale ]; \
641         then \
642                 for lang in $(LOCALE_NOPURGE); \
643                 do \
644                         if [ -f $(TARGET_DIR)/usr/share/X11/locale/$$lang/XLC_LOCALE ]; \
645                         then \
646                                 echo "$$lang/XLC_LOCALE: $$lang"; \
647                         fi \
648                 done > $(TARGET_DIR)/usr/share/X11/locale/locale.dir; \
649         fi
650 endef
651 TARGET_FINALIZE_HOOKS += PURGE_LOCALES
652 endif
653
654 $(TARGETS_ROOTFS): target-finalize
655
656 target-finalize: $(PACKAGES)
657         @$(call MESSAGE,"Finalizing target directory")
658         $(foreach hook,$(TARGET_FINALIZE_HOOKS),$($(hook))$(sep))
659         rm -rf $(TARGET_DIR)/usr/include $(TARGET_DIR)/usr/share/aclocal \
660                 $(TARGET_DIR)/usr/lib/pkgconfig $(TARGET_DIR)/usr/share/pkgconfig \
661                 $(TARGET_DIR)/usr/lib/cmake $(TARGET_DIR)/usr/share/cmake
662         find $(TARGET_DIR)/usr/{lib,share}/ -name '*.cmake' -print0 | xargs -0 rm -f
663         find $(TARGET_DIR)/lib/ $(TARGET_DIR)/usr/lib/ $(TARGET_DIR)/usr/libexec/ \
664                 \( -name '*.a' -o -name '*.la' \) -print0 | xargs -0 rm -f
665 ifneq ($(BR2_PACKAGE_GDB),y)
666         rm -rf $(TARGET_DIR)/usr/share/gdb
667 endif
668 ifneq ($(BR2_PACKAGE_BASH),y)
669         rm -rf $(TARGET_DIR)/usr/share/bash-completion
670 endif
671 ifneq ($(BR2_PACKAGE_ZSH),y)
672         rm -rf $(TARGET_DIR)/usr/share/zsh
673 endif
674         rm -rf $(TARGET_DIR)/usr/man $(TARGET_DIR)/usr/share/man
675         rm -rf $(TARGET_DIR)/usr/info $(TARGET_DIR)/usr/share/info
676         rm -rf $(TARGET_DIR)/usr/doc $(TARGET_DIR)/usr/share/doc
677         rm -rf $(TARGET_DIR)/usr/share/gtk-doc
678         rmdir $(TARGET_DIR)/usr/share 2>/dev/null || true
679         $(STRIP_FIND_CMD) | xargs -0 $(STRIPCMD) 2>/dev/null || true
680
681 # See http://sourceware.org/gdb/wiki/FAQ, "GDB does not see any threads
682 # besides the one in which crash occurred; or SIGTRAP kills my program when
683 # I set a breakpoint"
684 ifeq ($(BR2_TOOLCHAIN_HAS_THREADS),y)
685         find $(TARGET_DIR)/lib/ -type f -name 'libpthread*.so*' | \
686                 xargs -r $(STRIPCMD) $(STRIP_STRIP_DEBUG)
687 endif
688
689 # Valgrind needs ld.so with enough information, so only strip
690 # debugging symbols.
691         find $(TARGET_DIR)/lib/ -type f -name 'ld-*.so*' | \
692                 xargs -r $(STRIPCMD) $(STRIP_STRIP_DEBUG)
693         test -f $(TARGET_DIR)/etc/ld.so.conf && \
694                 { echo "ERROR: we shouldn't have a /etc/ld.so.conf file"; exit 1; } || true
695         test -d $(TARGET_DIR)/etc/ld.so.conf.d && \
696                 { echo "ERROR: we shouldn't have a /etc/ld.so.conf.d directory"; exit 1; } || true
697         mkdir -p $(TARGET_DIR)/etc
698         ( \
699                 echo "NAME=Buildroot"; \
700                 echo "VERSION=$(BR2_VERSION_FULL)"; \
701                 echo "ID=buildroot"; \
702                 echo "VERSION_ID=$(BR2_VERSION)"; \
703                 echo "PRETTY_NAME=\"Buildroot $(BR2_VERSION)\"" \
704         ) >  $(TARGET_DIR)/etc/os-release
705
706         @$(foreach d, $(call qstrip,$(BR2_ROOTFS_OVERLAY)), \
707                 $(call MESSAGE,"Copying overlay $(d)"); \
708                 rsync -a --ignore-times --keep-dirlinks $(RSYNC_VCS_EXCLUSIONS) \
709                         --chmod=u=rwX,go=rX --exclude .empty --exclude '*~' \
710                         $(d)/ $(TARGET_DIR)$(sep))
711
712         @$(foreach s, $(call qstrip,$(BR2_ROOTFS_POST_BUILD_SCRIPT)), \
713                 $(call MESSAGE,"Executing post-build script $(s)"); \
714                 $(EXTRA_ENV) $(s) $(TARGET_DIR) $(call qstrip,$(BR2_ROOTFS_POST_SCRIPT_ARGS))$(sep))
715
716 target-post-image: $(TARGETS_ROOTFS) target-finalize
717         @$(foreach s, $(call qstrip,$(BR2_ROOTFS_POST_IMAGE_SCRIPT)), \
718                 $(call MESSAGE,"Executing post-image script $(s)"); \
719                 $(EXTRA_ENV) $(s) $(BINARIES_DIR) $(call qstrip,$(BR2_ROOTFS_POST_SCRIPT_ARGS))$(sep))
720
721 source: $(foreach p,$(PACKAGES),$(p)-all-source)
722
723 _external-deps: $(foreach p,$(PACKAGES),$(p)-all-external-deps)
724 external-deps:
725         @$(MAKE1) -Bs $(EXTRAMAKEARGS) _external-deps | sort -u
726
727 # check if download URLs are outdated
728 source-check: $(foreach p,$(PACKAGES),$(p)-all-source-check)
729
730 legal-info-clean:
731         @rm -fr $(LEGAL_INFO_DIR)
732
733 legal-info-prepare: $(LEGAL_INFO_DIR)
734         @$(call MESSAGE,"Collecting legal info")
735         @$(call legal-license-file,buildroot,COPYING,COPYING,HOST)
736         @$(call legal-manifest,PACKAGE,VERSION,LICENSE,LICENSE FILES,SOURCE ARCHIVE,SOURCE SITE,TARGET)
737         @$(call legal-manifest,PACKAGE,VERSION,LICENSE,LICENSE FILES,SOURCE ARCHIVE,SOURCE SITE,HOST)
738         @$(call legal-manifest,buildroot,$(BR2_VERSION_FULL),GPLv2+,COPYING,not saved,not saved,HOST)
739         @$(call legal-warning,the Buildroot source code has not been saved)
740         @cp $(BR2_CONFIG) $(LEGAL_INFO_DIR)/buildroot.config
741
742 legal-info: dirs legal-info-clean legal-info-prepare $(foreach p,$(PACKAGES),$(p)-all-legal-info) \
743                 $(REDIST_SOURCES_DIR_TARGET) $(REDIST_SOURCES_DIR_HOST)
744         @cat support/legal-info/README.header >>$(LEGAL_REPORT)
745         @if [ -r $(LEGAL_WARNINGS) ]; then \
746                 cat support/legal-info/README.warnings-header \
747                         $(LEGAL_WARNINGS) >>$(LEGAL_REPORT); \
748                 cat $(LEGAL_WARNINGS); fi
749         @rm -f $(LEGAL_WARNINGS)
750         @(cd $(LEGAL_INFO_DIR); \
751                 find * -type f -exec sha256sum {} + | LC_ALL=C sort -k2 \
752                         >.legal-info.sha256; \
753                 mv .legal-info.sha256 legal-info.sha256)
754         @echo "Legal info produced in $(LEGAL_INFO_DIR)"
755
756 show-targets:
757         @echo $(PACKAGES) $(TARGETS_ROOTFS)
758
759 graph-build: $(O)/build/build-time.log
760         @install -d $(GRAPHS_DIR)
761         $(foreach o,name build duration,./support/scripts/graph-build-time \
762                                         --type=histogram --order=$(o) --input=$(<) \
763                                         --output=$(GRAPHS_DIR)/build.hist-$(o).$(BR_GRAPH_OUT) \
764                                         $(if $(BR2_GRAPH_ALT),--alternate-colors)$(sep))
765         $(foreach t,packages steps,./support/scripts/graph-build-time \
766                                    --type=pie-$(t) --input=$(<) \
767                                    --output=$(GRAPHS_DIR)/build.pie-$(t).$(BR_GRAPH_OUT) \
768                                    $(if $(BR2_GRAPH_ALT),--alternate-colors)$(sep))
769
770 graph-depends-requirements:
771         @dot -? >/dev/null 2>&1 || \
772                 { echo "ERROR: The 'dot' program from Graphviz is needed for graph-depends" >&2; exit 1; }
773
774 graph-depends: graph-depends-requirements
775         @$(INSTALL) -d $(GRAPHS_DIR)
776         @cd "$(CONFIG_DIR)"; \
777         $(TOPDIR)/support/scripts/graph-depends $(BR2_GRAPH_DEPS_OPTS) \
778                 --direct -o $(GRAPHS_DIR)/$(@).dot
779         dot $(BR2_GRAPH_DOT_OPTS) -T$(BR_GRAPH_OUT) \
780                 -o $(GRAPHS_DIR)/$(@).$(BR_GRAPH_OUT) \
781                 $(GRAPHS_DIR)/$(@).dot
782
783 graph-size:
784         $(Q)mkdir -p $(GRAPHS_DIR)
785         $(Q)$(TOPDIR)/support/scripts/size-stats --builddir $(BASE_DIR) \
786                 --graph $(GRAPHS_DIR)/graph-size.$(BR_GRAPH_OUT) \
787                 --file-size-csv $(GRAPHS_DIR)/file-size-stats.csv \
788                 --package-size-csv $(GRAPHS_DIR)/package-size-stats.csv
789
790 check-dependencies:
791         @cd "$(CONFIG_DIR)"; \
792         $(TOPDIR)/support/scripts/graph-depends -C
793
794 else # ifeq ($(BR2_HAVE_DOT_CONFIG),y)
795
796 all: menuconfig
797
798 endif # ifeq ($(BR2_HAVE_DOT_CONFIG),y)
799
800 # configuration
801 # ---------------------------------------------------------------------------
802
803 HOSTCFLAGS = $(CFLAGS_FOR_BUILD)
804 export HOSTCFLAGS
805
806 .PHONY: prepare-kconfig
807 prepare-kconfig: outputmakefile $(BUILD_DIR)/.br2-external.in
808
809 $(BUILD_DIR)/buildroot-config/%onf:
810         mkdir -p $(@D)/lxdialog
811         PKG_CONFIG_PATH="$(HOST_PKG_CONFIG_PATH)" $(MAKE) CC="$(HOSTCC_NOCCACHE)" HOSTCC="$(HOSTCC_NOCCACHE)" \
812             obj=$(@D) -C $(CONFIG) -f Makefile.br $(@F)
813
814 DEFCONFIG = $(call qstrip,$(BR2_DEFCONFIG))
815
816 # We don't want to fully expand BR2_DEFCONFIG here, so Kconfig will
817 # recognize that if it's still at its default $(CONFIG_DIR)/defconfig
818 COMMON_CONFIG_ENV = \
819         BR2_DEFCONFIG='$(call qstrip,$(value BR2_DEFCONFIG))' \
820         KCONFIG_AUTOCONFIG=$(BUILD_DIR)/buildroot-config/auto.conf \
821         KCONFIG_AUTOHEADER=$(BUILD_DIR)/buildroot-config/autoconf.h \
822         KCONFIG_TRISTATE=$(BUILD_DIR)/buildroot-config/tristate.config \
823         BR2_CONFIG=$(BR2_CONFIG) \
824         HOST_GCC_VERSION="$(HOSTCC_VERSION)" \
825         BUILD_DIR=$(BUILD_DIR) \
826         SKIP_LEGACY=
827
828 xconfig: $(BUILD_DIR)/buildroot-config/qconf prepare-kconfig
829         @$(COMMON_CONFIG_ENV) $< $(CONFIG_CONFIG_IN)
830
831 gconfig: $(BUILD_DIR)/buildroot-config/gconf prepare-kconfig
832         @$(COMMON_CONFIG_ENV) srctree=$(TOPDIR) $< $(CONFIG_CONFIG_IN)
833
834 menuconfig: $(BUILD_DIR)/buildroot-config/mconf prepare-kconfig
835         @$(COMMON_CONFIG_ENV) $< $(CONFIG_CONFIG_IN)
836
837 nconfig: $(BUILD_DIR)/buildroot-config/nconf prepare-kconfig
838         @$(COMMON_CONFIG_ENV) $< $(CONFIG_CONFIG_IN)
839
840 config: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
841         @$(COMMON_CONFIG_ENV) $< $(CONFIG_CONFIG_IN)
842
843 # For the config targets that automatically select options, we pass
844 # SKIP_LEGACY=y to disable the legacy options. However, in that case
845 # no values are set for the legacy options so a subsequent oldconfig
846 # will query them. Therefore, run an additional olddefconfig.
847
848 oldconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
849         @$(COMMON_CONFIG_ENV) $< --oldconfig $(CONFIG_CONFIG_IN)
850
851 randconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
852         @$(COMMON_CONFIG_ENV) SKIP_LEGACY=y $< --randconfig $(CONFIG_CONFIG_IN)
853         @$(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN) >/dev/null
854
855 allyesconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
856         @$(COMMON_CONFIG_ENV) SKIP_LEGACY=y $< --allyesconfig $(CONFIG_CONFIG_IN)
857         @$(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN) >/dev/null
858
859 allnoconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
860         @$(COMMON_CONFIG_ENV) SKIP_LEGACY=y $< --allnoconfig $(CONFIG_CONFIG_IN)
861         @$(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN) >/dev/null
862
863 randpackageconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
864         @grep -v BR2_PACKAGE_ $(BR2_CONFIG) > $(CONFIG_DIR)/.config.nopkg
865         @$(COMMON_CONFIG_ENV) SKIP_LEGACY=y \
866                 KCONFIG_ALLCONFIG=$(CONFIG_DIR)/.config.nopkg \
867                 $< --randconfig $(CONFIG_CONFIG_IN)
868         @rm -f $(CONFIG_DIR)/.config.nopkg
869         @$(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN) >/dev/null
870
871 allyespackageconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
872         @grep -v BR2_PACKAGE_ $(BR2_CONFIG) > $(CONFIG_DIR)/.config.nopkg
873         @$(COMMON_CONFIG_ENV) SKIP_LEGACY=y \
874                 KCONFIG_ALLCONFIG=$(CONFIG_DIR)/.config.nopkg \
875                 $< --allyesconfig $(CONFIG_CONFIG_IN)
876         @rm -f $(CONFIG_DIR)/.config.nopkg
877         @$(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN) >/dev/null
878
879 allnopackageconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
880         @grep -v BR2_PACKAGE_ $(BR2_CONFIG) > $(CONFIG_DIR)/.config.nopkg
881         @$(COMMON_CONFIG_ENV) SKIP_LEGACY=y \
882                 KCONFIG_ALLCONFIG=$(CONFIG_DIR)/.config.nopkg \
883                 $< --allnoconfig $(CONFIG_CONFIG_IN)
884         @rm -f $(CONFIG_DIR)/.config.nopkg
885         @$(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN) >/dev/null
886
887 silentoldconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
888         $(COMMON_CONFIG_ENV) $< --silentoldconfig $(CONFIG_CONFIG_IN)
889
890 olddefconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
891         $(COMMON_CONFIG_ENV) $< --olddefconfig $(CONFIG_CONFIG_IN)
892
893 defconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
894         @$(COMMON_CONFIG_ENV) $< --defconfig$(if $(DEFCONFIG),=$(DEFCONFIG)) $(CONFIG_CONFIG_IN)
895
896 define percent_defconfig
897 # Override the BR2_DEFCONFIG from COMMON_CONFIG_ENV with the new defconfig
898 %_defconfig: $(BUILD_DIR)/buildroot-config/conf $(1)/configs/%_defconfig prepare-kconfig
899         @$$(COMMON_CONFIG_ENV) BR2_DEFCONFIG=$(1)/configs/$$@ \
900                 $$< --defconfig=$(1)/configs/$$@ $$(CONFIG_CONFIG_IN)
901 endef
902 $(eval $(foreach d,$(call reverse,$(TOPDIR) $(BR2_EXTERNAL_DIRS)),$(call percent_defconfig,$(d))$(sep)))
903
904 savedefconfig: $(BUILD_DIR)/buildroot-config/conf prepare-kconfig
905         @$(COMMON_CONFIG_ENV) $< \
906                 --savedefconfig=$(if $(DEFCONFIG),$(DEFCONFIG),$(CONFIG_DIR)/defconfig) \
907                 $(CONFIG_CONFIG_IN)
908         @$(SED) '/BR2_DEFCONFIG=/d' $(if $(DEFCONFIG),$(DEFCONFIG),$(CONFIG_DIR)/defconfig)
909
910 .PHONY: defconfig savedefconfig
911
912 ################################################################################
913 #
914 # Cleanup and misc junk
915 #
916 ################################################################################
917
918 # outputmakefile generates a Makefile in the output directory, if using a
919 # separate output directory. This allows convenient use of make in the
920 # output directory.
921 outputmakefile:
922 ifeq ($(NEED_WRAPPER),y)
923         $(Q)$(TOPDIR)/support/scripts/mkmakefile $(TOPDIR) $(O)
924 endif
925
926 # Even though the target is a real file, we mark it as PHONY as we
927 # want it to be re-generated each time make is invoked, in case the
928 # value of BR2_EXTERNAL is changed.
929 .PHONY: $(BUILD_DIR)/.br2-external.in
930 $(BUILD_DIR)/.br2-external.in: $(BUILD_DIR)
931         $(Q)support/scripts/br2-external -k -o "$(@)" $(BR2_EXTERNAL)
932
933 # printvars prints all the variables currently defined in our
934 # Makefiles. Alternatively, if a non-empty VARS variable is passed,
935 # only the variables matching the make pattern passed in VARS are
936 # displayed.
937 printvars:
938         @$(foreach V, \
939                 $(sort $(if $(VARS),$(filter $(VARS),$(.VARIABLES)),$(.VARIABLES))), \
940                 $(if $(filter-out environment% default automatic, \
941                                 $(origin $V)), \
942                 $(info $V=$($V) ($(value $V)))))
943
944 clean:
945         rm -rf $(TARGET_DIR) $(BINARIES_DIR) $(HOST_DIR) \
946                 $(BUILD_DIR) $(BASE_DIR)/staging \
947                 $(LEGAL_INFO_DIR) $(GRAPHS_DIR)
948
949 distclean: clean
950 ifeq ($(O),$(CURDIR)/output)
951         rm -rf $(O)
952 endif
953         rm -rf $(TOPDIR)/dl $(BR2_CONFIG) $(CONFIG_DIR)/.config.old $(CONFIG_DIR)/..config.tmp \
954                 $(CONFIG_DIR)/.auto.deps $(BR2_EXTERNAL_FILE)
955
956 help:
957         @echo 'Cleaning:'
958         @echo '  clean                  - delete all files created by build'
959         @echo '  distclean              - delete all non-source files (including .config)'
960         @echo
961         @echo 'Build:'
962         @echo '  all                    - make world'
963         @echo '  toolchain              - build toolchain'
964         @echo
965         @echo 'Configuration:'
966         @echo '  menuconfig             - interactive curses-based configurator'
967         @echo '  nconfig                - interactive ncurses-based configurator'
968         @echo '  xconfig                - interactive Qt-based configurator'
969         @echo '  gconfig                - interactive GTK-based configurator'
970         @echo '  oldconfig              - resolve any unresolved symbols in .config'
971         @echo '  silentoldconfig        - Same as oldconfig, but quietly, additionally update deps'
972         @echo '  olddefconfig           - Same as silentoldconfig but sets new symbols to their default value'
973         @echo '  randconfig             - New config with random answer to all options'
974         @echo '  defconfig              - New config with default answer to all options'
975         @echo '                             BR2_DEFCONFIG, if set, is used as input'
976         @echo '  savedefconfig          - Save current config to BR2_DEFCONFIG (minimal config)'
977         @echo '  allyesconfig           - New config where all options are accepted with yes'
978         @echo '  allnoconfig            - New config where all options are answered with no'
979         @echo '  randpackageconfig      - New config with random answer to package options'
980         @echo '  allyespackageconfig    - New config where pkg options are accepted with yes'
981         @echo '  allnopackageconfig     - New config where package options are answered with no'
982         @echo
983         @echo 'Package-specific:'
984         @echo '  <pkg>                  - Build and install <pkg> and all its dependencies'
985         @echo '  <pkg>-source           - Only download the source files for <pkg>'
986         @echo '  <pkg>-extract          - Extract <pkg> sources'
987         @echo '  <pkg>-patch            - Apply patches to <pkg>'
988         @echo '  <pkg>-depends          - Build <pkg>'\''s dependencies'
989         @echo '  <pkg>-configure        - Build <pkg> up to the configure step'
990         @echo '  <pkg>-build            - Build <pkg> up to the build step'
991         @echo '  <pkg>-show-depends     - List packages on which <pkg> depends'
992         @echo '  <pkg>-show-rdepends    - List packages which have <pkg> as a dependency'
993         @echo '  <pkg>-graph-depends    - Generate a graph of <pkg>'\''s dependencies'
994         @echo '  <pkg>-graph-rdepends   - Generate a graph of <pkg>'\''s reverse dependencies'
995         @echo '  <pkg>-dirclean         - Remove <pkg> build directory'
996         @echo '  <pkg>-reconfigure      - Restart the build from the configure step'
997         @echo '  <pkg>-rebuild          - Restart the build from the build step'
998         $(foreach p,$(HELP_PACKAGES), \
999                 @echo $(sep) \
1000                 @echo '$($(p)_NAME):' $(sep) \
1001                 $($(p)_HELP_CMDS)$(sep))
1002         @echo
1003         @echo 'Documentation:'
1004         @echo '  manual                 - build manual in all formats'
1005         @echo '  manual-html            - build manual in HTML'
1006         @echo '  manual-split-html      - build manual in split HTML'
1007         @echo '  manual-pdf             - build manual in PDF'
1008         @echo '  manual-text            - build manual in text'
1009         @echo '  manual-epub            - build manual in ePub'
1010         @echo '  graph-build            - generate graphs of the build times'
1011         @echo '  graph-depends          - generate graph of the dependency tree'
1012         @echo '  graph-size             - generate stats of the filesystem size'
1013         @echo '  list-defconfigs        - list all defconfigs (pre-configured minimal systems)'
1014         @echo
1015         @echo 'Miscellaneous:'
1016         @echo '  source                 - download all sources needed for offline-build'
1017         @echo '  source-check           - check selected packages for valid download URLs'
1018         @echo '  external-deps          - list external packages used'
1019         @echo '  legal-info             - generate info about license compliance'
1020         @echo
1021         @echo '  make V=0|1             - 0 => quiet build (default), 1 => verbose build'
1022         @echo '  make O=dir             - Locate all output files in "dir", including .config'
1023         @echo
1024         @echo 'For further details, see README, generate the Buildroot manual, or consult'
1025         @echo 'it on-line at http://buildroot.org/docs.html'
1026         @echo
1027
1028 # List the defconfig files
1029 # $(1): base directory
1030 # $(2): br2-external name, empty for bundled
1031 define list-defconfigs
1032         @first=true; \
1033         for defconfig in $(1)/configs/*_defconfig; do \
1034                 [ -f "$${defconfig}" ] || continue; \
1035                 if $${first}; then \
1036                         if [ "$(2)" ]; then \
1037                                 printf 'External configs in "$(call qstrip,$(2))":\n'; \
1038                         else \
1039                                 printf "Built-in configs:\n"; \
1040                         fi; \
1041                         first=false; \
1042                 fi; \
1043                 defconfig="$${defconfig##*/}"; \
1044                 printf "  %-35s - Build for %s\n" "$${defconfig}" "$${defconfig%_defconfig}"; \
1045         done; \
1046         $${first} || printf "\n"
1047 endef
1048
1049 # We iterate over BR2_EXTERNAL_NAMES rather than BR2_EXTERNAL_DIRS,
1050 # because we want to display the name of the br2-external tree.
1051 list-defconfigs:
1052         $(call list-defconfigs,$(TOPDIR))
1053         $(foreach name,$(BR2_EXTERNAL_NAMES),\
1054                 $(call list-defconfigs,$(BR2_EXTERNAL_$(name)_PATH),\
1055                         $(BR2_EXTERNAL_$(name)_DESC))$(sep))
1056
1057 release: OUT = buildroot-$(BR2_VERSION)
1058
1059 # Create release tarballs. We need to fiddle a bit to add the generated
1060 # documentation to the git output
1061 release:
1062         git archive --format=tar --prefix=$(OUT)/ HEAD > $(OUT).tar
1063         $(MAKE) O=$(OUT) manual-html manual-text manual-pdf
1064         $(MAKE) O=$(OUT) manual-clean
1065         tar rf $(OUT).tar $(OUT)
1066         gzip -9 -c < $(OUT).tar > $(OUT).tar.gz
1067         bzip2 -9 -c < $(OUT).tar > $(OUT).tar.bz2
1068         rm -rf $(OUT) $(OUT).tar
1069
1070 print-version:
1071         @echo $(BR2_VERSION_FULL)
1072
1073 include docs/manual/manual.mk
1074 -include $(foreach dir,$(BR2_EXTERNAL_DIRS),$(sort $(wildcard $(dir)/docs/*/*.mk)))
1075
1076 .PHONY: $(noconfig_targets)
1077
1078 endif #umask / $(CURDIR) / $(O)