Makefile 56 KB
Newer Older
Linus Torvalds's avatar
Linus Torvalds committed
1
VERSION = 4
Linus Torvalds's avatar
Linus Torvalds committed
2
PATCHLEVEL = 6
Linus Torvalds's avatar
Linus Torvalds committed
3
SUBLEVEL = 0
Linus Torvalds's avatar
Linus Torvalds committed
4
EXTRAVERSION =
Linus Torvalds's avatar
Linus Torvalds committed
5
NAME = Charred Weasel
Linus Torvalds's avatar
Linus Torvalds committed
6 7 8 9 10 11 12

# *DOCUMENTATION*
# To see a list of typical targets execute "make help"
# More info can be located in ./README
# Comments in this file are targeted only to the developer, do not
# expect to learn how to build the kernel reading this file.

13 14 15 16
# o Do not use make's built-in rules and variables
#   (this increases performance and avoids hard-to-debug behaviour);
# o Look for make include files relative to root of kernel src
MAKEFLAGS += -rR --include-dir=$(CURDIR)
Linus Torvalds's avatar
Linus Torvalds committed
17

18
# Avoid funny character set dependencies
19
unexport LC_ALL
20 21
LC_COLLATE=C
LC_NUMERIC=C
22
export LC_COLLATE LC_NUMERIC
23

24 25 26
# Avoid interference with shell env settings
unexport GREP_OPTIONS

Linus Torvalds's avatar
Linus Torvalds committed
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
# We are using a recursive build, so we need to do a little thinking
# to get the ordering right.
#
# Most importantly: sub-Makefiles should only ever modify files in
# their own directory. If in some directory we have a dependency on
# a file in another dir (which doesn't happen often, but it's often
# unavoidable when linking the built-in.o targets which finally
# turn into vmlinux), we will call a sub make in that other dir, and
# after that we are sure that everything which is in that other dir
# is now up to date.
#
# The only cases where we need to modify files which have global
# effects are thus separated out and done before the recursive
# descending is started. They are now explicitly listed as the
# prepare rule.

43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
# Beautify output
# ---------------------------------------------------------------------------
#
# Normally, we echo the whole command before executing it. By making
# that echo $($(quiet)$(cmd)), we now have the possibility to set
# $(quiet) to choose other forms of output instead, e.g.
#
#         quiet_cmd_cc_o_c = Compiling $(RELDIR)/$@
#         cmd_cc_o_c       = $(CC) $(c_flags) -c -o $@ $<
#
# If $(quiet) is empty, the whole command will be printed.
# If it is set to "quiet_", only the short version will be printed.
# If it is set to "silent_", nothing will be printed at all, since
# the variable $(silent_cmd_cc_o_c) doesn't exist.
#
# A simple variant is to prefix commands with $(Q) - that's useful
# for commands that shall be hidden in non-verbose mode.
#
#	$(Q)ln $@ :<
#
# If KBUILD_VERBOSE equals 0 then the above command will be hidden.
# If KBUILD_VERBOSE equals 1 then the above command is displayed.
#
Linus Torvalds's avatar
Linus Torvalds committed
66 67 68
# To put more focus on warnings, be less verbose as default
# Use 'make V=1' to see the full commands

69 70
ifeq ("$(origin V)", "command line")
  KBUILD_VERBOSE = $(V)
Linus Torvalds's avatar
Linus Torvalds committed
71 72 73 74 75
endif
ifndef KBUILD_VERBOSE
  KBUILD_VERBOSE = 0
endif

76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
ifeq ($(KBUILD_VERBOSE),1)
  quiet =
  Q =
else
  quiet=quiet_
  Q = @
endif

# If the user is running make -s (silent mode), suppress echoing of
# commands

ifneq ($(filter 4.%,$(MAKE_VERSION)),)	# make-4
ifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),)
  quiet=silent_
endif
else					# make-3.8x
ifneq ($(filter s% -s%,$(MAKEFLAGS)),)
  quiet=silent_
endif
endif

export quiet Q KBUILD_VERBOSE

Linus Torvalds's avatar
Linus Torvalds committed
99 100 101 102 103
# kbuild supports saving output files in a separate directory.
# To locate output files in a separate directory two syntaxes are supported.
# In both cases the working directory must be the root of the kernel src.
# 1) O=
# Use "make O=dir/to/store/output/files/"
104
#
Linus Torvalds's avatar
Linus Torvalds committed
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
# 2) Set KBUILD_OUTPUT
# Set the environment variable KBUILD_OUTPUT to point to the directory
# where the output files shall be placed.
# export KBUILD_OUTPUT=dir/to/store/output/files/
# make
#
# The O= assignment takes precedence over the KBUILD_OUTPUT environment
# variable.

# KBUILD_SRC is set on invocation of make in OBJ directory
# KBUILD_SRC is not intended to be used by the regular user (for now)
ifeq ($(KBUILD_SRC),)

# OK, Make called in directory where kernel src resides
# Do we want to locate output files in a separate directory?
120 121
ifeq ("$(origin O)", "command line")
  KBUILD_OUTPUT := $(O)
Linus Torvalds's avatar
Linus Torvalds committed
122 123 124
endif

# That's our default target when none is given on the command line
125
PHONY := _all
Linus Torvalds's avatar
Linus Torvalds committed
126 127
_all:

128 129 130
# Cancel implicit rules on top Makefile
$(CURDIR)/Makefile Makefile: ;

131 132 133 134
ifneq ($(words $(subst :, ,$(CURDIR))), 1)
  $(error main directory cannot contain spaces nor colons)
endif

Linus Torvalds's avatar
Linus Torvalds committed
135 136 137 138
ifneq ($(KBUILD_OUTPUT),)
# Invoke a second make in the output directory, passing relevant variables
# check that the output directory actually exists
saved-output := $(KBUILD_OUTPUT)
139 140
KBUILD_OUTPUT := $(shell mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) \
								&& /bin/pwd)
Linus Torvalds's avatar
Linus Torvalds committed
141
$(if $(KBUILD_OUTPUT),, \
142
     $(error failed to create output directory "$(saved-output)"))
Linus Torvalds's avatar
Linus Torvalds committed
143

144 145
PHONY += $(MAKECMDGOALS) sub-make

146
$(filter-out _all sub-make $(CURDIR)/Makefile, $(MAKECMDGOALS)) _all: sub-make
147
	@:
148

149
sub-make:
150
	$(Q)$(MAKE) -C $(KBUILD_OUTPUT) KBUILD_SRC=$(CURDIR) \
151
	-f $(CURDIR)/Makefile $(filter-out _all sub-make,$(MAKECMDGOALS))
Linus Torvalds's avatar
Linus Torvalds committed
152 153 154 155 156 157 158 159 160

# Leave processing to above invocation of make
skip-makefile := 1
endif # ifneq ($(KBUILD_OUTPUT),)
endif # ifeq ($(KBUILD_SRC),)

# We process the rest of the Makefile if this is the final invocation of make
ifeq ($(skip-makefile),)

161 162 163 164 165
# Do not print "Entering directory ...",
# but we want to display it when entering to the output directory
# so that IDEs/editors are able to understand relative filenames.
MAKEFLAGS += --no-print-directory

166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193
# Call a source code checker (by default, "sparse") as part of the
# C compilation.
#
# Use 'make C=1' to enable checking of only re-compiled files.
# Use 'make C=2' to enable checking of *all* source files, regardless
# of whether they are re-compiled or not.
#
# See the file "Documentation/sparse.txt" for more details, including
# where to get the "sparse" utility.

ifeq ("$(origin C)", "command line")
  KBUILD_CHECKSRC = $(C)
endif
ifndef KBUILD_CHECKSRC
  KBUILD_CHECKSRC = 0
endif

# Use make M=dir to specify directory of external module to build
# Old syntax make ... SUBDIRS=$PWD is still supported
# Setting the environment variable KBUILD_EXTMOD take precedence
ifdef SUBDIRS
  KBUILD_EXTMOD ?= $(SUBDIRS)
endif

ifeq ("$(origin M)", "command line")
  KBUILD_EXTMOD := $(M)
endif

Linus Torvalds's avatar
Linus Torvalds committed
194 195
# If building an external module we do not care about the all: rule
# but instead _all depend on modules
196
PHONY += all
Linus Torvalds's avatar
Linus Torvalds committed
197 198 199 200 201 202
ifeq ($(KBUILD_EXTMOD),)
_all: all
else
_all: modules
endif

203 204 205 206 207 208 209 210 211 212 213
ifeq ($(KBUILD_SRC),)
        # building in the source tree
        srctree := .
else
        ifeq ($(KBUILD_SRC)/,$(dir $(CURDIR)))
                # building in a subdirectory of the source tree
                srctree := ..
        else
                srctree := $(KBUILD_SRC)
        endif
endif
214
objtree		:= .
Linus Torvalds's avatar
Linus Torvalds committed
215 216 217
src		:= $(srctree)
obj		:= $(objtree)

218
VPATH		:= $(srctree)$(if $(KBUILD_EXTMOD),:$(KBUILD_EXTMOD))
Linus Torvalds's avatar
Linus Torvalds committed
219

220
export srctree objtree VPATH
Linus Torvalds's avatar
Linus Torvalds committed
221 222 223 224

# SUBARCH tells the usermode build what the underlying arch is.  That is set
# first, and if a usermode build is happening, the "ARCH=um" on the command
# line overrides the setting of ARCH below.  If a native build is happening,
225
# then ARCH is assigned, getting whatever value it gets normally, and
Linus Torvalds's avatar
Linus Torvalds committed
226 227
# SUBARCH is subsequently ignored.

228 229
SUBARCH := $(shell uname -m | sed -e s/i.86/x86/ -e s/x86_64/x86/ \
				  -e s/sun4u/sparc64/ \
Linus Torvalds's avatar
Linus Torvalds committed
230
				  -e s/arm.*/arm/ -e s/sa110/arm/ \
231
				  -e s/s390x/s390/ -e s/parisc64/parisc/ \
Paul Mundt's avatar
Paul Mundt committed
232
				  -e s/ppc.*/powerpc/ -e s/mips.*/mips/ \
233
				  -e s/sh[234].*/sh/ -e s/aarch64.*/arm64/ )
Linus Torvalds's avatar
Linus Torvalds committed
234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250

# Cross compiling and selecting different set of gcc/bin-utils
# ---------------------------------------------------------------------------
#
# When performing cross compilation for other architectures ARCH shall be set
# to the target architecture. (See arch/* for the possibilities).
# ARCH can be set during invocation of make:
# make ARCH=ia64
# Another way is to have ARCH set in the environment.
# The default ARCH is the host where make is executed.

# CROSS_COMPILE specify the prefix used for all executables used
# during compilation. Only gcc and related bin-utils executables
# are prefixed with $(CROSS_COMPILE).
# CROSS_COMPILE can be set on the command line
# make CROSS_COMPILE=ia64-linux-
# Alternatively CROSS_COMPILE can be set in the environment.
251 252
# A third alternative is to store a setting in .config so that plain
# "make" in the configured kernel build directory always uses that.
Linus Torvalds's avatar
Linus Torvalds committed
253 254
# Default value for CROSS_COMPILE is not to prefix executables
# Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile
255
ARCH		?= $(SUBARCH)
256
CROSS_COMPILE	?= $(CONFIG_CROSS_COMPILE:"%"=%)
Linus Torvalds's avatar
Linus Torvalds committed
257 258

# Architecture as present in compile.h
259 260
UTS_MACHINE 	:= $(ARCH)
SRCARCH 	:= $(ARCH)
Linus Torvalds's avatar
Linus Torvalds committed
261

262 263 264 265 266 267 268
# Additional ARCH settings for x86
ifeq ($(ARCH),i386)
        SRCARCH := x86
endif
ifeq ($(ARCH),x86_64)
        SRCARCH := x86
endif
269

Sam Ravnborg's avatar
Sam Ravnborg committed
270
# Additional ARCH settings for sparc
271 272 273
ifeq ($(ARCH),sparc32)
       SRCARCH := sparc
endif
274
ifeq ($(ARCH),sparc64)
Sam Ravnborg's avatar
Sam Ravnborg committed
275
       SRCARCH := sparc
276
endif
277

278 279 280 281 282
# Additional ARCH settings for sh
ifeq ($(ARCH),sh64)
       SRCARCH := sh
endif

283
# Additional ARCH settings for tile
284 285 286
ifeq ($(ARCH),tilepro)
       SRCARCH := tile
endif
287 288 289 290
ifeq ($(ARCH),tilegx)
       SRCARCH := tile
endif

Sam Ravnborg's avatar
Sam Ravnborg committed
291 292 293
# Where to locate arch specific headers
hdr-arch  := $(SRCARCH)

294
KCONFIG_CONFIG	?= .config
295
export KCONFIG_CONFIG
296

Linus Torvalds's avatar
Linus Torvalds committed
297 298 299 300 301
# SHELL used by kbuild
CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
	  else if [ -x /bin/bash ]; then echo /bin/bash; \
	  else echo sh; fi ; fi)

302 303
HOSTCC       = gcc
HOSTCXX      = g++
304
HOSTCFLAGS   = -Wall -Wmissing-prototypes -Wstrict-prototypes -O2 -fomit-frame-pointer -std=gnu89
305
HOSTCXXFLAGS = -O2
Linus Torvalds's avatar
Linus Torvalds committed
306

307 308 309 310 311
ifeq ($(shell $(HOSTCC) -v 2>&1 | grep -c "clang version"), 1)
HOSTCFLAGS  += -Wno-unused-value -Wno-unused-parameter \
		-Wno-missing-field-initializers -fno-delete-null-pointer-checks
endif

312 313
# Decide whether to build built-in, modular, or both.
# Normally, just do built-in.
Linus Torvalds's avatar
Linus Torvalds committed
314 315 316 317

KBUILD_MODULES :=
KBUILD_BUILTIN := 1

318 319 320 321
# If we have only "make modules", don't compile built-in objects.
# When we're building modules with modversions, we need to consider
# the built-in objects during the descend as well, in order to
# make sure the checksums are up to date before we record them.
Linus Torvalds's avatar
Linus Torvalds committed
322 323 324 325 326

ifeq ($(MAKECMDGOALS),modules)
  KBUILD_BUILTIN := $(if $(CONFIG_MODVERSIONS),1)
endif

327 328 329
# If we have "make <whatever> modules", compile modules
# in addition to whatever we do anyway.
# Just "make" or "make all" shall build modules as well
Linus Torvalds's avatar
Linus Torvalds committed
330 331 332 333 334 335 336 337 338

ifneq ($(filter all _all modules,$(MAKECMDGOALS)),)
  KBUILD_MODULES := 1
endif

ifeq ($(MAKECMDGOALS),)
  KBUILD_MODULES := 1
endif

339
export KBUILD_MODULES KBUILD_BUILTIN
Linus Torvalds's avatar
Linus Torvalds committed
340 341
export KBUILD_CHECKSRC KBUILD_SRC KBUILD_EXTMOD

342
# We need some generic definitions (do not try to remake the file).
343 344
scripts/Kbuild.include: ;
include scripts/Kbuild.include
Linus Torvalds's avatar
Linus Torvalds committed
345 346 347 348 349 350 351 352 353 354 355 356 357

# Make variables (CC, etc...)
AS		= $(CROSS_COMPILE)as
LD		= $(CROSS_COMPILE)ld
CC		= $(CROSS_COMPILE)gcc
CPP		= $(CC) -E
AR		= $(CROSS_COMPILE)ar
NM		= $(CROSS_COMPILE)nm
STRIP		= $(CROSS_COMPILE)strip
OBJCOPY		= $(CROSS_COMPILE)objcopy
OBJDUMP		= $(CROSS_COMPILE)objdump
AWK		= awk
GENKSYMS	= scripts/genksyms/genksyms
358
INSTALLKERNEL  := installkernel
Linus Torvalds's avatar
Linus Torvalds committed
359 360
DEPMOD		= /sbin/depmod
PERL		= perl
361
PYTHON		= python
Linus Torvalds's avatar
Linus Torvalds committed
362 363
CHECK		= sparse

364 365
CHECKFLAGS     := -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ \
		  -Wbitwise -Wno-return-void $(CF)
366 367 368
CFLAGS_MODULE   =
AFLAGS_MODULE   =
LDFLAGS_MODULE  =
Linus Torvalds's avatar
Linus Torvalds committed
369 370
CFLAGS_KERNEL	=
AFLAGS_KERNEL	=
371
CFLAGS_GCOV	= -fprofile-arcs -ftest-coverage -fno-tree-loop-im -Wno-maybe-uninitialized
372
CFLAGS_KCOV	= -fsanitize-coverage=trace-pc
Linus Torvalds's avatar
Linus Torvalds committed
373 374


375 376 377 378 379 380 381 382
# Use USERINCLUDE when you must reference the UAPI directories only.
USERINCLUDE    := \
		-I$(srctree)/arch/$(hdr-arch)/include/uapi \
		-Iarch/$(hdr-arch)/include/generated/uapi \
		-I$(srctree)/include/uapi \
		-Iinclude/generated/uapi \
                -include $(srctree)/include/linux/kconfig.h

Linus Torvalds's avatar
Linus Torvalds committed
383 384
# Use LINUXINCLUDE when you must reference the include/ directory.
# Needed to be compatible with the O= option
385 386
LINUXINCLUDE    := \
		-I$(srctree)/arch/$(hdr-arch)/include \
387
		-Iarch/$(hdr-arch)/include/generated/uapi \
388 389 390 391
		-Iarch/$(hdr-arch)/include/generated \
		$(if $(KBUILD_SRC), -I$(srctree)/include) \
		-Iinclude \
		$(USERINCLUDE)
Linus Torvalds's avatar
Linus Torvalds committed
392

393
KBUILD_CPPFLAGS := -D__KERNEL__
Linus Torvalds's avatar
Linus Torvalds committed
394

395
KBUILD_CFLAGS   := -Wall -Wundef -Wstrict-prototypes -Wno-trigraphs \
396
		   -fno-strict-aliasing -fno-common \
397
		   -Werror-implicit-function-declaration \
398 399
		   -Wno-format-security \
		   -std=gnu89
400

401 402
KBUILD_AFLAGS_KERNEL :=
KBUILD_CFLAGS_KERNEL :=
403
KBUILD_AFLAGS   := -D__ASSEMBLY__
404 405 406
KBUILD_AFLAGS_MODULE  := -DMODULE
KBUILD_CFLAGS_MODULE  := -DMODULE
KBUILD_LDFLAGS_MODULE := -T $(srctree)/scripts/module-common.lds
Linus Torvalds's avatar
Linus Torvalds committed
407

Roman Zippel's avatar
Roman Zippel committed
408 409
# Read KERNELRELEASE from include/config/kernel.release (if it exists)
KERNELRELEASE = $(shell cat include/config/kernel.release 2> /dev/null)
410
KERNELVERSION = $(VERSION)$(if $(PATCHLEVEL),.$(PATCHLEVEL)$(if $(SUBLEVEL),.$(SUBLEVEL)))$(EXTRAVERSION)
411

412
export VERSION PATCHLEVEL SUBLEVEL KERNELRELEASE KERNELVERSION
413
export ARCH SRCARCH CONFIG_SHELL HOSTCC HOSTCFLAGS CROSS_COMPILE AS LD CC
414
export CPP AR NM STRIP OBJCOPY OBJDUMP
415
export MAKE AWK GENKSYMS INSTALLKERNEL PERL PYTHON UTS_MACHINE
416
export HOSTCXX HOSTCXXFLAGS LDFLAGS_MODULE CHECK CHECKFLAGS
Linus Torvalds's avatar
Linus Torvalds committed
417

418
export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINCLUDE OBJCOPYFLAGS LDFLAGS
419
export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE CFLAGS_GCOV CFLAGS_KCOV CFLAGS_KASAN CFLAGS_UBSAN
420
export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE
421
export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE
422
export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
423
export KBUILD_ARFLAGS
Linus Torvalds's avatar
Linus Torvalds committed
424 425 426 427 428 429 430 431

# When compiling out-of-tree modules, put MODVERDIR in the module
# tree rather than in the kernel tree. The kernel tree might
# even be read-only.
export MODVERDIR := $(if $(KBUILD_EXTMOD),$(firstword $(KBUILD_EXTMOD))/).tmp_versions

# Files to ignore in find ... statements

432 433 434
export RCS_FIND_IGNORE := \( -name SCCS -o -name BitKeeper -o -name .svn -o    \
			  -name CVS -o -name .pc -o -name .hg -o -name .git \) \
			  -prune -o
435 436
export RCS_TAR_IGNORE := --exclude SCCS --exclude BitKeeper --exclude .svn \
			 --exclude CVS --exclude .pc --exclude .hg --exclude .git
Linus Torvalds's avatar
Linus Torvalds committed
437 438 439 440 441

# ===========================================================================
# Rules shared between *config targets and build targets

# Basic helpers built in scripts/
442
PHONY += scripts_basic
Linus Torvalds's avatar
Linus Torvalds committed
443 444
scripts_basic:
	$(Q)$(MAKE) $(build)=scripts/basic
445
	$(Q)rm -f .tmp_quiet_recordmcount
Linus Torvalds's avatar
Linus Torvalds committed
446

447 448 449
# To avoid any implicit rule to kick in, define an empty command.
scripts/basic/%: scripts_basic ;

450
PHONY += outputmakefile
451 452 453
# outputmakefile generates a Makefile in the output directory, if using a
# separate output directory. This allows convenient use of make in the
# output directory.
Linus Torvalds's avatar
Linus Torvalds committed
454
outputmakefile:
455
ifneq ($(KBUILD_SRC),)
456
	$(Q)ln -fsn $(srctree) source
457 458 459
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/mkmakefile \
	    $(srctree) $(objtree) $(VERSION) $(PATCHLEVEL)
endif
Linus Torvalds's avatar
Linus Torvalds committed
460

Sam Ravnborg's avatar
Sam Ravnborg committed
461 462 463 464
# Support for using generic headers in asm-generic
PHONY += asm-generic
asm-generic:
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.asm-generic \
465 466 467
	            src=asm obj=arch/$(SRCARCH)/include/generated/asm
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.asm-generic \
	            src=uapi/asm obj=arch/$(SRCARCH)/include/generated/uapi/asm
Sam Ravnborg's avatar
Sam Ravnborg committed
468

Linus Torvalds's avatar
Linus Torvalds committed
469 470 471 472
# To make sure we do not include .config for any of the *config targets
# catch them early, and hand them over to scripts/kconfig/Makefile
# It is allowed to specify more targets when calling make, including
# mixing *config targets and build targets.
473
# For example 'make oldconfig all'.
Linus Torvalds's avatar
Linus Torvalds committed
474 475 476
# Detect when mixed targets is specified, and make a second invocation
# of make so .config is not included in this case either (for *config).

477
version_h := include/generated/uapi/linux/version.h
478
old_version_h := include/linux/version.h
David Howells's avatar
David Howells committed
479

480
no-dot-config-targets := clean mrproper distclean \
481
			 cscope gtags TAGS tags help% %docs check% coccicheck \
David Howells's avatar
David Howells committed
482
			 $(version_h) headers_% archheaders archscripts \
483
			 kernelversion %src-pkg
Linus Torvalds's avatar
Linus Torvalds committed
484 485 486 487 488 489 490 491 492 493 494 495 496 497

config-targets := 0
mixed-targets  := 0
dot-config     := 1

ifneq ($(filter $(no-dot-config-targets), $(MAKECMDGOALS)),)
	ifeq ($(filter-out $(no-dot-config-targets), $(MAKECMDGOALS)),)
		dot-config := 0
	endif
endif

ifeq ($(KBUILD_EXTMOD),)
        ifneq ($(filter config %config,$(MAKECMDGOALS)),)
                config-targets := 1
498
                ifneq ($(words $(MAKECMDGOALS)),1)
Linus Torvalds's avatar
Linus Torvalds committed
499 500 501 502
                        mixed-targets := 1
                endif
        endif
endif
503 504 505 506 507 508
# install and module_install need also be processed one by one
ifneq ($(filter install,$(MAKECMDGOALS)),)
        ifneq ($(filter modules_install,$(MAKECMDGOALS)),)
	        mixed-targets := 1
        endif
endif
Linus Torvalds's avatar
Linus Torvalds committed
509 510 511 512 513 514

ifeq ($(mixed-targets),1)
# ===========================================================================
# We're called with mixed targets (*config and build targets).
# Handle them one by one.

515 516 517 518 519 520 521 522 523 524
PHONY += $(MAKECMDGOALS) __build_one_by_one

$(filter-out __build_one_by_one, $(MAKECMDGOALS)): __build_one_by_one
	@:

__build_one_by_one:
	$(Q)set -e; \
	for i in $(MAKECMDGOALS); do \
		$(MAKE) -f $(srctree)/Makefile $$i; \
	done
Linus Torvalds's avatar
Linus Torvalds committed
525 526 527 528 529 530 531 532 533 534

else
ifeq ($(config-targets),1)
# ===========================================================================
# *config targets only - make sure prerequisites are updated, and descend
# in scripts/kconfig to make the *config target

# Read arch specific Makefile to set KBUILD_DEFCONFIG as needed.
# KBUILD_DEFCONFIG may point out an alternative default configuration
# used for 'make defconfig'
535
include arch/$(SRCARCH)/Makefile
536
export KBUILD_DEFCONFIG KBUILD_KCONFIG
Linus Torvalds's avatar
Linus Torvalds committed
537

538 539 540 541
config: scripts_basic outputmakefile FORCE
	$(Q)$(MAKE) $(build)=scripts/kconfig $@

%config: scripts_basic outputmakefile FORCE
Linus Torvalds's avatar
Linus Torvalds committed
542 543 544 545 546 547 548 549 550 551
	$(Q)$(MAKE) $(build)=scripts/kconfig $@

else
# ===========================================================================
# Build targets only - this includes vmlinux, arch specific targets, clean
# targets and others. In general all targets except *config targets.

ifeq ($(KBUILD_EXTMOD),)
# Additional helpers built in scripts/
# Carefully list dependencies so we do not try to build scripts twice
552
# in parallel
553
PHONY += scripts
554 555
scripts: scripts_basic include/config/auto.conf include/config/tristate.conf \
	 asm-generic
Linus Torvalds's avatar
Linus Torvalds committed
556 557 558 559
	$(Q)$(MAKE) $(build)=$(@)

# Objects we will link into vmlinux / subdirs we need to visit
init-y		:= init/
560
drivers-y	:= drivers/ sound/ firmware/
Linus Torvalds's avatar
Linus Torvalds committed
561 562 563
net-y		:= net/
libs-y		:= lib/
core-y		:= usr/
564
virt-y		:= virt/
Linus Torvalds's avatar
Linus Torvalds committed
565 566 567
endif # KBUILD_EXTMOD

ifeq ($(dot-config),1)
568 569
# Read in config
-include include/config/auto.conf
Linus Torvalds's avatar
Linus Torvalds committed
570

571
ifeq ($(KBUILD_EXTMOD),)
Linus Torvalds's avatar
Linus Torvalds committed
572 573
# Read in dependencies to all Kconfig* files, make sure to run
# oldconfig if changes are detected.
574
-include include/config/auto.conf.cmd
Linus Torvalds's avatar
Linus Torvalds committed
575 576

# To avoid any implicit rule to kick in, define an empty command
577
$(KCONFIG_CONFIG) include/config/auto.conf.cmd: ;
Linus Torvalds's avatar
Linus Torvalds committed
578

579
# If .config is newer than include/config/auto.conf, someone tinkered
580
# with it and forgot to run make oldconfig.
581
# if auto.conf.cmd is missing then we are probably in a cleaned tree so
582
# we execute the config step to be sure to catch updated Kconfig files
583
include/config/%.conf: $(KCONFIG_CONFIG) include/config/auto.conf.cmd
Linus Torvalds's avatar
Linus Torvalds committed
584
	$(Q)$(MAKE) -f $(srctree)/Makefile silentoldconfig
585
else
586
# external modules needs include/generated/autoconf.h and include/config/auto.conf
587 588 589 590
# but do not care if they are up-to-date. Use auto.conf to trigger the test
PHONY += include/config/auto.conf

include/config/auto.conf:
591
	$(Q)test -e include/generated/autoconf.h -a -e $@ || (		\
592 593 594 595 596
	echo >&2;							\
	echo >&2 "  ERROR: Kernel configuration is invalid.";		\
	echo >&2 "         include/generated/autoconf.h or $@ are missing.";\
	echo >&2 "         Run 'make oldconfig && make prepare' on kernel src to fix it.";	\
	echo >&2 ;							\
597 598 599
	/bin/false)

endif # KBUILD_EXTMOD
600

Linus Torvalds's avatar
Linus Torvalds committed
601 602
else
# Dummy target needed, because used as prerequisite
603
include/config/auto.conf: ;
604
endif # $(dot-config)
Linus Torvalds's avatar
Linus Torvalds committed
605 606 607 608

# The all: target is the default when no target is given on the
# command line.
# This allow a user to issue only 'make' to build a kernel including modules
Michal Marek's avatar
Michal Marek committed
609
# Defaults to vmlinux, but the arch makefile usually adds further targets
Linus Torvalds's avatar
Linus Torvalds committed
610 611
all: vmlinux

612 613 614 615 616
# The arch Makefile can set ARCH_{CPP,A,C}FLAGS to override the default
# values of the respective KBUILD_* variables
ARCH_CPPFLAGS :=
ARCH_AFLAGS :=
ARCH_CFLAGS :=
617
include arch/$(SRCARCH)/Makefile
618 619 620

KBUILD_CFLAGS	+= $(call cc-option,-fno-delete-null-pointer-checks,)

Linus Torvalds's avatar
Linus Torvalds committed
621
ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
622
KBUILD_CFLAGS	+= -Os $(call cc-disable-warning,maybe-uninitialized,)
Linus Torvalds's avatar
Linus Torvalds committed
623
else
624 625 626 627 628
ifdef CONFIG_PROFILE_ALL_BRANCHES
KBUILD_CFLAGS	+= -O2 $(call cc-disable-warning,maybe-uninitialized,)
else
KBUILD_CFLAGS   += -O2
endif
Linus Torvalds's avatar
Linus Torvalds committed
629 630
endif

631 632 633
# Tell gcc to never replace conditional load with a non-conditional one
KBUILD_CFLAGS	+= $(call cc-option,--param=allow-store-data-races=0)

Andi Kleen's avatar
Andi Kleen committed
634 635 636 637 638 639 640 641 642 643
ifdef CONFIG_READABLE_ASM
# Disable optimizations that make assembler listings hard to read.
# reorder blocks reorders the control in the function
# ipa clone creates specialized cloned functions
# partial inlining inlines only parts of functions
KBUILD_CFLAGS += $(call cc-option,-fno-reorder-blocks,) \
                 $(call cc-option,-fno-ipa-cp-clone,) \
                 $(call cc-option,-fno-partial-inlining)
endif

644
ifneq ($(CONFIG_FRAME_WARN),0)
645 646 647
KBUILD_CFLAGS += $(call cc-option,-Wframe-larger-than=${CONFIG_FRAME_WARN})
endif

648
# Handle stack protector mode.
649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664
#
# Since kbuild can potentially perform two passes (first with the old
# .config values and then with updated .config values), we cannot error out
# if a desired compiler option is unsupported. If we were to error, kbuild
# could never get to the second pass and actually notice that we changed
# the option to something that was supported.
#
# Additionally, we don't want to fallback and/or silently change which compiler
# flags will be used, since that leads to producing kernels with different
# security feature characteristics depending on the compiler used. ("But I
# selected CC_STACKPROTECTOR_STRONG! Why did it build with _REGULAR?!")
#
# The middle ground is to warn here so that the failed option is obvious, but
# to let the build fail with bad compiler flags so that we can't produce a
# kernel when there is a CONFIG and compiler mismatch.
#
665
ifdef CONFIG_CC_STACKPROTECTOR_REGULAR
666 667
  stackp-flag := -fstack-protector
  ifeq ($(call cc-option, $(stackp-flag)),)
668
    $(warning Cannot use CONFIG_CC_STACKPROTECTOR_REGULAR: \
669
             -fstack-protector not supported by compiler)
670
  endif
671 672
else
ifdef CONFIG_CC_STACKPROTECTOR_STRONG
673 674 675 676 677
  stackp-flag := -fstack-protector-strong
  ifeq ($(call cc-option, $(stackp-flag)),)
    $(warning Cannot use CONFIG_CC_STACKPROTECTOR_STRONG: \
	      -fstack-protector-strong not supported by compiler)
  endif
678 679 680
else
  # Force off for distro compilers that enable stack protector by default.
  stackp-flag := $(call cc-option, -fno-stack-protector)
681
endif
682
endif
683
KBUILD_CFLAGS += $(stackp-flag)
684

685 686 687 688 689 690 691 692
ifdef CONFIG_KCOV
  ifeq ($(call cc-option, $(CFLAGS_KCOV)),)
    $(warning Cannot use CONFIG_KCOV: \
             -fsanitize-coverage=trace-pc is not supported by compiler)
    CFLAGS_KCOV =
  endif
endif

Michal Marek's avatar
Michal Marek committed
693
ifeq ($(cc-name),clang)
694 695 696 697 698 699 700 701 702 703 704
KBUILD_CPPFLAGS += $(call cc-option,-Qunused-arguments,)
KBUILD_CPPFLAGS += $(call cc-option,-Wno-unknown-warning-option,)
KBUILD_CFLAGS += $(call cc-disable-warning, unused-variable)
KBUILD_CFLAGS += $(call cc-disable-warning, format-invalid-specifier)
KBUILD_CFLAGS += $(call cc-disable-warning, gnu)
# Quiet clang warning: comparison of unsigned expression < 0 is always false
KBUILD_CFLAGS += $(call cc-disable-warning, tautological-compare)
# CLANG uses a _MergedGlobals as optimization, but this breaks modpost, as the
# source of a reference will be _MergedGlobals and not on of the whitelisted names.
# See modpost pattern 2
KBUILD_CFLAGS += $(call cc-option, -mno-global-merge,)
705
KBUILD_CFLAGS += $(call cc-option, -fcatch-undefined-behavior)
706 707
else

708 709
# These warnings generated too much noise in a regular build.
# Use make W=1 to enable them (see scripts/Makefile.build)
710
KBUILD_CFLAGS += $(call cc-disable-warning, unused-but-set-variable)
711
KBUILD_CFLAGS += $(call cc-disable-warning, unused-const-variable)
712
endif
713

Linus Torvalds's avatar
Linus Torvalds committed
714
ifdef CONFIG_FRAME_POINTER
715
KBUILD_CFLAGS	+= -fno-omit-frame-pointer -fno-optimize-sibling-calls
Linus Torvalds's avatar
Linus Torvalds committed
716
else
717 718 719 720 721 722
# Some targets (ARM with Thumb2, for example), can't be built with frame
# pointers.  For those, we don't have FUNCTION_TRACER automatically
# select FRAME_POINTER.  However, FUNCTION_TRACER adds -pg, and this is
# incompatible with -fomit-frame-pointer with current GCC, so we don't use
# -fomit-frame-pointer with FUNCTION_TRACER.
ifndef CONFIG_FUNCTION_TRACER
723
KBUILD_CFLAGS	+= -fomit-frame-pointer
Linus Torvalds's avatar
Linus Torvalds committed
724
endif
725
endif
Linus Torvalds's avatar
Linus Torvalds committed
726

727 728
KBUILD_CFLAGS   += $(call cc-option, -fno-var-tracking-assignments)

Linus Torvalds's avatar
Linus Torvalds committed
729
ifdef CONFIG_DEBUG_INFO
730 731 732
ifdef CONFIG_DEBUG_INFO_SPLIT
KBUILD_CFLAGS   += $(call cc-option, -gsplit-dwarf, -g)
else
733
KBUILD_CFLAGS	+= -g
734
endif
735
KBUILD_AFLAGS	+= -Wa,-gdwarf-2
Linus Torvalds's avatar
Linus Torvalds committed
736
endif
737 738 739
ifdef CONFIG_DEBUG_INFO_DWARF4
KBUILD_CFLAGS	+= $(call cc-option, -gdwarf-4,)
endif
Linus Torvalds's avatar
Linus Torvalds committed
740

741
ifdef CONFIG_DEBUG_INFO_REDUCED
742 743
KBUILD_CFLAGS 	+= $(call cc-option, -femit-struct-debug-baseonly) \
		   $(call cc-option,-fno-var-tracking)
744 745
endif

746
ifdef CONFIG_FUNCTION_TRACER
747 748 749 750
ifndef CC_FLAGS_FTRACE
CC_FLAGS_FTRACE := -pg
endif
export CC_FLAGS_FTRACE
751 752 753
ifdef CONFIG_HAVE_FENTRY
CC_USING_FENTRY	:= $(call cc-option, -mfentry -DCC_USING_FENTRY)
endif
754
KBUILD_CFLAGS	+= $(CC_FLAGS_FTRACE) $(CC_USING_FENTRY)
755
KBUILD_AFLAGS	+= $(CC_USING_FENTRY)
756
ifdef CONFIG_DYNAMIC_FTRACE
757
	ifdef CONFIG_HAVE_C_RECORDMCOUNT
758 759 760 761
		BUILD_C_RECORDMCOUNT := y
		export BUILD_C_RECORDMCOUNT
	endif
endif
762 763
endif

764 765 766 767 768
# We trigger additional mismatches with less inlining
ifdef CONFIG_DEBUG_SECTION_MISMATCH
KBUILD_CFLAGS += $(call cc-option, -fno-inline-functions-called-once)
endif

769
# arch Makefile may override CC so keep this after arch Makefile is included
770
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
771 772
CHECKFLAGS     += $(NOSTDINC_FLAGS)

Linus Torvalds's avatar
Linus Torvalds committed
773
# warn about C99 declaration after statement
774
KBUILD_CFLAGS += $(call cc-option,-Wdeclaration-after-statement,)
Linus Torvalds's avatar
Linus Torvalds committed
775

776
# disable pointer signed / unsigned warnings in gcc 4.0
777
KBUILD_CFLAGS += $(call cc-disable-warning, pointer-sign)
Linus Torvalds's avatar
Linus Torvalds committed
778

779
# disable invalid "can't wrap" optimizations for signed / pointers
780
KBUILD_CFLAGS	+= $(call cc-option,-fno-strict-overflow)
781

782 783 784
# conserve stack if available
KBUILD_CFLAGS   += $(call cc-option,-fconserve-stack)

785 786 787 788 789 790
# disallow errors like 'EXPORT_GPL(foo);' with missing header
KBUILD_CFLAGS   += $(call cc-option,-Werror=implicit-int)

# require functions to have arguments in prototypes, not empty 'int foo()'
KBUILD_CFLAGS   += $(call cc-option,-Werror=strict-prototypes)

791 792 793
# Prohibit date/time macros, which would make the build non-deterministic
KBUILD_CFLAGS   += $(call cc-option,-Werror=date-time)

794 795 796
# enforce correct pointer usage
KBUILD_CFLAGS   += $(call cc-option,-Werror=incompatible-pointer-types)

797 798 799
# use the deterministic mode of AR if available
KBUILD_ARFLAGS := $(call ar-option,D)

800 801 802
# check for 'asm goto'
ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC)), y)
	KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO
803
	KBUILD_AFLAGS += -DCC_HAVE_ASM_GOTO
804 805
endif

806 807
include scripts/Makefile.kasan
include scripts/Makefile.extrawarn
808
include scripts/Makefile.ubsan
809

810 811 812 813 814
# Add any arch overrides and user supplied CPPFLAGS, AFLAGS and CFLAGS as the
# last assignments
KBUILD_CPPFLAGS += $(ARCH_CPPFLAGS) $(KCPPFLAGS)
KBUILD_AFLAGS   += $(ARCH_AFLAGS)   $(KAFLAGS)
KBUILD_CFLAGS   += $(ARCH_CFLAGS)   $(KCFLAGS)
815

Roland McGrath's avatar
Roland McGrath committed
816 817
# Use --build-id when available.
LDFLAGS_BUILD_ID = $(patsubst -Wl$(comma)%,%,\
818
			      $(call cc-ldoption, -Wl$(comma)--build-id,))
819
KBUILD_LDFLAGS_MODULE += $(LDFLAGS_BUILD_ID)
Roland McGrath's avatar
Roland McGrath committed
820 821
LDFLAGS_vmlinux += $(LDFLAGS_BUILD_ID)

822
ifeq ($(CONFIG_STRIP_ASM_SYMS),y)
823
LDFLAGS_vmlinux	+= $(call ld-option, -X,)
824 825
endif

Linus Torvalds's avatar
Linus Torvalds committed
826
# Default kernel image to build when no specific target is given.
827
# KBUILD_IMAGE may be overruled on the command line or
Linus Torvalds's avatar
Linus Torvalds committed
828 829 830 831 832 833 834 835 836 837
# set in the environment
# Also any assignments in arch/$(ARCH)/Makefile take precedence over
# this default value
export KBUILD_IMAGE ?= vmlinux

#
# INSTALL_PATH specifies where to place the updated kernel and system map
# images. Default is /boot, but you can set it to other values
export	INSTALL_PATH ?= /boot

838 839 840 841 842 843 844
#
# INSTALL_DTBS_PATH specifies a prefix for relocations required by build roots.
# Like INSTALL_MOD_PATH, it isn't defined in the Makefile, but can be passed as
# an argument if needed. Otherwise it defaults to the kernel install path
#
export INSTALL_DTBS_PATH ?= $(INSTALL_PATH)/dtbs/$(KERNELRELEASE)

Linus Torvalds's avatar
Linus Torvalds committed
845 846 847
#
# INSTALL_MOD_PATH specifies a prefix to MODLIB for module directory
# relocations required by build roots.  This is not defined in the
848
# makefile but the argument can be passed to make if needed.
Linus Torvalds's avatar
Linus Torvalds committed
849 850
#

851
MODLIB	= $(INSTALL_MOD_PATH)/lib/modules/$(KERNELRELEASE)
Linus Torvalds's avatar
Linus Torvalds committed
852 853
export MODLIB

854
#
855 856 857 858
# INSTALL_MOD_STRIP, if defined, will cause modules to be
# stripped after they are installed.  If INSTALL_MOD_STRIP is '1', then
# the default option --strip-debug will be used.  Otherwise,
# INSTALL_MOD_STRIP value will be used as the options to the strip command.
859

860 861
ifdef INSTALL_MOD_STRIP
ifeq ($(INSTALL_MOD_STRIP),1)
862
mod_strip_cmd = $(STRIP) --strip-debug
863
else
864
mod_strip_cmd = $(STRIP) $(INSTALL_MOD_STRIP)
865 866
endif # INSTALL_MOD_STRIP=1
else
867
mod_strip_cmd = true
868 869 870
endif # INSTALL_MOD_STRIP
export mod_strip_cmd

871 872 873 874 875 876 877
# CONFIG_MODULE_COMPRESS, if defined, will cause module to be compressed
# after they are installed in agreement with CONFIG_MODULE_COMPRESS_GZIP
# or CONFIG_MODULE_COMPRESS_XZ.

mod_compress_cmd = true
ifdef CONFIG_MODULE_COMPRESS
  ifdef CONFIG_MODULE_COMPRESS_GZIP
878
    mod_compress_cmd = gzip -n -f
879 880
  endif # CONFIG_MODULE_COMPRESS_GZIP
  ifdef CONFIG_MODULE_COMPRESS_XZ
881
    mod_compress_cmd = xz -f
882 883 884 885
  endif # CONFIG_MODULE_COMPRESS_XZ
endif # CONFIG_MODULE_COMPRESS
export mod_compress_cmd

886 887 888
# Select initial ramdisk compression format, default is gzip(1).
# This shall be used by the dracut(8) tool while creating an initramfs image.
#
Jan Beulich's avatar
Jan Beulich committed
889 890 891 892 893 894
INITRD_COMPRESS-y                  := gzip
INITRD_COMPRESS-$(CONFIG_RD_BZIP2) := bzip2
INITRD_COMPRESS-$(CONFIG_RD_LZMA)  := lzma
INITRD_COMPRESS-$(CONFIG_RD_XZ)    := xz
INITRD_COMPRESS-$(CONFIG_RD_LZO)   := lzo
INITRD_COMPRESS-$(CONFIG_RD_LZ4)   := lz4
895 896 897
# do not export INITRD_COMPRESS, since we didn't actually
# choose a sane default compression above.
# export INITRD_COMPRESS := $(INITRD_COMPRESS-y)
Linus Torvalds's avatar
Linus Torvalds committed
898

899
ifdef CONFIG_MODULE_SIG_ALL
900 901 902
$(eval $(call config_filename,MODULE_SIG_KEY))

mod_sign_cmd = scripts/sign-file $(CONFIG_MODULE_SIG_HASH) $(MODULE_SIG_KEY_SRCPREFIX)$(CONFIG_MODULE_SIG_KEY) certs/signing_key.x509
903 904 905 906 907 908
else
mod_sign_cmd = true
endif
export mod_sign_cmd


Linus Torvalds's avatar
Linus Torvalds committed
909
ifeq ($(KBUILD_EXTMOD),)
910
core-y		+= kernel/ certs/ mm/ fs/ ipc/ security/ crypto/ block/
Linus Torvalds's avatar
Linus Torvalds committed
911 912 913

vmlinux-dirs	:= $(patsubst %/,%,$(filter %/, $(init-y) $(init-m) \
		     $(core-y) $(core-m) $(drivers-y) $(drivers-m) \
914
		     $(net-y) $(net-m) $(libs-y) $(libs-m) $(virt-y)))
Linus Torvalds's avatar
Linus Torvalds committed
915 916

vmlinux-alldirs	:= $(sort $(vmlinux-dirs) $(patsubst %/,%,$(filter %/, \
917
		     $(init-) $(core-) $(drivers-) $(net-) $(libs-) $(virt-))))
Linus Torvalds's avatar
Linus Torvalds committed
918 919 920 921 922 923 924 925

init-y		:= $(patsubst %/, %/built-in.o, $(init-y))
core-y		:= $(patsubst %/, %/built-in.o, $(core-y))
drivers-y	:= $(patsubst %/, %/built-in.o, $(drivers-y))
net-y		:= $(patsubst %/, %/built-in.o, $(net-y))
libs-y1		:= $(patsubst %/, %/lib.a, $(libs-y))
libs-y2		:= $(patsubst %/, %/built-in.o, $(libs-y))
libs-y		:= $(libs-y1) $(libs-y2)
926
virt-y		:= $(patsubst %/, %/built-in.o, $(virt-y))
Linus Torvalds's avatar
Linus Torvalds committed
927

928
# Externally visible symbols (used by link-vmlinux.sh)
929
export KBUILD_VMLINUX_INIT := $(head-y) $(init-y)
930
export KBUILD_VMLINUX_MAIN := $(core-y) $(libs-y) $(drivers-y) $(net-y) $(virt-y)
931
export KBUILD_LDS          := arch/$(SRCARCH)/kernel/vmlinux.lds
932
export LDFLAGS_vmlinux
933
# used by scripts/pacmage/Makefile
934
export KBUILD_ALLDIRS := $(sort $(filter-out arch/%,$(vmlinux-alldirs)) arch Documentation include samples scripts tools)
935

936
vmlinux-deps := $(KBUILD_LDS) $(KBUILD_VMLINUX_INIT) $(KBUILD_VMLINUX_MAIN)
Linus Torvalds's avatar
Linus Torvalds committed
937

938 939 940 941 942
# Include targets which we want to execute sequentially if the rest of the
# kernel build went well. If CONFIG_TRIM_UNUSED_KSYMS is set, this might be
# evaluated more than once.
PHONY += vmlinux_prereq
vmlinux_prereq: $(vmlinux-deps) FORCE
943
ifdef CONFIG_HEADERS_CHECK
944
	$(Q)$(MAKE) -f $(srctree)/Makefile headers_check
945
endif
946 947
ifdef CONFIG_BUILD_DOCSRC
	$(Q)$(MAKE) $(build)=Documentation
Jan Kiszka's avatar
Jan Kiszka committed
948 949 950
endif
ifdef CONFIG_GDB_SCRIPTS
	$(Q)ln -fsn `cd $(srctree) && /bin/pwd`/scripts/gdb/vmlinux-gdb.py
951
endif
952
ifdef CONFIG_TRIM_UNUSED_KSYMS
953
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/adjust_autoksyms.sh \
954 955
	  "$(MAKE) KBUILD_MODULES=1 -f $(srctree)/Makefile vmlinux_prereq"
endif
956 957 958

# standalone target for easier testing
include/generated/autoksyms.h: FORCE
959
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/adjust_autoksyms.sh true
960

961 962 963 964
# Final link of vmlinux
      cmd_link-vmlinux = $(CONFIG_SHELL) $< $(LD) $(LDFLAGS) $(LDFLAGS_vmlinux)
quiet_cmd_link-vmlinux = LINK    $@

965
vmlinux: scripts/link-vmlinux.sh vmlinux_prereq $(vmlinux-deps) FORCE
966
	+$(call if_changed,link-vmlinux)
967

968 969 970 971 972
# Build samples along the rest of the kernel
ifdef CONFIG_SAMPLES
vmlinux-dirs += samples
endif

973
# The actual objects are generated when descending,
Linus Torvalds's avatar
Linus Torvalds committed
974
# make sure no implicit rule kicks in
975
$(sort $(vmlinux-deps)): $(vmlinux-dirs) ;
Linus Torvalds's avatar
Linus Torvalds committed
976 977 978 979 980 981 982

# Handle descending into subdirectories listed in $(vmlinux-dirs)
# Preset locale variables to speed up the build process. Limit locale
# tweaks to this spot to avoid wrong language settings when running
# make menuconfig etc.
# Error messages still appears in the original language

983
PHONY += $(vmlinux-dirs)
984
$(vmlinux-dirs): prepare scripts
Linus Torvalds's avatar
Linus Torvalds committed
985 986
	$(Q)$(MAKE) $(build)=$@

987 988 989 990
define filechk_kernel.release
	echo "$(KERNELVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
endef

991
# Store (new) KERNELRELEASE string in include/config/kernel.release
Roman Zippel's avatar
Roman Zippel committed
992
include/config/kernel.release: include/config/auto.conf FORCE
993
	$(call filechk,kernel.release)
994 995


Linus Torvalds's avatar
Linus Torvalds committed
996
# Things we need to do before we recursively start building the kernel
997 998 999 1000
# or the modules are listed in "prepare".
# A multi level approach is used. prepareN is processed before prepareN-1.
# archprepare is used in arch Makefiles and when processed asm symlink,
# version.h and scripts_basic is processed / created.
Linus Torvalds's avatar
Linus Torvalds committed
1001

1002
# Listed in dependency order
1003
PHONY += prepare archprepare prepare0 prepare1 prepare2 prepare3
1004

1005
# prepare3 is used to check if we are building in a separate output directory,
Linus Torvalds's avatar
Linus Torvalds committed
1006 1007
# and if so do:
# 1) Check that make has not been executed in the kernel src $(srctree)
Roman Zippel's avatar
Roman Zippel committed
1008
prepare3: include/config/kernel.release
Linus Torvalds's avatar
Linus Torvalds committed
1009
ifneq ($(KBUILD_SRC),)
1010
	@$(kecho) '  Using $(srctree) as source for kernel'
1011
	$(Q)if [ -f $(srctree)/.config -o -d $(srctree)/include/config ]; then \
1012 1013
		echo >&2 "  $(srctree) is not clean, please run 'make mrproper'"; \
		echo >&2 "  in the '$(srctree)' directory.";\
Linus Torvalds's avatar
Linus Torvalds committed
1014 1015 1016 1017
		/bin/false; \
	fi;
endif

1018
# prepare2 creates a makefile if using a separate output directory
Sam Ravnborg's avatar
Sam Ravnborg committed
1019
prepare2: prepare3 outputmakefile asm-generic
Linus Torvalds's avatar
Linus Torvalds committed
1020

David Howells's avatar
David Howells committed
1021
prepare1: prepare2 $(version_h) include/generated/utsrelease.h \
Sam Ravnborg's avatar
Sam Ravnborg committed
1022
                   include/config/auto.conf
1023
	$(cmd_crmodverdir)
1024 1025
	$(Q)test -e include/generated/autoksyms.h || \
	    touch   include/generated/autoksyms.h
Linus Torvalds's avatar
Linus Torvalds committed
1026

1027
archprepare: archheaders archscripts prepare1 scripts_basic
1028

1029
prepare0: archprepare
1030
	$(Q)$(MAKE) $(build)=.
1031

Linus Torvalds's avatar
Linus Torvalds committed
1032
# All the preparing..
1033 1034
prepare: prepare0 prepare-objtool

1035
ifdef CONFIG_STACK_VALIDATION
1036 1037
  has_libelf := $(call try-run,\
		echo "int main() {}" | $(HOSTCC) -xc -o /dev/null -lelf -,1,0)
1038 1039 1040 1041 1042 1043 1044 1045 1046
  ifeq ($(has_libelf),1)
    objtool_target := tools/objtool FORCE
  else
    $(warning "Cannot use CONFIG_STACK_VALIDATION, please install libelf-dev or elfutils-libelf-devel")
    SKIP_STACK_VALIDATION := 1
    export SKIP_STACK_VALIDATION
  endif
endif

1047
PHONY += prepare-objtool
1048
prepare-objtool: $(objtool_target)
Linus Torvalds's avatar
Linus Torvalds committed
1049 1050 1051 1052 1053 1054 1055 1056

# Generate some files
# ---------------------------------------------------------------------------

# KERNELRELEASE can change from a few different places, meaning version.h
# needs to be updated, so this check is forced on all builds

uts_len := 64
1057 1058 1059 1060 1061 1062 1063
define filechk_utsrelease.h
	if [ `echo -n "$(KERNELRELEASE)" | wc -c ` -gt $(uts_len) ]; then \
	  echo '"$(KERNELRELEASE)" exceeds $(uts_len) characters' >&2;    \
	  exit 1;                                                         \
	fi;                                                               \
	(echo \#define UTS_RELEASE \"$(KERNELRELEASE)\";)
endef
Linus Torvalds's avatar
Linus Torvalds committed
1064 1065

define filechk_version.h
1066 1067
	(echo \#define LINUX_VERSION_CODE $(shell                         \
	expr $(VERSION) \* 65536 + 0$(PATCHLEVEL) \* 256 + 0$(SUBLEVEL)); \
1068
	echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))';)
Linus Torvalds's avatar
Linus Torvalds committed
1069 1070
endef

David Howells's avatar
David Howells committed
1071
$(version_h): $(srctree)/Makefile FORCE
Linus Torvalds's avatar
Linus Torvalds committed
1072
	$(call filechk,version.h)
1073
	$(Q)rm -f $(old_version_h)
Linus Torvalds's avatar
Linus Torvalds committed
1074

1075
include/generated/utsrelease.h: include/config/kernel.release FORCE
1076 1077
	$(call filechk,utsrelease.h)

1078 1079
PHONY += headerdep
headerdep:
1080 1081
	$(Q)find $(srctree)/include/ -name '*.h' | xargs --max-args 1 \
	$(srctree)/scripts/headerdep.pl -I$(srctree)/include
1082

1083 1084 1085 1086 1087 1088
# ---------------------------------------------------------------------------
# Firmware install
INSTALL_FW_PATH=$(INSTALL_MOD_PATH)/lib/firmware
export INSTALL_FW_PATH

PHONY += firmware_install
1089
firmware_install:
1090 1091 1092
	@mkdir -p $(objtree)/firmware
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.fwinst obj=firmware __fw_install

1093 1094 1095
# ---------------------------------------------------------------------------
# Kernel headers

1096 1097
#Default location for installed headers
export INSTALL_HDR_PATH = $(objtree)/usr
1098

1099 1100
# If we do an all arch process set dst to asm-$(hdr-arch)
hdr-dst = $(if $(KBUILD_HEADERS), dst=include/asm-$(hdr-arch), dst=include/asm)
1101

1102 1103 1104
PHONY += archheaders
archheaders:

1105 1106 1107
PHONY += archscripts
archscripts:

1108
PHONY += __headers
1109
__headers: $(version_h) scripts_basic asm-generic archheaders archscripts
1110
	$(Q)$(MAKE) $(build)=scripts build_unifdef
1111 1112

PHONY += headers_install_all
1113 1114
headers_install_all:
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/headers.sh install
1115

1116
PHONY += headers_install
1117
headers_install: __headers
1118 1119 1120 1121
	$(if $(wildcard $(srctree)/arch/$(hdr-arch)/include/uapi/asm/Kbuild),, \
	  $(error Headers not exportable for the $(SRCARCH) architecture))
	$(Q)$(MAKE) $(hdr-inst)=include/uapi
	$(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst)
1122

1123 1124
PHONY += headers_check_all
headers_check_all: headers_install_all
1125
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/headers.sh check
1126

1127 1128
PHONY += headers_check
headers_check: headers_install
1129 1130
	$(Q)$(MAKE) $(hdr-inst)=include/uapi HDRCHECK=1
	$(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst) HDRCHECK=1
1131

1132 1133 1134 1135 1136 1137 1138
# ---------------------------------------------------------------------------
# Kernel selftest

PHONY += kselftest
kselftest:
	$(Q)$(MAKE) -C tools/testing/selftests run_tests

1139 1140 1141
kselftest-clean:
	$(Q)$(MAKE) -C tools/testing/selftests clean

1142 1143 1144 1145 1146 1147 1148 1149
PHONY += kselftest-merge
kselftest-merge:
	$(if $(wildcard $(objtree)/.config),, $(error No .config exists, config your kernel first!))
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/kconfig/merge_config.sh \
		-m $(objtree)/.config \
		$(srctree)/tools/testing/selftests/*/config
	+$(Q)$(MAKE) -f $(srctree)/Makefile olddefconfig

Linus Torvalds's avatar
Linus Torvalds committed
1150 1151 1152 1153 1154
# ---------------------------------------------------------------------------
# Modules

ifdef CONFIG_MODULES

1155
# By default, build modules as well
Linus Torvalds's avatar
Linus Torvalds committed
1156

1157
all: modules
Linus Torvalds's avatar
Linus Torvalds committed
1158

1159
# Build modules
Tejun Heo's avatar
Tejun Heo committed
1160
#
1161 1162 1163
# A module can be listed more than once in obj-m resulting in
# duplicate lines in modules.order files.  Those are removed
# using awk while concatenating to the final file.
Linus Torvalds's avatar
Linus Torvalds committed
1164

1165
PHONY += modules
1166
modules: $(vmlinux-dirs) $(if $(KBUILD_BUILTIN),vmlinux) modules.builtin
Tejun Heo's avatar
Tejun Heo committed
1167
	$(Q)$(AWK) '!x[$$0]++' $(vmlinux-dirs:%=$(objtree)/%/modules.order) > $(objtree)/modules.order
1168
	@$(kecho) '  Building modules, stage 2.';
1169
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
1170
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.fwinst obj=firmware __fw_modbuild
Linus Torvalds's avatar
Linus Torvalds committed
1171

1172 1173 1174
modules.builtin: $(vmlinux-dirs:%=%/modules.builtin)
	$(Q)$(AWK) '!x[$$0]++' $^ > $(objtree)/modules.builtin

1175
%/modules.builtin: include/config/auto.conf
1176 1177
	$(Q)$(MAKE) $(modbuiltin)=$*

Linus Torvalds's avatar
Linus Torvalds committed
1178 1179

# Target to prepare building external modules
1180
PHONY += modules_prepare
1181
modules_prepare: prepare scripts
Linus Torvalds's avatar
Linus Torvalds committed
1182 1183

# Target to install modules
1184
PHONY += modules_install
Linus Torvalds's avatar
Linus Torvalds committed
1185 1186
modules_install: _modinst_ _modinst_post