Makefile 59.9 KB
Newer Older
1
# SPDX-License-Identifier: GPL-2.0
Linus Torvalds's avatar
Linus Torvalds committed
2
VERSION = 4
Linus Torvalds's avatar
Linus Torvalds committed
3
PATCHLEVEL = 14
Greg Kroah-Hartman's avatar
Greg Kroah-Hartman committed
4
SUBLEVEL = 167
Linus Torvalds's avatar
Linus Torvalds committed
5
EXTRAVERSION =
Greg Kroah-Hartman's avatar
Greg Kroah-Hartman committed
6
NAME = Petit Gorille
Linus Torvalds's avatar
Linus Torvalds committed
7
8
9
10
11
12
13

# *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.

14
15
16
17
# That's our default target when none is given on the command line
PHONY := _all
_all:

18
19
20
21
# 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
22

23
# Avoid funny character set dependencies
24
unexport LC_ALL
25
26
LC_COLLATE=C
LC_NUMERIC=C
27
export LC_COLLATE LC_NUMERIC
28

29
30
31
# Avoid interference with shell env settings
unexport GREP_OPTIONS

Linus Torvalds's avatar
Linus Torvalds committed
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# 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.

48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# 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
71
72
73
# To put more focus on warnings, be less verbose as default
# Use 'make V=1' to see the full commands

74
75
ifeq ("$(origin V)", "command line")
  KBUILD_VERBOSE = $(V)
Linus Torvalds's avatar
Linus Torvalds committed
76
77
78
79
80
endif
ifndef KBUILD_VERBOSE
  KBUILD_VERBOSE = 0
endif

81
82
83
84
85
86
87
88
89
90
91
ifeq ($(KBUILD_VERBOSE),1)
  quiet =
  Q =
else
  quiet=quiet_
  Q = @
endif

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

92
ifneq ($(findstring s,$(filter-out --%,$(MAKEFLAGS))),)
93
  quiet=silent_
94
  tools_silent=s
95
96
97
98
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
# 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.

114
115
# KBUILD_SRC is not intended to be used by the regular user (for now),
# it is set on invocation of make with KBUILD_OUTPUT or O= specified.
Linus Torvalds's avatar
Linus Torvalds committed
116
117
118
119
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
endif

124
125
126
# Cancel implicit rules on top Makefile
$(CURDIR)/Makefile Makefile: ;

127
128
129
130
ifneq ($(words $(subst :, ,$(CURDIR))), 1)
  $(error main directory cannot contain spaces nor colons)
endif

Linus Torvalds's avatar
Linus Torvalds committed
131
132
133
ifneq ($(KBUILD_OUTPUT),)
# check that the output directory actually exists
saved-output := $(KBUILD_OUTPUT)
134
135
KBUILD_OUTPUT := $(shell mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) \
								&& /bin/pwd)
Linus Torvalds's avatar
Linus Torvalds committed
136
$(if $(KBUILD_OUTPUT),, \
137
     $(error failed to create output directory "$(saved-output)"))
Linus Torvalds's avatar
Linus Torvalds committed
138

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

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

144
# Invoke a second make in the output directory, passing relevant variables
145
sub-make:
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
# 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.
#
Cao jin's avatar
Cao jin committed
169
170
# See the file "Documentation/dev-tools/sparse.rst" for more details,
# including where to get the "sparse" utility.
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189

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

190
191
192
193
194
195
196
197
198
199
200
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
201
202
203

export KBUILD_CHECKSRC KBUILD_EXTMOD KBUILD_SRC

204
objtree		:= .
Linus Torvalds's avatar
Linus Torvalds committed
205
206
207
src		:= $(srctree)
obj		:= $(objtree)

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

210
export srctree objtree VPATH
Linus Torvalds's avatar
Linus Torvalds committed
211

212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
# 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.
# For example 'make oldconfig all'.
# Detect when mixed targets is specified, and make a second invocation
# of make so .config is not included in this case either (for *config).

version_h := include/generated/uapi/linux/version.h
old_version_h := include/linux/version.h

no-dot-config-targets := clean mrproper distclean \
			 cscope gtags TAGS tags help% %docs check% coccicheck \
			 $(version_h) headers_% archheaders archscripts \
			 kernelversion %src-pkg

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
                ifneq ($(words $(MAKECMDGOALS)),1)
                        mixed-targets := 1
                endif
        endif
endif
# install and modules_install need also be processed one by one
ifneq ($(filter install,$(MAKECMDGOALS)),)
        ifneq ($(filter modules_install,$(MAKECMDGOALS)),)
	        mixed-targets := 1
        endif
endif

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

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

else

# We need some generic definitions (do not try to remake the file).
scripts/Kbuild.include: ;
include scripts/Kbuild.include

# Read KERNELRELEASE from include/config/kernel.release (if it exists)
KERNELRELEASE = $(shell cat include/config/kernel.release 2> /dev/null)
KERNELVERSION = $(VERSION)$(if $(PATCHLEVEL),.$(PATCHLEVEL)$(if $(SUBLEVEL),.$(SUBLEVEL)))$(EXTRAVERSION)
export VERSION PATCHLEVEL SUBLEVEL KERNELRELEASE KERNELVERSION

Linus Torvalds's avatar
Linus Torvalds committed
280
281
282
# 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,
283
# then ARCH is assigned, getting whatever value it gets normally, and
Linus Torvalds's avatar
Linus Torvalds committed
284
285
# SUBARCH is subsequently ignored.

286
287
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
288
				  -e s/arm.*/arm/ -e s/sa110/arm/ \
289
				  -e s/s390x/s390/ -e s/parisc64/parisc/ \
Paul Mundt's avatar
Paul Mundt committed
290
				  -e s/ppc.*/powerpc/ -e s/mips.*/mips/ \
291
				  -e s/sh[234].*/sh/ -e s/aarch64.*/arm64/ )
Linus Torvalds's avatar
Linus Torvalds committed
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308

# 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.
Roland McGrath's avatar
Roland McGrath committed
309
310
# 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
311
312
# Default value for CROSS_COMPILE is not to prefix executables
# Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile
313
ARCH		?= $(SUBARCH)
Roland McGrath's avatar
Roland McGrath committed
314
CROSS_COMPILE	?= $(CONFIG_CROSS_COMPILE:"%"=%)
Linus Torvalds's avatar
Linus Torvalds committed
315
316

# Architecture as present in compile.h
317
318
UTS_MACHINE 	:= $(ARCH)
SRCARCH 	:= $(ARCH)
Linus Torvalds's avatar
Linus Torvalds committed
319

320
321
322
323
324
325
326
# Additional ARCH settings for x86
ifeq ($(ARCH),i386)
        SRCARCH := x86
endif
ifeq ($(ARCH),x86_64)
        SRCARCH := x86
endif
327

Sam Ravnborg's avatar
Sam Ravnborg committed
328
# Additional ARCH settings for sparc
Namhyung Kim's avatar
Namhyung Kim committed
329
330
331
ifeq ($(ARCH),sparc32)
       SRCARCH := sparc
endif
332
ifeq ($(ARCH),sparc64)
Sam Ravnborg's avatar
Sam Ravnborg committed
333
       SRCARCH := sparc
334
endif
335

336
337
338
339
340
# Additional ARCH settings for sh
ifeq ($(ARCH),sh64)
       SRCARCH := sh
endif

341
# Additional ARCH settings for tile
342
343
344
ifeq ($(ARCH),tilepro)
       SRCARCH := tile
endif
345
346
347
348
ifeq ($(ARCH),tilegx)
       SRCARCH := tile
endif

Sam Ravnborg's avatar
Sam Ravnborg committed
349
350
351
# Where to locate arch specific headers
hdr-arch  := $(SRCARCH)

352
KCONFIG_CONFIG	?= .config
353
export KCONFIG_CONFIG
354

Linus Torvalds's avatar
Linus Torvalds committed
355
356
357
358
359
# 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)

360
361
362
HOST_LFS_CFLAGS := $(shell getconf LFS_CFLAGS 2>/dev/null)
HOST_LFS_LDFLAGS := $(shell getconf LFS_LDFLAGS 2>/dev/null)
HOST_LFS_LIBS := $(shell getconf LFS_LIBS 2>/dev/null)
363

364
365
HOSTCC       = gcc
HOSTCXX      = g++
366
367
368
369
370
HOSTCFLAGS   := -Wall -Wmissing-prototypes -Wstrict-prototypes -O2 \
		-fomit-frame-pointer -std=gnu89 $(HOST_LFS_CFLAGS)
HOSTCXXFLAGS := -O2 $(HOST_LFS_CFLAGS)
HOSTLDFLAGS  := $(HOST_LFS_LDFLAGS)
HOST_LOADLIBES := $(HOST_LFS_LIBS)
Linus Torvalds's avatar
Linus Torvalds committed
371
372
373
374
375
376
377
378
379
380
381
382
383

# 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
384
INSTALLKERNEL  := installkernel
Linus Torvalds's avatar
Linus Torvalds committed
385
386
DEPMOD		= /sbin/depmod
PERL		= perl
387
PYTHON		= python
Linus Torvalds's avatar
Linus Torvalds committed
388
389
CHECK		= sparse

390
391
CHECKFLAGS     := -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ \
		  -Wbitwise -Wno-return-void $(CF)
392
NOSTDINC_FLAGS  =
393
394
395
CFLAGS_MODULE   =
AFLAGS_MODULE   =
LDFLAGS_MODULE  =
Linus Torvalds's avatar
Linus Torvalds committed
396
397
CFLAGS_KERNEL	=
AFLAGS_KERNEL	=
398
LDFLAGS_vmlinux =
Linus Torvalds's avatar
Linus Torvalds committed
399

400
401
402
# Use USERINCLUDE when you must reference the UAPI directories only.
USERINCLUDE    := \
		-I$(srctree)/arch/$(hdr-arch)/include/uapi \
403
		-I$(objtree)/arch/$(hdr-arch)/include/generated/uapi \
404
		-I$(srctree)/include/uapi \
405
		-I$(objtree)/include/generated/uapi \
406
407
                -include $(srctree)/include/linux/kconfig.h

Linus Torvalds's avatar
Linus Torvalds committed
408
409
# Use LINUXINCLUDE when you must reference the include/ directory.
# Needed to be compatible with the O= option
410
411
LINUXINCLUDE    := \
		-I$(srctree)/arch/$(hdr-arch)/include \
412
		-I$(objtree)/arch/$(hdr-arch)/include/generated \
413
		$(if $(KBUILD_SRC), -I$(srctree)/include) \
414
415
		-I$(objtree)/include \
		$(USERINCLUDE)
Linus Torvalds's avatar
Linus Torvalds committed
416

417
KBUILD_AFLAGS   := -D__ASSEMBLY__
418
KBUILD_CFLAGS   := -Wall -Wundef -Wstrict-prototypes -Wno-trigraphs \
419
		   -fno-strict-aliasing -fno-common -fshort-wchar \
420
		   -Werror-implicit-function-declaration \
421
		   -Wno-format-security \
422
423
		   -std=gnu89
KBUILD_CPPFLAGS := -D__KERNEL__
424
425
KBUILD_AFLAGS_KERNEL :=
KBUILD_CFLAGS_KERNEL :=
426
427
428
KBUILD_AFLAGS_MODULE  := -DMODULE
KBUILD_CFLAGS_MODULE  := -DMODULE
KBUILD_LDFLAGS_MODULE := -T $(srctree)/scripts/module-common.lds
429
GCC_PLUGINS_CFLAGS :=
430
CLANG_FLAGS :=
Linus Torvalds's avatar
Linus Torvalds committed
431

432
export ARCH SRCARCH CONFIG_SHELL HOSTCC HOSTCFLAGS CROSS_COMPILE AS LD CC
433
export CPP AR NM STRIP OBJCOPY OBJDUMP HOSTLDFLAGS HOST_LOADLIBES
434
export MAKE AWK GENKSYMS INSTALLKERNEL PERL PYTHON UTS_MACHINE
435
export HOSTCXX HOSTCXXFLAGS LDFLAGS_MODULE CHECK CHECKFLAGS
Linus Torvalds's avatar
Linus Torvalds committed
436

437
export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINCLUDE OBJCOPYFLAGS LDFLAGS
438
439
export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE
export CFLAGS_KASAN CFLAGS_KASAN_NOSANITIZE CFLAGS_UBSAN
440
export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE
441
export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE
442
export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
443
export KBUILD_ARFLAGS
Linus Torvalds's avatar
Linus Torvalds committed
444
445
446
447
448
449
450
451

# 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

452
453
454
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
Jesper Juhl's avatar
Jesper Juhl committed
455
456
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
457
458
459
460

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

461
# Basic helpers built in scripts/basic/
462
PHONY += scripts_basic
Linus Torvalds's avatar
Linus Torvalds committed
463
464
scripts_basic:
	$(Q)$(MAKE) $(build)=scripts/basic
465
	$(Q)rm -f .tmp_quiet_recordmcount
Linus Torvalds's avatar
Linus Torvalds committed
466

467
468
469
# To avoid any implicit rule to kick in, define an empty command.
scripts/basic/%: scripts_basic ;

470
PHONY += outputmakefile
471
472
473
# 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
474
outputmakefile:
475
ifneq ($(KBUILD_SRC),)
476
	$(Q)ln -fsn $(srctree) source
477
478
479
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/mkmakefile \
	    $(srctree) $(objtree) $(VERSION) $(PATCHLEVEL)
endif
Linus Torvalds's avatar
Linus Torvalds committed
480

481
482
ifeq ($(cc-name),clang)
ifneq ($(CROSS_COMPILE),)
483
CLANG_FLAGS	+= --target=$(notdir $(CROSS_COMPILE:%-=%))
484
GCC_TOOLCHAIN_DIR := $(dir $(shell which $(CROSS_COMPILE)elfedit))
485
CLANG_FLAGS	+= --prefix=$(GCC_TOOLCHAIN_DIR)
486
GCC_TOOLCHAIN	:= $(realpath $(GCC_TOOLCHAIN_DIR)/..)
487
488
endif
ifneq ($(GCC_TOOLCHAIN),)
489
CLANG_FLAGS	+= --gcc-toolchain=$(GCC_TOOLCHAIN)
490
endif
491
CLANG_FLAGS	+= -no-integrated-as
492
CLANG_FLAGS	+= -Werror=unknown-warning-option
493
494
KBUILD_CFLAGS	+= $(CLANG_FLAGS)
KBUILD_AFLAGS	+= $(CLANG_FLAGS)
495
export CLANG_FLAGS
496
497
endif

498
RETPOLINE_CFLAGS_GCC := -mindirect-branch=thunk-extern -mindirect-branch-register
499
RETPOLINE_VDSO_CFLAGS_GCC := -mindirect-branch=thunk-inline -mindirect-branch-register
500
RETPOLINE_CFLAGS_CLANG := -mretpoline-external-thunk
501
RETPOLINE_VDSO_CFLAGS_CLANG := -mretpoline
502
RETPOLINE_CFLAGS := $(call cc-option,$(RETPOLINE_CFLAGS_GCC),$(call cc-option,$(RETPOLINE_CFLAGS_CLANG)))
503
RETPOLINE_VDSO_CFLAGS := $(call cc-option,$(RETPOLINE_VDSO_CFLAGS_GCC),$(call cc-option,$(RETPOLINE_VDSO_CFLAGS_CLANG)))
504
export RETPOLINE_CFLAGS
505
export RETPOLINE_VDSO_CFLAGS
506

Linus Torvalds's avatar
Linus Torvalds committed
507
508
509
510
511
512
513
514
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'
515
include arch/$(SRCARCH)/Makefile
516
export KBUILD_DEFCONFIG KBUILD_KCONFIG
Linus Torvalds's avatar
Linus Torvalds committed
517

518
519
520
521
config: scripts_basic outputmakefile FORCE
	$(Q)$(MAKE) $(build)=scripts/kconfig $@

%config: scripts_basic outputmakefile FORCE
Linus Torvalds's avatar
Linus Torvalds committed
522
523
524
525
526
527
528
	$(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.

529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
# If building an external module we do not care about the all: rule
# but instead _all depend on modules
PHONY += all
ifeq ($(KBUILD_EXTMOD),)
_all: all
else
_all: modules
endif

# Decide whether to build built-in, modular, or both.
# Normally, just do built-in.

KBUILD_MODULES :=
KBUILD_BUILTIN := 1

# 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.

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

# 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

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

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

export KBUILD_MODULES KBUILD_BUILTIN

Linus Torvalds's avatar
Linus Torvalds committed
567
568
569
ifeq ($(KBUILD_EXTMOD),)
# Additional helpers built in scripts/
# Carefully list dependencies so we do not try to build scripts twice
570
# in parallel
571
PHONY += scripts
572
scripts: scripts_basic include/config/auto.conf include/config/tristate.conf \
Emese Revfy's avatar
Emese Revfy committed
573
	 asm-generic gcc-plugins
Linus Torvalds's avatar
Linus Torvalds committed
574
575
576
577
	$(Q)$(MAKE) $(build)=$(@)

# Objects we will link into vmlinux / subdirs we need to visit
init-y		:= init/
578
drivers-y	:= drivers/ sound/ firmware/
Linus Torvalds's avatar
Linus Torvalds committed
579
580
581
net-y		:= net/
libs-y		:= lib/
core-y		:= usr/
582
virt-y		:= virt/
Linus Torvalds's avatar
Linus Torvalds committed
583
584
585
endif # KBUILD_EXTMOD

ifeq ($(dot-config),1)
586
587
# Read in config
-include include/config/auto.conf
Linus Torvalds's avatar
Linus Torvalds committed
588

589
ifeq ($(KBUILD_EXTMOD),)
Linus Torvalds's avatar
Linus Torvalds committed
590
591
# Read in dependencies to all Kconfig* files, make sure to run
# oldconfig if changes are detected.
592
-include include/config/auto.conf.cmd
Linus Torvalds's avatar
Linus Torvalds committed
593
594

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

597
# If .config is newer than include/config/auto.conf, someone tinkered
598
# with it and forgot to run make oldconfig.
599
# if auto.conf.cmd is missing then we are probably in a cleaned tree so
600
# we execute the config step to be sure to catch updated Kconfig files
601
include/config/%.conf: $(KCONFIG_CONFIG) include/config/auto.conf.cmd
Linus Torvalds's avatar
Linus Torvalds committed
602
	$(Q)$(MAKE) -f $(srctree)/Makefile silentoldconfig
603
else
604
# external modules needs include/generated/autoconf.h and include/config/auto.conf
605
606
607
608
# 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:
609
	$(Q)test -e include/generated/autoconf.h -a -e $@ || (		\
Michal Marek's avatar
Michal Marek committed
610
611
612
613
614
	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 ;							\
615
616
617
	/bin/false)

endif # KBUILD_EXTMOD
618

Linus Torvalds's avatar
Linus Torvalds committed
619
620
else
# Dummy target needed, because used as prerequisite
621
include/config/auto.conf: ;
622
endif # $(dot-config)
Linus Torvalds's avatar
Linus Torvalds committed
623

624
625
626
627
628
629
630
# For the kernel to actually contain only the needed exported symbols,
# we have to build modules as well to determine what those symbols are.
# (this can be evaluated only once include/config/auto.conf has been included)
ifdef CONFIG_TRIM_UNUSED_KSYMS
  KBUILD_MODULES := 1
endif

Linus Torvalds's avatar
Linus Torvalds committed
631
632
633
# 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
634
# Defaults to vmlinux, but the arch makefile usually adds further targets
Linus Torvalds's avatar
Linus Torvalds committed
635
636
all: vmlinux

637
638
639
640
641
642
KBUILD_CFLAGS	+= $(call cc-option,-fno-PIE)
KBUILD_AFLAGS	+= $(call cc-option,-fno-PIE)
CFLAGS_GCOV	:= -fprofile-arcs -ftest-coverage -fno-tree-loop-im $(call cc-disable-warning,maybe-uninitialized,)
CFLAGS_KCOV	:= $(call cc-option,-fsanitize-coverage=trace-pc,)
export CFLAGS_GCOV CFLAGS_KCOV

643
644
645
646
647
# 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 :=
648
include arch/$(SRCARCH)/Makefile
649
650

KBUILD_CFLAGS	+= $(call cc-option,-fno-delete-null-pointer-checks,)
651
KBUILD_CFLAGS	+= $(call cc-disable-warning,frame-address,)
652
653
654
KBUILD_CFLAGS	+= $(call cc-disable-warning, format-truncation)
KBUILD_CFLAGS	+= $(call cc-disable-warning, format-overflow)
KBUILD_CFLAGS	+= $(call cc-disable-warning, int-in-bool-context)
655
KBUILD_CFLAGS	+= $(call cc-disable-warning, address-of-packed-member)
Arnd Bergmann's avatar
Arnd Bergmann committed
656
KBUILD_CFLAGS	+= $(call cc-disable-warning, attribute-alias)
657

Linus Torvalds's avatar
Linus Torvalds committed
658
ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
659
KBUILD_CFLAGS	+= -Os $(call cc-disable-warning,maybe-uninitialized,)
Linus Torvalds's avatar
Linus Torvalds committed
660
else
661
ifdef CONFIG_PROFILE_ALL_BRANCHES
662
KBUILD_CFLAGS	+= -O2 $(call cc-disable-warning,maybe-uninitialized,)
663
664
665
else
KBUILD_CFLAGS   += -O2
endif
Linus Torvalds's avatar
Linus Torvalds committed
666
667
endif

668
669
670
KBUILD_CFLAGS += $(call cc-ifversion, -lt, 0409, \
			$(call cc-disable-warning,maybe-uninitialized,))

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

674
675
676
677
678
679
# check for 'asm goto'
ifeq ($(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-goto.sh $(CC) $(KBUILD_CFLAGS)), y)
	KBUILD_CFLAGS += -DCC_HAVE_ASM_GOTO
	KBUILD_AFLAGS += -DCC_HAVE_ASM_GOTO
endif

Emese Revfy's avatar
Emese Revfy committed
680
681
include scripts/Makefile.gcc-plugins

Andi Kleen's avatar
Andi Kleen committed
682
683
684
685
686
687
688
689
690
691
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

692
ifneq ($(CONFIG_FRAME_WARN),0)
693
694
695
KBUILD_CFLAGS += $(call cc-option,-Wframe-larger-than=${CONFIG_FRAME_WARN})
endif

696
697
698
# This selects the stack protector compiler flag. Testing it is delayed
# until after .config has been reprocessed, in the prepare-compiler-check
# target.
699
ifdef CONFIG_CC_STACKPROTECTOR_REGULAR
700
  stackp-flag := -fstack-protector
701
  stackp-name := REGULAR
702
703
else
ifdef CONFIG_CC_STACKPROTECTOR_STRONG
704
  stackp-flag := -fstack-protector-strong
705
  stackp-name := STRONG
706
707
708
else
  # Force off for distro compilers that enable stack protector by default.
  stackp-flag := $(call cc-option, -fno-stack-protector)
Tejun Heo's avatar
Tejun Heo committed
709
endif
710
endif
711
712
# Find arch-specific stack protector compiler sanity-checking script.
ifdef CONFIG_CC_STACKPROTECTOR
713
714
  stackp-path := $(srctree)/scripts/gcc-$(SRCARCH)_$(BITS)-has-stack-protector.sh
  stackp-check := $(wildcard $(stackp-path))
715
endif
716
KBUILD_CFLAGS += $(stackp-flag)
717

718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
ifeq ($(cc-name),clang)
KBUILD_CPPFLAGS += $(call cc-option,-Qunused-arguments,)
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,)
KBUILD_CFLAGS += $(call cc-option, -fcatch-undefined-behavior)
else

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

736
KBUILD_CFLAGS += $(call cc-disable-warning, unused-const-variable)
Linus Torvalds's avatar
Linus Torvalds committed
737
ifdef CONFIG_FRAME_POINTER
738
KBUILD_CFLAGS	+= -fno-omit-frame-pointer -fno-optimize-sibling-calls
Linus Torvalds's avatar
Linus Torvalds committed
739
else
740
741
742
743
744
745
# 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
746
KBUILD_CFLAGS	+= -fomit-frame-pointer
Linus Torvalds's avatar
Linus Torvalds committed
747
endif
748
endif
Linus Torvalds's avatar
Linus Torvalds committed
749

750
751
KBUILD_CFLAGS   += $(call cc-option, -fno-var-tracking-assignments)

Linus Torvalds's avatar
Linus Torvalds committed
752
ifdef CONFIG_DEBUG_INFO
753
754
755
ifdef CONFIG_DEBUG_INFO_SPLIT
KBUILD_CFLAGS   += $(call cc-option, -gsplit-dwarf, -g)
else
756
KBUILD_CFLAGS	+= -g
757
endif
758
KBUILD_AFLAGS	+= -Wa,-gdwarf-2
Linus Torvalds's avatar
Linus Torvalds committed
759
endif
760
761
762
ifdef CONFIG_DEBUG_INFO_DWARF4
KBUILD_CFLAGS	+= $(call cc-option, -gdwarf-4,)
endif
Linus Torvalds's avatar
Linus Torvalds committed
763

764
ifdef CONFIG_DEBUG_INFO_REDUCED
765
766
KBUILD_CFLAGS 	+= $(call cc-option, -femit-struct-debug-baseonly) \
		   $(call cc-option,-fno-var-tracking)
767
768
endif

769
ifdef CONFIG_FUNCTION_TRACER
770
771
772
773
ifndef CC_FLAGS_FTRACE
CC_FLAGS_FTRACE := -pg
endif
export CC_FLAGS_FTRACE
774
775
776
ifdef CONFIG_HAVE_FENTRY
CC_USING_FENTRY	:= $(call cc-option, -mfentry -DCC_USING_FENTRY)
endif
777
KBUILD_CFLAGS	+= $(CC_FLAGS_FTRACE) $(CC_USING_FENTRY)
778
KBUILD_AFLAGS	+= $(CC_USING_FENTRY)
779
ifdef CONFIG_DYNAMIC_FTRACE
780
	ifdef CONFIG_HAVE_C_RECORDMCOUNT
781
782
783
784
		BUILD_C_RECORDMCOUNT := y
		export BUILD_C_RECORDMCOUNT
	endif
endif
785
786
endif

787
788
789
790
791
# We trigger additional mismatches with less inlining
ifdef CONFIG_DEBUG_SECTION_MISMATCH
KBUILD_CFLAGS += $(call cc-option, -fno-inline-functions-called-once)
endif

792
793
794
795
796
ifdef CONFIG_LD_DEAD_CODE_DATA_ELIMINATION
KBUILD_CFLAGS	+= $(call cc-option,-ffunction-sections,)
KBUILD_CFLAGS	+= $(call cc-option,-fdata-sections,)
endif

797
# arch Makefile may override CC so keep this after arch Makefile is included
798
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
799
800
CHECKFLAGS     += $(NOSTDINC_FLAGS)

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

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

807
808
809
# disable stringop warnings in gcc 8+
KBUILD_CFLAGS += $(call cc-disable-warning, stringop-truncation)

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

813
814
815
816
817
818
819
820
821
# clang sets -fmerge-all-constants by default as optimization, but this
# is non-conforming behavior for C and in fact breaks the kernel, so we
# need to disable it here generally.
KBUILD_CFLAGS	+= $(call cc-option,-fno-merge-all-constants)

# for gcc -fno-merge-all-constants disables everything, but it is fine
# to have actual conforming behavior enabled.
KBUILD_CFLAGS	+= $(call cc-option,-fmerge-constants)

822
823
824
# Make sure -fstack-check isn't enabled (like gentoo apparently did)
KBUILD_CFLAGS  += $(call cc-option,-fno-stack-check,)

825
826
827
# conserve stack if available
KBUILD_CFLAGS   += $(call cc-option,-fconserve-stack)

828
829
830
831
832
833
# 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)

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

837
838
839
# enforce correct pointer usage
KBUILD_CFLAGS   += $(call cc-option,-Werror=incompatible-pointer-types)

840
841
842
# Require designated initializers for all marked structures
KBUILD_CFLAGS   += $(call cc-option,-Werror=designated-init)

843
844
845
# change __FILE__ to the relative path from the srctree
KBUILD_CFLAGS	+= $(call cc-option,-fmacro-prefix-map=$(srctree)/=)

846
847
848
849
850
851
# ensure -fcf-protection is disabled when using retpoline as it is
# incompatible with -mindirect-branch=thunk-extern
ifdef CONFIG_RETPOLINE
KBUILD_CFLAGS += $(call cc-option,-fcf-protection=none)
endif

852
853
854
# use the deterministic mode of AR if available
KBUILD_ARFLAGS := $(call ar-option,D)

855
856
include scripts/Makefile.kasan
include scripts/Makefile.extrawarn
857
include scripts/Makefile.ubsan
858

859
860
861
862
863
# 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)
864

Roland McGrath's avatar
Roland McGrath committed
865
# Use --build-id when available.
866
LDFLAGS_BUILD_ID := $(patsubst -Wl$(comma)%,%,\
867
			      $(call cc-ldoption, -Wl$(comma)--build-id,))
868
KBUILD_LDFLAGS_MODULE += $(LDFLAGS_BUILD_ID)
Roland McGrath's avatar
Roland McGrath committed
869
870
LDFLAGS_vmlinux += $(LDFLAGS_BUILD_ID)

871
872
873
874
ifdef CONFIG_LD_DEAD_CODE_DATA_ELIMINATION
LDFLAGS_vmlinux	+= $(call ld-option, --gc-sections,)
endif

875
ifeq ($(CONFIG_STRIP_ASM_SYMS),y)
876
LDFLAGS_vmlinux	+= $(call ld-option, -X,)
877
878
endif

Linus Torvalds's avatar
Linus Torvalds committed
879
# Default kernel image to build when no specific target is given.
880
# KBUILD_IMAGE may be overruled on the command line or
Linus Torvalds's avatar
Linus Torvalds committed
881
882
883
884
885
886
887
888
889
890
# 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

891
892
893
894
895
896
897
#
# 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
898
899
900
#
# INSTALL_MOD_PATH specifies a prefix to MODLIB for module directory
# relocations required by build roots.  This is not defined in the
901
# makefile but the argument can be passed to make if needed.
Linus Torvalds's avatar
Linus Torvalds committed
902
903
#

904
MODLIB	= $(INSTALL_MOD_PATH)/lib/modules/$(KERNELRELEASE)
Linus Torvalds's avatar
Linus Torvalds committed
905
906
export MODLIB

907
#
908
909
910
911
# 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.
912

913
914
ifdef INSTALL_MOD_STRIP
ifeq ($(INSTALL_MOD_STRIP),1)
915
mod_strip_cmd = $(STRIP) --strip-debug
916
else
917
mod_strip_cmd = $(STRIP) $(INSTALL_MOD_STRIP)
918
919
endif # INSTALL_MOD_STRIP=1
else
920
mod_strip_cmd = true
921
922
923
endif # INSTALL_MOD_STRIP
export mod_strip_cmd

924
925
926
927
928
929
930
# 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
931
    mod_compress_cmd = gzip -n -f
932
933
  endif # CONFIG_MODULE_COMPRESS_GZIP
  ifdef CONFIG_MODULE_COMPRESS_XZ
934
    mod_compress_cmd = xz -f
935
936
937
938
  endif # CONFIG_MODULE_COMPRESS_XZ
endif # CONFIG_MODULE_COMPRESS
export mod_compress_cmd

939
940
941
# 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
942
943
944
945
946
947
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
948
949
950
# 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
951

952
ifdef CONFIG_MODULE_SIG_ALL
953
954
955
$(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
956
957
958
959
960
else
mod_sign_cmd = true
endif
export mod_sign_cmd

961
962
HOST_LIBELF_LIBS = $(shell pkg-config libelf --libs 2>/dev/null || echo -lelf)

963
964
ifdef CONFIG_STACK_VALIDATION
  has_libelf := $(call try-run,\
965
		echo "int main() {}" | $(HOSTCC) -xc -o /dev/null $(HOST_LIBELF_LIBS) -,1,0)
966
967
968
969
970
971
972
973
  ifeq ($(has_libelf),1)
    objtool_target := tools/objtool FORCE
  else
    SKIP_STACK_VALIDATION := 1
    export SKIP_STACK_VALIDATION
  endif
endif

974

Linus Torvalds's avatar
Linus Torvalds committed
975
ifeq ($(KBUILD_EXTMOD),)
976
core-y		+= kernel/ certs/ mm/ fs/ ipc/ security/ crypto/ block/
Linus Torvalds's avatar
Linus Torvalds committed
977
978
979

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

vmlinux-alldirs	:= $(sort $(vmlinux-dirs) $(patsubst %/,%,$(filter %/, \
983
		     $(init-) $(core-) $(drivers-) $(net-) $(libs-) $(virt-))))
Linus Torvalds's avatar
Linus Torvalds committed
984
985
986
987
988
989

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))
990
libs-y2		:= $(filter-out %.a, $(patsubst %/, %/built-in.o, $(libs-y)))
991
virt-y		:= $(patsubst %/, %/built-in.o, $(virt-y))
Linus Torvalds's avatar
Linus Torvalds committed
992

993
# Externally visible symbols (used by link-vmlinux.sh)
994
export KBUILD_VMLINUX_INIT := $(head-y) $(init-y)
995
996
export KBUILD_VMLINUX_MAIN := $(core-y) $(libs-y2) $(drivers-y) $(net-y) $(virt-y)
export KBUILD_VMLINUX_LIBS := $(libs-y1)
997
export KBUILD_LDS          := arch/$(SRCARCH)/kernel/vmlinux.lds
998
export LDFLAGS_vmlinux
999
# used by scripts/package/Makefile
1000
export KBUILD_ALLDIRS := $(sort $(filter-out arch/%,$(vmlinux-alldirs)) arch Documentation include samples scripts tools)
1001

1002
vmlinux-deps := $(KBUILD_LDS) $(KBUILD_VMLINUX_INIT) $(KBUILD_VMLINUX_MAIN) $(KBUILD_VMLINUX_LIBS)
Linus Torvalds's avatar
Linus Torvalds committed
1003

1004
1005
1006
1007
1008
# 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
1009
ifdef CONFIG_HEADERS_CHECK
1010
	$(Q)$(MAKE) -f $(srctree)/Makefile headers_check
1011
endif
Jan Kiszka's avatar
Jan Kiszka committed
1012
ifdef CONFIG_GDB_SCRIPTS
1013
	$(Q)ln -fsn $(abspath $(srctree)/scripts/gdb/vmlinux-gdb.py)
1014
endif
1015
ifdef CONFIG_TRIM_UNUSED_KSYMS
1016
	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/adjust_autoksyms.sh \
1017
	  "$(MAKE) -f $(srctree)/Makefile vmlinux"
1018
endif
1019
1020
1021

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

1024
1025
1026
ARCH_POSTLINK := $(wildcard $(srctree)/arch/$(SRCARCH)/Makefile.postlink)

# Final link of vmlinux with optional arch pass after final link
1027
1028
cmd_link-vmlinux =                                                 \
	$(CONFIG_SHELL) $< $(LD) $(LDFLAGS) $(LDFLAGS_vmlinux) ;    \
1029
	$(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) $@, true)
1030

1031
vmlinux: scripts/link-vmlinux.sh vmlinux_prereq $(vmlinux-deps) FORCE
1032
	+$(call if_changed,link-vmlinux)
1033

1034
1035
1036
1037
1038
# Build samples along the rest of the kernel
ifdef CONFIG_SAMPLES
vmlinux-dirs += samples
endif

1039
# The actual objects are generated when descending,
Linus Torvalds's avatar
Linus Torvalds committed
1040
# make sure no implicit rule kicks in
1041
$(sort $(vmlinux-deps)): $(vmlinux-dirs) ;
Linus Torvalds's avatar
Linus Torvalds committed
1042
1043
1044
1045
1046
1047
1048

# 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

1049
PHONY += $(vmlinux-dirs)
1050
$(vmlinux-dirs): prepare scripts
Linus Torvalds's avatar
Linus Torvalds committed
1051
1052
	$(Q)$(MAKE) $(build)=$@

1053
1054
1055
1056
define filechk_kernel.release
	echo "$(KERNELVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
endef

1057
# Store (new) KERNELRELEASE string in include/config/kernel.release
Roman Zippel's avatar
Roman Zippel committed
1058
include/config/kernel.release: include/config/auto.conf FORCE
1059
	$(call filechk,kernel.release)
1060
1061


Linus Torvalds's avatar
Linus Torvalds committed
1062
# Things we need to do before we recursively start building the kernel
1063
1064
1065
1066
# 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
1067

1068
# Listed in dependency order
1069
PHONY += prepare archprepare prepare0 prepare1 prepare2 prepare3
1070

1071
# prepare3 is used to check if we are building in a separate output directory,
Linus Torvalds's avatar
Linus Torvalds committed
1072
1073
# and if so do:
# 1) Check that make has not been executed in the kernel src $(srctree)
Roman Zippel's avatar
Roman Zippel committed
1074
prepare3: include/config/kernel.release
Linus Torvalds's avatar
Linus Torvalds committed
1075
ifneq ($(KBUILD_SRC),)
1076
	@$(kecho) '  Using $(srctree) as source for kernel'
1077
	$(Q)if [ -f $(srctree)/.config -o -d $(srctree)/include/config ]; then \
Michal Marek's avatar
Michal Marek committed
1078
1079
		echo >&2 "  $(srctree) is not clean, please run 'make mrproper'"; \
		echo >&2 "  in the '$(srctree)' directory.";\
Linus Torvalds's avatar
Linus Torvalds committed
1080
1081
1082
1083
		/bin/false; \
	fi;
endif

1084
1085
1086
1087
# prepare2 creates a makefile if using a separate output directory.
# From this point forward, .config has been reprocessed, so any rules
# that need to depend on updated CONFIG_* values can be checked here.
prepare2: prepare3 prepare-compiler-check outputmakefile asm-generic
Linus Torvalds's avatar
Linus Torvalds committed
1088

David Howells's avatar
David Howells committed
1089
prepare1: prepare2 $(version_h) include/generated/utsrelease.h \
Sam Ravnborg's avatar
Sam Ravnborg committed
1090
                   include/config/auto.conf
Sam Ravnborg's avatar
Sam Ravnborg committed
1091
	$(cmd_crmodverdir)
Linus Torvalds's avatar
Linus Torvalds committed
1092

1093
archprepare: archheaders archscripts prepare1 scripts_basic
1094

Emese Revfy's avatar
Emese Revfy committed
1095
prepare0: archprepare gcc-plugins
1096
	$(Q)$(MAKE) $(build)=.
1097

Linus Torvalds's avatar
Linus Torvalds committed
1098
# All the preparing..
1099
1100
prepare: prepare0 prepare-objtool

1101
1102
1103
1104
1105
1106
1107
1108
1109
# Support for using generic headers in asm-generic
PHONY += asm-generic uapi-asm-generic
asm-generic: uapi-asm-generic
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.asm-generic \
	            src=asm obj=arch/$(SRCARCH)/include/generated/asm
uapi-asm-generic:
	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.asm-generic \
	            src=uapi/asm obj=arch/$(SRCARCH)/include/generated/uapi/asm

1110
PHONY += prepare-objtool
1111
prepare-objtool: $(objtool_target)
1112
1113
1114
1115
1116
1117
1118
1119
ifeq ($(SKIP_STACK_VALIDATION),1)
ifdef CONFIG_UNWINDER_ORC
	@echo "error: Cannot generate ORC metadata for CONFIG_UNWINDER_ORC=y, please install libelf-dev, libelf-devel or elfutils-libelf-devel" >&2
	@false
else
	@echo "warning: Cannot use CONFIG_STACK_VALIDATION=y, please install libelf-dev, libelf-devel or elfutils-libelf-devel" >&2
endif
endif
Linus Torvalds's avatar
Linus Torvalds committed
1120

1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
# Check for CONFIG flags that require compiler support. Abort the build
# after .config has been processed, but before the kernel build starts.
#
# For security-sensitive CONFIG options, 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. (For example, "But I selected
# CC_STACKPROTECTOR_STRONG! Why did it build with _REGULAR?!")
PHONY += prepare-compiler-check
prepare-compiler-check: FORCE
# Make sure compiler supports requested stack protector flag.
ifdef stackp-name
  ifeq ($(call cc-option, $(stackp-flag)),)
	@echo Cannot use CONFIG_CC_STACKPROTECTOR_$(stackp-name): \
		  $(stackp-flag) not supported by compiler >&2 && exit 1
  endif
endif
# Make sure compiler does not have buggy stack-protector support.
ifdef stackp-check
  ifneq ($(shell $(CONFIG_SHELL) $(stackp-check) $(CC) $(KBUILD_CPPFLAGS) $(biarch)),y)
	@echo Cannot use CONFIG_CC_STACKPROTECTOR_$(stackp-name): \
                  $(stackp-flag) available but compiler is broken >&2 && exit 1
  endif
endif
	@:

Linus Torvalds's avatar
Linus Torvalds committed
1147
1148
1149
1150
1151
1152
1153
# 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
Sam Ravnborg's avatar
Sam Ravnborg committed
1154
1155
1156
1157