Makefile 55.6 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 = -rc1
Linus Torvalds's avatar
Linus Torvalds committed
5
NAME = Blurry Fish Butt
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: ;

Linus Torvalds's avatar
Linus Torvalds committed
131 132 133 134
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)
135 136
KBUILD_OUTPUT := $(shell mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) \
								&& /bin/pwd)
Linus Torvalds's avatar
Linus Torvalds committed
137
$(if $(KBUILD_OUTPUT),, \
138
     $(error failed to create output directory "$(saved-output)"))
Linus Torvalds's avatar
Linus Torvalds committed
139

140 141
PHONY += $(MAKECMDGOALS) sub-make

142
$(filter-out _all sub-make $(CURDIR)/Makefile, $(MAKECMDGOALS)) _all: sub-make
143
	@:
144 145

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

# 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),)

157 158 159 160 161
# 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

162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189
# 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
190 191
# If building an external module we do not care about the all: rule
# but instead _all depend on modules
192
PHONY += all
Linus Torvalds's avatar
Linus Torvalds committed
193 194 195 196 197 198
ifeq ($(KBUILD_EXTMOD),)
_all: all
else
_all: modules
endif

199 200 201 202 203 204 205 206 207 208 209
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
210
objtree		:= .
Linus Torvalds's avatar
Linus Torvalds committed
211 212 213
src		:= $(srctree)
obj		:= $(objtree)

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

216
export srctree objtree VPATH
Linus Torvalds's avatar
Linus Torvalds committed
217 218 219 220

# 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,
221
# then ARCH is assigned, getting whatever value it gets normally, and
Linus Torvalds's avatar
Linus Torvalds committed
222 223
# SUBARCH is subsequently ignored.

224 225
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
226
				  -e s/arm.*/arm/ -e s/sa110/arm/ \
227
				  -e s/s390x/s390/ -e s/parisc64/parisc/ \
Paul Mundt's avatar
Paul Mundt committed
228
				  -e s/ppc.*/powerpc/ -e s/mips.*/mips/ \
229
				  -e s/sh[234].*/sh/ -e s/aarch64.*/arm64/ )
Linus Torvalds's avatar
Linus Torvalds committed
230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246

# 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.
247 248
# 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
249 250
# Default value for CROSS_COMPILE is not to prefix executables
# Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile
251
ARCH		?= $(SUBARCH)
252
CROSS_COMPILE	?= $(CONFIG_CROSS_COMPILE:"%"=%)
Linus Torvalds's avatar
Linus Torvalds committed
253 254

# Architecture as present in compile.h
255 256
UTS_MACHINE 	:= $(ARCH)
SRCARCH 	:= $(ARCH)
Linus Torvalds's avatar
Linus Torvalds committed
257

258 259 260 261 262 263 264
# Additional ARCH settings for x86
ifeq ($(ARCH),i386)
        SRCARCH := x86
endif
ifeq ($(ARCH),x86_64)
        SRCARCH := x86
endif
265

Sam Ravnborg's avatar
Sam Ravnborg committed
266
# Additional ARCH settings for sparc
267 268 269
ifeq ($(ARCH),sparc32)
       SRCARCH := sparc
endif
270
ifeq ($(ARCH),sparc64)
Sam Ravnborg's avatar
Sam Ravnborg committed
271
       SRCARCH := sparc
272
endif
273

274 275 276 277 278
# Additional ARCH settings for sh
ifeq ($(ARCH),sh64)
       SRCARCH := sh
endif

279
# Additional ARCH settings for tile
280 281 282
ifeq ($(ARCH),tilepro)
       SRCARCH := tile
endif
283 284 285 286
ifeq ($(ARCH),tilegx)
       SRCARCH := tile
endif

Sam Ravnborg's avatar
Sam Ravnborg committed
287 288 289
# Where to locate arch specific headers
hdr-arch  := $(SRCARCH)

290
KCONFIG_CONFIG	?= .config
291
export KCONFIG_CONFIG
292

Linus Torvalds's avatar
Linus Torvalds committed
293 294 295 296 297
# 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)

298 299
HOSTCC       = gcc
HOSTCXX      = g++
300
HOSTCFLAGS   = -Wall -Wmissing-prototypes -Wstrict-prototypes -O2 -fomit-frame-pointer -std=gnu89
301
HOSTCXXFLAGS = -O2
Linus Torvalds's avatar
Linus Torvalds committed
302

303 304 305 306 307
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

308 309
# Decide whether to build built-in, modular, or both.
# Normally, just do built-in.
Linus Torvalds's avatar
Linus Torvalds committed
310 311 312 313

KBUILD_MODULES :=
KBUILD_BUILTIN := 1

314 315 316 317
# 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
318 319 320 321 322

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

323 324 325
# 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
326 327 328 329 330 331 332 333 334

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

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

335
export KBUILD_MODULES KBUILD_BUILTIN
Linus Torvalds's avatar
Linus Torvalds committed
336 337
export KBUILD_CHECKSRC KBUILD_SRC KBUILD_EXTMOD

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

# 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
354
INSTALLKERNEL  := installkernel
Linus Torvalds's avatar
Linus Torvalds committed
355 356
DEPMOD		= /sbin/depmod
PERL		= perl
357
PYTHON		= python
Linus Torvalds's avatar
Linus Torvalds committed
358 359
CHECK		= sparse

360 361
CHECKFLAGS     := -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ \
		  -Wbitwise -Wno-return-void $(CF)
362 363 364
CFLAGS_MODULE   =
AFLAGS_MODULE   =
LDFLAGS_MODULE  =
Linus Torvalds's avatar
Linus Torvalds committed
365 366
CFLAGS_KERNEL	=
AFLAGS_KERNEL	=
367
CFLAGS_GCOV	= -fprofile-arcs -ftest-coverage
368
CFLAGS_KCOV	= -fsanitize-coverage=trace-pc
Linus Torvalds's avatar
Linus Torvalds committed
369 370


371 372 373 374 375 376 377 378
# 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
379 380
# Use LINUXINCLUDE when you must reference the include/ directory.
# Needed to be compatible with the O= option
381 382
LINUXINCLUDE    := \
		-I$(srctree)/arch/$(hdr-arch)/include \
383
		-Iarch/$(hdr-arch)/include/generated/uapi \
384 385 386 387
		-Iarch/$(hdr-arch)/include/generated \
		$(if $(KBUILD_SRC), -I$(srctree)/include) \
		-Iinclude \
		$(USERINCLUDE)
Linus Torvalds's avatar
Linus Torvalds committed
388

389
KBUILD_CPPFLAGS := -D__KERNEL__
Linus Torvalds's avatar
Linus Torvalds committed
390

391
KBUILD_CFLAGS   := -Wall -Wundef -Wstrict-prototypes -Wno-trigraphs \
392
		   -fno-strict-aliasing -fno-common \
393
		   -Werror-implicit-function-declaration \
394 395
		   -Wno-format-security \
		   -std=gnu89
396

397 398
KBUILD_AFLAGS_KERNEL :=
KBUILD_CFLAGS_KERNEL :=
399
KBUILD_AFLAGS   := -D__ASSEMBLY__
400 401 402
KBUILD_AFLAGS_MODULE  := -DMODULE
KBUILD_CFLAGS_MODULE  := -DMODULE
KBUILD_LDFLAGS_MODULE := -T $(srctree)/scripts/module-common.lds
Linus Torvalds's avatar
Linus Torvalds committed
403

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

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

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

# 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

428 429 430
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
431 432
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
433 434 435 436 437

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

# Basic helpers built in scripts/
438
PHONY += scripts_basic
Linus Torvalds's avatar
Linus Torvalds committed
439 440
scripts_basic:
	$(Q)$(MAKE) $(build)=scripts/basic
441
	$(Q)rm -f .tmp_quiet_recordmcount
Linus Torvalds's avatar
Linus Torvalds committed
442

443 444 445
# To avoid any implicit rule to kick in, define an empty command.
scripts/basic/%: scripts_basic ;

446
PHONY += outputmakefile
447 448 449
# 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
450
outputmakefile:
451
ifneq ($(KBUILD_SRC),)
452
	$(Q)ln -fsn $(srctree) source
453 454 455
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/mkmakefile \
	    $(srctree) $(objtree) $(VERSION) $(PATCHLEVEL)
endif
Linus Torvalds's avatar
Linus Torvalds committed
456

Sam Ravnborg's avatar
Sam Ravnborg committed
457 458 459 460
# Support for using generic headers in asm-generic
PHONY += asm-generic
asm-generic:
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.asm-generic \
461 462 463
	            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
464

Linus Torvalds's avatar
Linus Torvalds committed
465 466 467 468
# 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.
469
# For example 'make oldconfig all'.
Linus Torvalds's avatar
Linus Torvalds committed
470 471 472
# Detect when mixed targets is specified, and make a second invocation
# of make so .config is not included in this case either (for *config).

473
version_h := include/generated/uapi/linux/version.h
474
old_version_h := include/linux/version.h
David Howells's avatar
David Howells committed
475

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

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
494
                ifneq ($(words $(MAKECMDGOALS)),1)
Linus Torvalds's avatar
Linus Torvalds committed
495 496 497 498
                        mixed-targets := 1
                endif
        endif
endif
499 500 501 502 503 504
# 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
505 506 507 508 509 510

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

511 512 513 514 515 516 517 518 519 520
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
521 522 523 524 525 526 527 528 529 530

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'
531
include arch/$(SRCARCH)/Makefile
532
export KBUILD_DEFCONFIG KBUILD_KCONFIG
Linus Torvalds's avatar
Linus Torvalds committed
533

534 535 536 537
config: scripts_basic outputmakefile FORCE
	$(Q)$(MAKE) $(build)=scripts/kconfig $@

%config: scripts_basic outputmakefile FORCE
Linus Torvalds's avatar
Linus Torvalds committed
538 539 540 541 542 543 544 545 546 547
	$(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
548
# in parallel
549
PHONY += scripts
550 551
scripts: scripts_basic include/config/auto.conf include/config/tristate.conf \
	 asm-generic
Linus Torvalds's avatar
Linus Torvalds committed
552 553 554 555
	$(Q)$(MAKE) $(build)=$(@)

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

ifeq ($(dot-config),1)
564 565
# Read in config
-include include/config/auto.conf
Linus Torvalds's avatar
Linus Torvalds committed
566

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

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

575
# If .config is newer than include/config/auto.conf, someone tinkered
576
# with it and forgot to run make oldconfig.
577
# if auto.conf.cmd is missing then we are probably in a cleaned tree so
578
# we execute the config step to be sure to catch updated Kconfig files
579
include/config/%.conf: $(KCONFIG_CONFIG) include/config/auto.conf.cmd
Linus Torvalds's avatar
Linus Torvalds committed
580
	$(Q)$(MAKE) -f $(srctree)/Makefile silentoldconfig
581
else
582
# external modules needs include/generated/autoconf.h and include/config/auto.conf
583 584 585 586
# 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:
587
	$(Q)test -e include/generated/autoconf.h -a -e $@ || (		\
588 589 590 591 592
	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 ;							\
593 594 595
	/bin/false)

endif # KBUILD_EXTMOD
596

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

# 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
605
# Defaults to vmlinux, but the arch makefile usually adds further targets
Linus Torvalds's avatar
Linus Torvalds committed
606 607
all: vmlinux

608 609 610 611 612
# 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 :=
613
include arch/$(SRCARCH)/Makefile
614 615 616

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

Linus Torvalds's avatar
Linus Torvalds committed
617
ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
618
KBUILD_CFLAGS	+= -Os $(call cc-disable-warning,maybe-uninitialized,)
Linus Torvalds's avatar
Linus Torvalds committed
619
else
620
KBUILD_CFLAGS	+= -O2
Linus Torvalds's avatar
Linus Torvalds committed
621 622
endif

623 624 625
# 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
626 627 628 629 630 631 632 633 634 635
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

636
ifneq ($(CONFIG_FRAME_WARN),0)
637 638 639
KBUILD_CFLAGS += $(call cc-option,-Wframe-larger-than=${CONFIG_FRAME_WARN})
endif

640
# Handle stack protector mode.
641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656
#
# 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.
#
657
ifdef CONFIG_CC_STACKPROTECTOR_REGULAR
658 659
  stackp-flag := -fstack-protector
  ifeq ($(call cc-option, $(stackp-flag)),)
660
    $(warning Cannot use CONFIG_CC_STACKPROTECTOR_REGULAR: \
661
             -fstack-protector not supported by compiler)
662
  endif
663 664
else
ifdef CONFIG_CC_STACKPROTECTOR_STRONG
665 666 667 668 669
  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
670 671 672
else
  # Force off for distro compilers that enable stack protector by default.
  stackp-flag := $(call cc-option, -fno-stack-protector)
673
endif
674
endif
675
KBUILD_CFLAGS += $(stackp-flag)
676

677 678 679 680 681 682 683 684
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
685
ifeq ($(cc-name),clang)
686 687 688 689 690 691 692 693 694 695 696
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,)
697
KBUILD_CFLAGS += $(call cc-option, -fcatch-undefined-behavior)
698 699
else

700 701
# This warning generated too much noise in a regular build.
# Use make W=1 to enable this warning (see scripts/Makefile.build)
702
KBUILD_CFLAGS += $(call cc-disable-warning, unused-but-set-variable)
703
endif
704

Linus Torvalds's avatar
Linus Torvalds committed
705
ifdef CONFIG_FRAME_POINTER
706
KBUILD_CFLAGS	+= -fno-omit-frame-pointer -fno-optimize-sibling-calls
Linus Torvalds's avatar
Linus Torvalds committed
707
else
708 709 710 711 712 713
# 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
714
KBUILD_CFLAGS	+= -fomit-frame-pointer
Linus Torvalds's avatar
Linus Torvalds committed
715
endif
716
endif
Linus Torvalds's avatar
Linus Torvalds committed
717

718 719
KBUILD_CFLAGS   += $(call cc-option, -fno-var-tracking-assignments)

Linus Torvalds's avatar
Linus Torvalds committed
720
ifdef CONFIG_DEBUG_INFO
721 722 723
ifdef CONFIG_DEBUG_INFO_SPLIT
KBUILD_CFLAGS   += $(call cc-option, -gsplit-dwarf, -g)
else
724
KBUILD_CFLAGS	+= -g
725
endif
726
KBUILD_AFLAGS	+= -Wa,-gdwarf-2
Linus Torvalds's avatar
Linus Torvalds committed
727
endif
728 729 730
ifdef CONFIG_DEBUG_INFO_DWARF4
KBUILD_CFLAGS	+= $(call cc-option, -gdwarf-4,)
endif
Linus Torvalds's avatar
Linus Torvalds committed
731

732
ifdef CONFIG_DEBUG_INFO_REDUCED
733 734
KBUILD_CFLAGS 	+= $(call cc-option, -femit-struct-debug-baseonly) \
		   $(call cc-option,-fno-var-tracking)
735 736
endif

737
ifdef CONFIG_FUNCTION_TRACER
738 739 740 741
ifndef CC_FLAGS_FTRACE
CC_FLAGS_FTRACE := -pg
endif
export CC_FLAGS_FTRACE
742 743 744
ifdef CONFIG_HAVE_FENTRY
CC_USING_FENTRY	:= $(call cc-option, -mfentry -DCC_USING_FENTRY)
endif
745
KBUILD_CFLAGS	+= $(CC_FLAGS_FTRACE) $(CC_USING_FENTRY)
746
KBUILD_AFLAGS	+= $(CC_USING_FENTRY)
747
ifdef CONFIG_DYNAMIC_FTRACE
748
	ifdef CONFIG_HAVE_C_RECORDMCOUNT
749 750 751 752
		BUILD_C_RECORDMCOUNT := y
		export BUILD_C_RECORDMCOUNT
	endif
endif
753 754
endif

755 756 757 758 759
# We trigger additional mismatches with less inlining
ifdef CONFIG_DEBUG_SECTION_MISMATCH
KBUILD_CFLAGS += $(call cc-option, -fno-inline-functions-called-once)
endif

760
# arch Makefile may override CC so keep this after arch Makefile is included
761
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
762 763
CHECKFLAGS     += $(NOSTDINC_FLAGS)

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

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

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

773 774 775
# conserve stack if available
KBUILD_CFLAGS   += $(call cc-option,-fconserve-stack)

776 777 778 779 780 781
# 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)

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

785 786 787
# enforce correct pointer usage
KBUILD_CFLAGS   += $(call cc-option,-Werror=incompatible-pointer-types)

788 789 790
# use the deterministic mode of AR if available
KBUILD_ARFLAGS := $(call ar-option,D)

791 792 793
# check for 'asm goto'
ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC)), y)
	KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO
794
	KBUILD_AFLAGS += -DCC_HAVE_ASM_GOTO
795 796
endif

797 798
include scripts/Makefile.kasan
include scripts/Makefile.extrawarn
799
include scripts/Makefile.ubsan
800

801 802 803 804 805
# 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)
806

Roland McGrath's avatar
Roland McGrath committed
807 808
# Use --build-id when available.
LDFLAGS_BUILD_ID = $(patsubst -Wl$(comma)%,%,\
809
			      $(call cc-ldoption, -Wl$(comma)--build-id,))
810
KBUILD_LDFLAGS_MODULE += $(LDFLAGS_BUILD_ID)
Roland McGrath's avatar
Roland McGrath committed
811 812
LDFLAGS_vmlinux += $(LDFLAGS_BUILD_ID)

813
ifeq ($(CONFIG_STRIP_ASM_SYMS),y)
814
LDFLAGS_vmlinux	+= $(call ld-option, -X,)
815 816
endif

Linus Torvalds's avatar
Linus Torvalds committed
817
# Default kernel image to build when no specific target is given.
818
# KBUILD_IMAGE may be overruled on the command line or
Linus Torvalds's avatar
Linus Torvalds committed
819 820 821 822 823 824 825 826 827 828
# 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

829 830 831 832 833 834 835
#
# 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
836 837 838
#
# INSTALL_MOD_PATH specifies a prefix to MODLIB for module directory
# relocations required by build roots.  This is not defined in the
839
# makefile but the argument can be passed to make if needed.
Linus Torvalds's avatar
Linus Torvalds committed
840 841
#

842
MODLIB	= $(INSTALL_MOD_PATH)/lib/modules/$(KERNELRELEASE)
Linus Torvalds's avatar
Linus Torvalds committed
843 844
export MODLIB

845
#
846 847 848 849
# 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.
850

851 852
ifdef INSTALL_MOD_STRIP
ifeq ($(INSTALL_MOD_STRIP),1)
853
mod_strip_cmd = $(STRIP) --strip-debug
854
else
855
mod_strip_cmd = $(STRIP) $(INSTALL_MOD_STRIP)
856 857
endif # INSTALL_MOD_STRIP=1
else
858
mod_strip_cmd = true
859 860 861
endif # INSTALL_MOD_STRIP
export mod_strip_cmd

862 863 864 865 866 867 868
# 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
869
    mod_compress_cmd = gzip -n -f
870 871
  endif # CONFIG_MODULE_COMPRESS_GZIP
  ifdef CONFIG_MODULE_COMPRESS_XZ
872
    mod_compress_cmd = xz -f
873 874 875 876
  endif # CONFIG_MODULE_COMPRESS_XZ
endif # CONFIG_MODULE_COMPRESS
export mod_compress_cmd

877 878 879
# 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
880 881 882 883 884 885
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
886 887 888
# 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
889

890
ifdef CONFIG_MODULE_SIG_ALL
891 892 893
$(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
894 895 896 897 898 899
else
mod_sign_cmd = true
endif
export mod_sign_cmd


Linus Torvalds's avatar
Linus Torvalds committed
900
ifeq ($(KBUILD_EXTMOD),)
901
core-y		+= kernel/ certs/ mm/ fs/ ipc/ security/ crypto/ block/
Linus Torvalds's avatar
Linus Torvalds committed
902 903 904

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

vmlinux-alldirs	:= $(sort $(vmlinux-dirs) $(patsubst %/,%,$(filter %/, \
908
		     $(init-) $(core-) $(drivers-) $(net-) $(libs-) $(virt-))))
Linus Torvalds's avatar
Linus Torvalds committed
909 910 911 912 913 914 915 916

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)
917
virt-y		:= $(patsubst %/, %/built-in.o, $(virt-y))
Linus Torvalds's avatar
Linus Torvalds committed
918

919
# Externally visible symbols (used by link-vmlinux.sh)
920
export KBUILD_VMLINUX_INIT := $(head-y) $(init-y)
921
export KBUILD_VMLINUX_MAIN := $(core-y) $(libs-y) $(drivers-y) $(net-y) $(virt-y)
922
export KBUILD_LDS          := arch/$(SRCARCH)/kernel/vmlinux.lds
923
export LDFLAGS_vmlinux
924
# used by scripts/pacmage/Makefile
925
export KBUILD_ALLDIRS := $(sort $(filter-out arch/%,$(vmlinux-alldirs)) arch Documentation include samples scripts tools)
926

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

929 930 931
# Final link of vmlinux
      cmd_link-vmlinux = $(CONFIG_SHELL) $< $(LD) $(LDFLAGS) $(LDFLAGS_vmlinux)
quiet_cmd_link-vmlinux = LINK    $@
Linus Torvalds's avatar
Linus Torvalds committed
932

933 934 935
# Include targets which we want to
# execute if the rest of the kernel build went well.
vmlinux: scripts/link-vmlinux.sh $(vmlinux-deps) FORCE
936 937 938 939
ifdef CONFIG_TRIM_UNUSED_KSYMS
	$(Q)$(CONFIG_SHELL) scripts/adjust_autoksyms.sh \
	  "$(MAKE) KBUILD_MODULES=1 -f $(srctree)/Makefile autoksyms_recursive"
endif
940
ifdef CONFIG_HEADERS_CHECK
941
	$(Q)$(MAKE) -f $(srctree)/Makefile headers_check
942 943 944
endif
ifdef CONFIG_SAMPLES
	$(Q)$(MAKE) $(build)=samples
945 946 947
endif
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
	+$(call if_changed,link-vmlinux)
953

954 955 956 957 958 959 960 961 962
autoksyms_recursive: $(vmlinux-deps)
	$(Q)$(CONFIG_SHELL) scripts/adjust_autoksyms.sh \
	  "$(MAKE) KBUILD_MODULES=1 -f $(srctree)/Makefile autoksyms_recursive"
PHONY += autoksyms_recursive

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

963
# The actual objects are generated when descending,
Linus Torvalds's avatar
Linus Torvalds committed
964
# make sure no implicit rule kicks in
965
$(sort $(vmlinux-deps)): $(vmlinux-dirs) ;
Linus Torvalds's avatar
Linus Torvalds committed
966 967 968 969 970 971 972

# 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

973
PHONY += $(vmlinux-dirs)
974
$(vmlinux-dirs): prepare scripts
Linus Torvalds's avatar
Linus Torvalds committed
975 976
	$(Q)$(MAKE) $(build)=$@

977 978 979 980
define filechk_kernel.release
	echo "$(KERNELVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
endef

981
# Store (new) KERNELRELEASE string in include/config/kernel.release
Roman Zippel's avatar
Roman Zippel committed
982
include/config/kernel.release: include/config/auto.conf FORCE
983
	$(call filechk,kernel.release)
984 985


Linus Torvalds's avatar
Linus Torvalds committed
986
# Things we need to do before we recursively start building the kernel
987 988 989 990
# 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
991

992
# Listed in dependency order
993
PHONY += prepare archprepare prepare0 prepare1 prepare2 prepare3
994

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

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

David Howells's avatar
David Howells committed
1011
prepare1: prepare2 $(version_h) include/generated/utsrelease.h \
Sam Ravnborg's avatar
Sam Ravnborg committed
1012
                   include/config/auto.conf
1013
	$(cmd_crmodverdir)
1014 1015
	$(Q)test -e include/generated/autoksyms.h || \
	    touch   include/generated/autoksyms.h
Linus Torvalds's avatar
Linus Torvalds committed
1016

1017
archprepare: archheaders archscripts prepare1 scripts_basic
1018 1019

prepare0: archprepare FORCE
1020
	$(Q)$(MAKE) $(build)=.
1021

Linus Torvalds's avatar
Linus Torvalds committed
1022
# All the preparing..
1023 1024
prepare: prepare0 prepare-objtool

1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035
ifdef CONFIG_STACK_VALIDATION
  has_libelf := $(shell echo "int main() {}" | $(HOSTCC) -xc -o /dev/null -lelf - &> /dev/null && echo 1 || echo 0)
  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

1036
PHONY += prepare-objtool
1037
prepare-objtool: $(objtool_target)
Linus Torvalds's avatar
Linus Torvalds committed
1038 1039 1040 1041 1042 1043 1044 1045

# 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
1046 1047 1048 1049 1050 1051 1052
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
1053 1054

define filechk_version.h
1055 1056
	(echo \#define LINUX_VERSION_CODE $(shell                         \
	expr $(VERSION) \* 65536 + 0$(PATCHLEVEL) \* 256 + 0$(SUBLEVEL)); \
1057
	echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))';)
Linus Torvalds's avatar
Linus Torvalds committed
1058 1059
endef

David Howells's avatar
David Howells committed
1060
$(version_h): $(srctree)/Makefile FORCE
Linus Torvalds's avatar
Linus Torvalds committed
1061
	$(call filechk,version.h)
1062
	$(Q)rm -f $(old_version_h)
Linus Torvalds's avatar
Linus Torvalds committed
1063

1064
include/generated/utsrelease.h: include/config/kernel.release FORCE
1065 1066
	$(call filechk,utsrelease.h)

1067 1068
PHONY += headerdep
headerdep:
1069 1070
	$(Q)find $(srctree)/include/ -name '*.h' | xargs --max-args 1 \
	$(srctree)/scripts/headerdep.pl -I$(srctree)/include
1071

1072 1073 1074 1075 1076 1077 1078 1079 1080 1081
# ---------------------------------------------------------------------------
# Firmware install
INSTALL_FW_PATH=$(INSTALL_MOD_PATH)/lib/firmware
export INSTALL_FW_PATH

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

1082 1083 1084
# ---------------------------------------------------------------------------
# Kernel headers

1085 1086
#Default location for installed headers
export INSTALL_HDR_PATH = $(objtree)/usr
1087

1088 1089
# 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)
1090

1091 1092 1093
PHONY += archheaders
archheaders:

1094 1095 1096
PHONY += archscripts
archscripts:

1097
PHONY += __headers
David Howells's avatar
David Howells committed
1098
__headers: $(version_h) scripts_basic asm-generic archheaders archscripts FORCE
1099
	$(Q)$(MAKE) $(build)=scripts build_unifdef
1100 1101

PHONY += headers_install_all
1102 1103
headers_install_all:
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/headers.sh install
1104

1105
PHONY += headers_install
1106
headers_install: __headers
1107 1108 1109 1110
	$(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)
1111

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

1116 1117
PHONY += headers_check
headers_check: headers_install
1118 1119
	$(Q)$(MAKE) $(hdr-inst)=include/uapi HDRCHECK=1
	$(Q)$(MAKE) $(hdr-inst)=arch/$(hdr-arch)/include/uapi/asm $(hdr-dst) HDRCHECK=1
1120

1121 1122 1123 1124 1125 1126 1127
# ---------------------------------------------------------------------------
# Kernel selftest

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

1128 1129 1130
kselftest-clean:
	$(Q)$(MAKE) -C tools/testing/selftests clean

1131 1132 1133 1134 1135 1136 1137 1138
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
1139 1140 1141 1142 1143
# ---------------------------------------------------------------------------
# Modules

ifdef CONFIG_MODULES

1144
# By default, build modules as well
Linus Torvalds's avatar
Linus Torvalds committed
1145

1146
all: modules
Linus Torvalds's avatar
Linus Torvalds committed
1147

1148
# Build modules
Tejun Heo's avatar
Tejun Heo committed
1149
#
1150 1151 1152
# 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
1153

1154
PHONY += modules
1155
modules: $(vmlinux-dirs) $(if $(KBUILD_BUILTIN),vmlinux) modules.builtin
Tejun Heo's avatar
Tejun Heo committed
1156
	$(Q)$(AWK) '!x[$$0]++' $(vmlinux-dirs:%=$(objtree)/%/modules.order) > $(objtree)/modules.order
1157
	@$(kecho) '  Building modules, stage 2.';
1158
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
1159
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.fwinst obj=firmware __fw_modbuild
Linus Torvalds's avatar
Linus Torvalds committed
1160

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

1164
%/modules.builtin: include/config/auto.conf
1165 1166
	$(Q)$(MAKE) $(modbuiltin)=$*

Linus Torvalds's avatar
Linus Torvalds committed
1167 1168

# Target to prepare building external modules
1169
PHONY += modules_prepare
1170
modules_prepare: prepare scripts
Linus Torvalds's avatar
Linus Torvalds committed
1171 1172

# Target to install modules
1173
PHONY += modules_install
Linus Torvalds's avatar
Linus Torvalds committed
1174 1175
modules_install: _modinst_ _modinst_post

1176
PHONY += _modinst_
1177
_modinst_:
Linus Torvalds's avatar
Linus Torvalds committed
1178 1179 1180
	@rm -rf $(MODLIB)/kernel
	@rm -f $(MODLIB)/source
	@mkdir -p $(MODLIB)/kernel
1181
	@ln -s `cd $(srctree) && /bin/pwd` $(MODLIB)/source
Linus Torvalds's avatar
Linus Torvalds committed
1182 1183
	@if [ ! $(objtree) -ef  $(MODLIB)/build ]; then \
		rm -f $(MODLIB)/build ; \
1184
		ln -s $(CURDIR) $(MODLIB)/build ; \
Linus Torvalds's avatar
Linus Torvalds committed
1185
	fi
Tejun Heo's avatar
Tejun Heo committed
1186
	@cp -f $(objtree)/modules.order $(MODLIB)/
1187
	@cp -f $(objtree)/modules.builtin $(MODLIB)/
1188
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modinst
Linus Torvalds's avatar
Linus Torvalds committed
1189

1190
# This depmod is only for convenience to give the initial
Linus Torvalds's avatar
Linus Torvalds committed
1191 1192
# boot a modules.dep even before / is mounted read-write.  However the
# boot script depmod is the master version.
1193
PHONY += _modinst_post