Blame view

Makefile 62.9 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  # SPDX-License-Identifier: GPL-2.0
bfeffd155   Linus Torvalds   Linux 5.0-rc1
2
  VERSION = 5
3650b228f   Linus Torvalds   Linux 5.10-rc1
3
  PATCHLEVEL = 10
e2d133180   Greg Kroah-Hartman   Linux 5.10.9
4
  SUBLEVEL = 9
2c85ebc57   Linus Torvalds   Linux 5.10
5
  EXTRAVERSION =
d6d5df1db   Linus Torvalds   Linux 5.4-rc5
6
  NAME = Kleptomaniac Octopus
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
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.
121c2a137   Masahiro Yamada   kbuild: error out...
13
14
  $(if $(filter __%, $(MAKECMDGOALS)), \
  	$(error targets prefixed with '__' are only for internal use))
ba634eceb   Masahiro Yamada   kbuild: move "_al...
15
  # That's our default target when none is given on the command line
121c2a137   Masahiro Yamada   kbuild: error out...
16
17
  PHONY := __all
  __all:
ba634eceb   Masahiro Yamada   kbuild: move "_al...
18

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
19
20
21
22
23
24
  # 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
f49821ee3   Nicholas Piggin   kbuild: rename bu...
25
  # unavoidable when linking the built-in.a targets which finally
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
26
27
28
29
30
31
32
33
  # 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.
221cc2d27   Masahiro Yamada   kbuild: skip pars...
34
  ifneq ($(sub_make_done),1)
3812b8c5c   Masahiro Yamada   kbuild: make -r/-...
35
36
37
38
39
40
41
42
43
44
45
46
47
  
  # Do not use make's built-in rules and variables
  # (this increases performance and avoids hard-to-debug behaviour)
  MAKEFLAGS += -rR
  
  # Avoid funny character set dependencies
  unexport LC_ALL
  LC_COLLATE=C
  LC_NUMERIC=C
  export LC_COLLATE LC_NUMERIC
  
  # Avoid interference with shell env settings
  unexport GREP_OPTIONS
066b7ed95   Michal Marek   kbuild: Do not pr...
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
  # 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.
505b12b38   Randy Dunlap   kbuild: add comme...
70
  # If KBUILD_VERBOSE equals 2 then give the reason why each target is rebuilt.
066b7ed95   Michal Marek   kbuild: Do not pr...
71
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
72
73
  # To put more focus on warnings, be less verbose as default
  # Use 'make V=1' to see the full commands
b8b0618cf   Cheng Renquan   kbuild: remove ex...
74
75
  ifeq ("$(origin V)", "command line")
    KBUILD_VERBOSE = $(V)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
76
77
78
79
  endif
  ifndef KBUILD_VERBOSE
    KBUILD_VERBOSE = 0
  endif
066b7ed95   Michal Marek   kbuild: Do not pr...
80
81
82
83
84
85
86
87
88
89
  ifeq ($(KBUILD_VERBOSE),1)
    quiet =
    Q =
  else
    quiet=quiet_
    Q = @
  endif
  
  # If the user is running make -s (silent mode), suppress echoing of
  # commands
6f0fa58e4   Masahiro Yamada   kbuild: simplify ...
90
  ifneq ($(findstring s,$(filter-out --%,$(MAKEFLAGS))),)
066b7ed95   Michal Marek   kbuild: Do not pr...
91
92
    quiet=silent_
  endif
066b7ed95   Michal Marek   kbuild: Do not pr...
93
94
  
  export quiet Q KBUILD_VERBOSE
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
95
96
97
98
99
100
101
102
103
104
  # Kbuild will save output files in the current working directory.
  # This does not need to match to the root of the kernel source tree.
  #
  # For example, you can do this:
  #
  #  cd /dir/to/store/output/files; make -f /dir/to/kernel/source/Makefile
  #
  # If you want to save output files in a different location, there are
  # two syntaxes to specify it.
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
105
106
  # 1) O=
  # Use "make O=dir/to/store/output/files/"
070b98bfd   Sam Ravnborg   kbuild: trivial f...
107
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
108
  # 2) Set KBUILD_OUTPUT
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
109
110
  # Set the environment variable KBUILD_OUTPUT to point to the output directory.
  # export KBUILD_OUTPUT=dir/to/store/output/files/; make
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
111
112
113
  #
  # The O= assignment takes precedence over the KBUILD_OUTPUT environment
  # variable.
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
114
  # Do we want to change the working directory?
b8b0618cf   Cheng Renquan   kbuild: remove ex...
115
116
  ifeq ("$(origin O)", "command line")
    KBUILD_OUTPUT := $(O)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
117
  endif
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
  ifneq ($(KBUILD_OUTPUT),)
  # Make's built-in functions such as $(abspath ...), $(realpath ...) cannot
  # expand a shell special character '~'. We use a somewhat tedious way here.
  abs_objtree := $(shell mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) && pwd)
  $(if $(abs_objtree),, \
       $(error failed to create output directory "$(KBUILD_OUTPUT)"))
  
  # $(realpath ...) resolves symlinks
  abs_objtree := $(realpath $(abs_objtree))
  else
  abs_objtree := $(CURDIR)
  endif # ifneq ($(KBUILD_OUTPUT),)
  
  ifeq ($(abs_objtree),$(CURDIR))
  # Suppress "Entering directory ..." unless we are changing the work directory.
  MAKEFLAGS += --no-print-directory
  else
  need-sub-make := 1
51193b76b   Robert Jarzmik   kbuild: forbid ke...
136
  endif
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
137
  abs_srctree := $(realpath $(dir $(lastword $(MAKEFILE_LIST))))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
138

25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
139
140
141
  ifneq ($(words $(subst :, ,$(abs_srctree))), 1)
  $(error source directory cannot contain spaces or colons)
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
142

25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
143
  ifneq ($(abs_srctree),$(abs_objtree))
80463f1b7   Masahiro Yamada   kbuild: add --inc...
144
145
146
  # Look for make include files relative to root of kernel src
  #
  # This does not become effective immediately because MAKEFLAGS is re-parsed
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
147
148
  # once after the Makefile is read. We need to invoke sub-make.
  MAKEFLAGS += --include-dir=$(abs_srctree)
688931a5a   Masahiro Yamada   kbuild: skip sub-...
149
  need-sub-make := 1
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
150
  endif
3812b8c5c   Masahiro Yamada   kbuild: make -r/-...
151

93fdddfef   Masahiro Yamada   kbuild: add this-...
152
  this-makefile := $(lastword $(MAKEFILE_LIST))
688931a5a   Masahiro Yamada   kbuild: skip sub-...
153
154
155
156
157
  ifneq ($(filter 3.%,$(MAKE_VERSION)),)
  # 'MAKEFLAGS += -rR' does not immediately become effective for GNU Make 3.x
  # We need to invoke sub-make to avoid implicit rules in the top Makefile.
  need-sub-make := 1
  # Cancel implicit rules for this Makefile.
93fdddfef   Masahiro Yamada   kbuild: add this-...
158
  $(this-makefile): ;
688931a5a   Masahiro Yamada   kbuild: skip sub-...
159
  endif
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
160
  export abs_srctree abs_objtree
221cc2d27   Masahiro Yamada   kbuild: skip pars...
161
  export sub_make_done := 1
688931a5a   Masahiro Yamada   kbuild: skip sub-...
162
  ifeq ($(need-sub-make),1)
121c2a137   Masahiro Yamada   kbuild: error out...
163
  PHONY += $(MAKECMDGOALS) __sub-make
0b35786d7   Milton Miller   kbuild: call make...
164

121c2a137   Masahiro Yamada   kbuild: error out...
165
  $(filter-out $(this-makefile), $(MAKECMDGOALS)) __all: __sub-make
16f890988   Charles Keepax   kbuild: Remove re...
166
  	@:
0b35786d7   Milton Miller   kbuild: call make...
167

c4e6fff1a   Cao jin   kbuild: improve c...
168
  # Invoke a second make in the output directory, passing relevant variables
121c2a137   Masahiro Yamada   kbuild: error out...
169
  __sub-make:
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
170
  	$(Q)$(MAKE) -C $(abs_objtree) -f $(abs_srctree)/Makefile $(MAKECMDGOALS)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
171

688931a5a   Masahiro Yamada   kbuild: skip sub-...
172
  endif # need-sub-make
221cc2d27   Masahiro Yamada   kbuild: skip pars...
173
  endif # sub_make_done
688931a5a   Masahiro Yamada   kbuild: skip sub-...
174

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
175
  # We process the rest of the Makefile if this is the final invocation of make
688931a5a   Masahiro Yamada   kbuild: skip sub-...
176
  ifeq ($(need-sub-make),)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
177

7ff525712   Masahiro Yamada   kbuild: fake the ...
178
179
180
181
  # 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
aa55c8e2f   Masahiro Yamada   kbuild: handle C=...
182
183
184
185
186
187
188
  # 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.
  #
036db11ca   Cao jin   sparse doc: fix r...
189
190
  # See the file "Documentation/dev-tools/sparse.rst" for more details,
  # including where to get the "sparse" utility.
aa55c8e2f   Masahiro Yamada   kbuild: handle C=...
191
192
193
194
195
196
197
  
  ifeq ("$(origin C)", "command line")
    KBUILD_CHECKSRC = $(C)
  endif
  ifndef KBUILD_CHECKSRC
    KBUILD_CHECKSRC = 0
  endif
7e35b4259   Masahiro Yamada   kbuild: remove SU...
198
199
  # Use make M=dir or set the environment variable KBUILD_EXTMOD to specify the
  # directory of external module to build. Setting M= takes precedence.
aa55c8e2f   Masahiro Yamada   kbuild: handle C=...
200
201
202
  ifeq ("$(origin M)", "command line")
    KBUILD_EXTMOD := $(M)
  endif
e9e81b634   Masahiro Yamada   kbuild: disallow ...
203
204
  $(if $(word 2, $(KBUILD_EXTMOD)), \
  	$(error building multiple external modules is not supported))
051f278e9   Masahiro Yamada   kbuild: replace K...
205
  export KBUILD_CHECKSRC KBUILD_EXTMOD
394053f4a   Masahiro Yamada   kbuild: make sing...
206
  extmod-prefix = $(if $(KBUILD_EXTMOD),$(KBUILD_EXTMOD)/)
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
207
  ifeq ($(abs_srctree),$(abs_objtree))
9da0763bd   Michal Marek   kbuild: Use relat...
208
209
          # building in the source tree
          srctree := .
051f278e9   Masahiro Yamada   kbuild: replace K...
210
  	building_out_of_srctree :=
9da0763bd   Michal Marek   kbuild: Use relat...
211
  else
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
212
          ifeq ($(abs_srctree)/,$(dir $(abs_objtree)))
9da0763bd   Michal Marek   kbuild: Use relat...
213
214
215
                  # building in a subdirectory of the source tree
                  srctree := ..
          else
25b146c5b   Masahiro Yamada   kbuild: allow Kbu...
216
                  srctree := $(abs_srctree)
9da0763bd   Michal Marek   kbuild: Use relat...
217
          endif
051f278e9   Masahiro Yamada   kbuild: replace K...
218
  	building_out_of_srctree := 1
9da0763bd   Michal Marek   kbuild: Use relat...
219
  endif
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
220

95fd3f87b   Masahiro Yamada   kbuild: add a fla...
221
222
223
  ifneq ($(KBUILD_ABS_SRCTREE),)
  srctree := $(abs_srctree)
  endif
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
224

7e1c04779   Michal Marek   kbuild: Use relat...
225
  objtree		:= .
6b12de69a   Masahiro Yamada   kbuild: simplify ...
226
  VPATH		:= $(srctree)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
227

051f278e9   Masahiro Yamada   kbuild: replace K...
228
  export building_out_of_srctree srctree objtree VPATH
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
229

2c1f4f125   Masahiro Yamada   kbuild: re-order ...
230
231
232
233
234
235
236
237
238
239
  # 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
22340a065   Masahiro Yamada   kbuild: process m...
240
241
  clean-targets := %clean mrproper cleandocs
  no-dot-config-targets := $(clean-targets) \
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
242
  			 cscope gtags TAGS tags help% %docs check% coccicheck \
59b2bd05f   Masahiro Yamada   kbuild: add 'head...
243
  			 $(version_h) headers headers_% archheaders archscripts \
4623980de   David Engraf   kbuild: add outpu...
244
245
  			 %asm-generic kernelversion %src-pkg dt_binding_check \
  			 outputmakefile
efbf97265   Masahiro Yamada   kbuild: remove re...
246
  no-sync-config-targets := $(no-dot-config-targets) %install kernelrelease
394053f4a   Masahiro Yamada   kbuild: make sing...
247
  single-targets := %.a %.i %.ko %.lds %.ll %.lst %.mod %.o %.s %.symtypes %/
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
248

2042b5486   Masahiro Yamada   kbuild: unset var...
249
250
251
252
  config-build	:=
  mixed-build	:=
  need-config	:= 1
  may-sync-config	:= 1
394053f4a   Masahiro Yamada   kbuild: make sing...
253
  single-build	:=
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
254
255
256
  
  ifneq ($(filter $(no-dot-config-targets), $(MAKECMDGOALS)),)
  	ifeq ($(filter-out $(no-dot-config-targets), $(MAKECMDGOALS)),)
2042b5486   Masahiro Yamada   kbuild: unset var...
257
  		need-config :=
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
258
259
  	endif
  endif
d79424137   Masahiro Yamada   kbuild: do not up...
260
261
  ifneq ($(filter $(no-sync-config-targets), $(MAKECMDGOALS)),)
  	ifeq ($(filter-out $(no-sync-config-targets), $(MAKECMDGOALS)),)
2042b5486   Masahiro Yamada   kbuild: unset var...
262
  		may-sync-config :=
d79424137   Masahiro Yamada   kbuild: do not up...
263
264
265
266
  	endif
  endif
  
  ifneq ($(KBUILD_EXTMOD),)
2042b5486   Masahiro Yamada   kbuild: unset var...
267
  	may-sync-config :=
d79424137   Masahiro Yamada   kbuild: do not up...
268
  endif
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
269
  ifeq ($(KBUILD_EXTMOD),)
efbf97265   Masahiro Yamada   kbuild: remove re...
270
          ifneq ($(filter %config,$(MAKECMDGOALS)),)
2042b5486   Masahiro Yamada   kbuild: unset var...
271
  		config-build := 1
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
272
                  ifneq ($(words $(MAKECMDGOALS)),1)
2042b5486   Masahiro Yamada   kbuild: unset var...
273
  			mixed-build := 1
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
274
275
276
                  endif
          endif
  endif
22340a065   Masahiro Yamada   kbuild: process m...
277

394053f4a   Masahiro Yamada   kbuild: make sing...
278
279
280
281
282
283
284
  # We cannot build single targets and the others at the same time
  ifneq ($(filter $(single-targets), $(MAKECMDGOALS)),)
  	single-build := 1
  	ifneq ($(filter-out $(single-targets), $(MAKECMDGOALS)),)
  		mixed-build := 1
  	endif
  endif
22340a065   Masahiro Yamada   kbuild: process m...
285
286
287
  # For "make -j clean all", "make -j mrproper defconfig all", etc.
  ifneq ($(filter $(clean-targets),$(MAKECMDGOALS)),)
          ifneq ($(filter-out $(clean-targets),$(MAKECMDGOALS)),)
2042b5486   Masahiro Yamada   kbuild: unset var...
288
  		mixed-build := 1
22340a065   Masahiro Yamada   kbuild: process m...
289
290
          endif
  endif
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
291
292
293
  # install and modules_install need also be processed one by one
  ifneq ($(filter install,$(MAKECMDGOALS)),)
          ifneq ($(filter modules_install,$(MAKECMDGOALS)),)
2042b5486   Masahiro Yamada   kbuild: unset var...
294
  		mixed-build := 1
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
295
296
          endif
  endif
2042b5486   Masahiro Yamada   kbuild: unset var...
297
  ifdef mixed-build
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
298
299
300
301
302
  # ===========================================================================
  # We're called with mixed targets (*config and build targets).
  # Handle them one by one.
  
  PHONY += $(MAKECMDGOALS) __build_one_by_one
121c2a137   Masahiro Yamada   kbuild: error out...
303
  $(MAKECMDGOALS): __build_one_by_one
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
304
305
306
307
308
309
310
  	@:
  
  __build_one_by_one:
  	$(Q)set -e; \
  	for i in $(MAKECMDGOALS); do \
  		$(MAKE) -f $(srctree)/Makefile $$i; \
  	done
2042b5486   Masahiro Yamada   kbuild: unset var...
311
  else # !mixed-build
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
312

2c1f4f125   Masahiro Yamada   kbuild: re-order ...
313
314
315
316
317
318
  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
b2d35fa5f   Anders Roxell   selftests: add he...
319
  include scripts/subarch.include
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
  
  # 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.
  # Default value for CROSS_COMPILE is not to prefix executables
  # Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile
2331d1a6c   Sam Ravnborg   kbuild: revert "s...
339
  ARCH		?= $(SUBARCH)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
340
341
  
  # Architecture as present in compile.h
6752ed90d   Thomas Gleixner   Kbuild: allow arc...
342
343
  UTS_MACHINE 	:= $(ARCH)
  SRCARCH 	:= $(ARCH)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
344

d746d647f   Sam Ravnborg   x86: do not use $...
345
346
347
348
349
350
351
  # Additional ARCH settings for x86
  ifeq ($(ARCH),i386)
          SRCARCH := x86
  endif
  ifeq ($(ARCH),x86_64)
          SRCARCH := x86
  endif
74b469f2e   Sam Ravnborg   x86: move i386 an...
352

5e5387900   Sam Ravnborg   sparc,sparc64: un...
353
  # Additional ARCH settings for sparc
e69f58c03   Namhyung Kim   kbuild: add ARCH=...
354
355
356
  ifeq ($(ARCH),sparc32)
         SRCARCH := sparc
  endif
a439fe51a   Sam Ravnborg   sparc, sparc64: u...
357
  ifeq ($(ARCH),sparc64)
5e5387900   Sam Ravnborg   sparc,sparc64: un...
358
         SRCARCH := sparc
a439fe51a   Sam Ravnborg   sparc, sparc64: u...
359
  endif
2fb9b1bd9   Sam Ravnborg   kbuild: prepare h...
360

3cc000b58   Paul Mundt   sh: Plug in suppo...
361
362
363
364
  # Additional ARCH settings for sh
  ifeq ($(ARCH),sh64)
         SRCARCH := sh
  endif
14cdd3c40   Roman Zippel   kconfig: KCONFIG_...
365
  KCONFIG_CONFIG	?= .config
41263fc67   Ben Gardiner   kbuild: fix inter...
366
  export KCONFIG_CONFIG
14cdd3c40   Roman Zippel   kconfig: KCONFIG_...
367

2a86f6612   Masahiro Yamada   kbuild: use KBUIL...
368
369
  # Default file for 'make defconfig'. This may be overridden by arch-Makefile.
  export KBUILD_DEFCONFIG := defconfig
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
370
  # SHELL used by kbuild
858805b33   Masahiro Yamada   kbuild: add $(BAS...
371
  CONFIG_SHELL := sh
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
372

6d79a7b42   Masahiro Yamada   kbuild: suppress ...
373
374
375
  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)
d7f14c66c   Uwe Kleine-König   kbuild: Enable La...
376

a0d1c951e   Masahiro Yamada   kbuild: support L...
377
378
379
380
381
382
383
  ifneq ($(LLVM),)
  HOSTCC	= clang
  HOSTCXX	= clang++
  else
  HOSTCC	= gcc
  HOSTCXX	= g++
  endif
7f3a59db2   Masahiro Yamada   kbuild: add infra...
384
385
386
387
388
389
  
  export KBUILD_USERCFLAGS := -Wall -Wmissing-prototypes -Wstrict-prototypes \
  			      -O2 -fomit-frame-pointer -std=gnu89
  export KBUILD_USERLDFLAGS :=
  
  KBUILD_HOSTCFLAGS   := $(KBUILD_USERCFLAGS) $(HOST_LFS_CFLAGS) $(HOSTCFLAGS)
735aab1e0   Masahiro Yamada   kbuild: add -Wall...
390
  KBUILD_HOSTCXXFLAGS := -Wall -O2 $(HOST_LFS_CFLAGS) $(HOSTCXXFLAGS)
f92d19e0e   Laura Abbott   kbuild: Use HOST*...
391
392
  KBUILD_HOSTLDFLAGS  := $(HOST_LFS_LDFLAGS) $(HOSTLDFLAGS)
  KBUILD_HOSTLDLIBS   := $(HOST_LFS_LIBS) $(HOSTLDLIBS)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
393

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
394
  # Make variables (CC, etc...)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
395
  CPP		= $(CC) -E
a0d1c951e   Masahiro Yamada   kbuild: support L...
396
397
398
399
400
401
402
403
  ifneq ($(LLVM),)
  CC		= clang
  LD		= ld.lld
  AR		= llvm-ar
  NM		= llvm-nm
  OBJCOPY		= llvm-objcopy
  OBJDUMP		= llvm-objdump
  READELF		= llvm-readelf
a0d1c951e   Masahiro Yamada   kbuild: support L...
404
405
406
407
  STRIP		= llvm-strip
  else
  CC		= $(CROSS_COMPILE)gcc
  LD		= $(CROSS_COMPILE)ld
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
408
409
  AR		= $(CROSS_COMPILE)ar
  NM		= $(CROSS_COMPILE)nm
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
410
411
  OBJCOPY		= $(CROSS_COMPILE)objcopy
  OBJDUMP		= $(CROSS_COMPILE)objdump
eefb8c124   Dmitry Golovin   x86/boot: kbuild:...
412
  READELF		= $(CROSS_COMPILE)readelf
a0d1c951e   Masahiro Yamada   kbuild: support L...
413
414
  STRIP		= $(CROSS_COMPILE)strip
  endif
e83b9f554   Andrii Nakryiko   kbuild: add abili...
415
  PAHOLE		= pahole
c9a0f3b85   Jiri Olsa   bpf: Resolve BTF ...
416
  RESOLVE_BTFIDS	= $(objtree)/tools/bpf/resolve_btfids/resolve_btfids
73a4f6dbe   Masahiro Yamada   kbuild: add LEX a...
417
418
  LEX		= flex
  YACC		= bison
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
419
  AWK		= awk
caa27b66b   Sam Ravnborg   kbuild: use INSTA...
420
  INSTALLKERNEL  := installkernel
3ca425885   Dominique Martinet   kbuild: don't har...
421
  DEPMOD		= depmod
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
422
  PERL		= perl
011bf1254   Masahiro Yamada   kbuild: allow to ...
423
  PYTHON		= python
e9781b52d   Masahiro Yamada   kbuild: add PYTHO...
424
  PYTHON3		= python3
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
425
  CHECK		= sparse
858805b33   Masahiro Yamada   kbuild: add $(BAS...
426
  BASH		= bash
e4a42c82e   Denis Efremov   kbuild: fix broke...
427
428
429
  KGZIP		= gzip
  KBZIP2		= bzip2
  KLZOP		= lzop
8dfb61dcb   Denis Efremov   kbuild: add varia...
430
431
432
  LZMA		= lzma
  LZ4		= lz4c
  XZ		= xz
48f7ddf78   Nick Terrell   init: Add support...
433
  ZSTD		= zstd
8dfb61dcb   Denis Efremov   kbuild: add varia...
434

80a7d1d99   Hannes Eder   kbuild: disable s...
435
  CHECKFLAGS     := -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ \
6c49f359c   Luc Van Oostenryck   kbuild: disable s...
436
  		  -Wbitwise -Wno-return-void -Wno-unknown-attribute $(CF)
0c22be071   Douglas Anderson   kbuild: Make NOST...
437
  NOSTDINC_FLAGS :=
6588169d5   Sam Ravnborg   kbuild: allow ass...
438
439
440
  CFLAGS_MODULE   =
  AFLAGS_MODULE   =
  LDFLAGS_MODULE  =
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
441
442
  CFLAGS_KERNEL	=
  AFLAGS_KERNEL	=
b36fad65d   Michal Marek   kbuild: Initializ...
443
  LDFLAGS_vmlinux =
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
444

abbf1590d   David Howells   UAPI: Partition t...
445
446
  # Use USERINCLUDE when you must reference the UAPI directories only.
  USERINCLUDE    := \
9d022c540   Masahiro Yamada   kbuild: replace $...
447
448
  		-I$(srctree)/arch/$(SRCARCH)/include/uapi \
  		-I$(objtree)/arch/$(SRCARCH)/include/generated/uapi \
abbf1590d   David Howells   UAPI: Partition t...
449
  		-I$(srctree)/include/uapi \
3308b2856   Arnd Bergmann   Kbuild: always pr...
450
  		-I$(objtree)/include/generated/uapi \
abbf1590d   David Howells   UAPI: Partition t...
451
                  -include $(srctree)/include/linux/kconfig.h
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
452
453
  # Use LINUXINCLUDE when you must reference the include/ directory.
  # Needed to be compatible with the O= option
abbf1590d   David Howells   UAPI: Partition t...
454
  LINUXINCLUDE    := \
9d022c540   Masahiro Yamada   kbuild: replace $...
455
456
  		-I$(srctree)/arch/$(SRCARCH)/include \
  		-I$(objtree)/arch/$(SRCARCH)/include/generated \
051f278e9   Masahiro Yamada   kbuild: replace K...
457
  		$(if $(building_out_of_srctree),-I$(srctree)/include) \
f8224f7f4   Masahiro Yamada   kbuild: remove du...
458
459
  		-I$(objtree)/include \
  		$(USERINCLUDE)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
460

42a92bccd   Masahiro Yamada   kbuild: add -fno-...
461
  KBUILD_AFLAGS   := -D__ASSEMBLY__ -fno-PIE
eeb5687a7   Masahiro Yamada   kbuild: add -Werr...
462
  KBUILD_CFLAGS   := -Wall -Wundef -Werror=strict-prototypes -Wno-trigraphs \
42a92bccd   Masahiro Yamada   kbuild: add -fno-...
463
  		   -fno-strict-aliasing -fno-common -fshort-wchar -fno-PIE \
b89f25ea7   Luc Van Oostenryck   kbuild: use -Werr...
464
  		   -Werror=implicit-function-declaration -Werror=implicit-int \
172aad81a   Olaf Hering   kbuild: enforce -...
465
  		   -Werror=return-type -Wno-format-security \
433dc2ebe   Masahiro Yamada   kbuild: do not ca...
466
467
  		   -std=gnu89
  KBUILD_CPPFLAGS := -D__KERNEL__
80c00ba94   Sam Ravnborg   kbuild: allow ass...
468
469
  KBUILD_AFLAGS_KERNEL :=
  KBUILD_CFLAGS_KERNEL :=
6588169d5   Sam Ravnborg   kbuild: allow ass...
470
471
  KBUILD_AFLAGS_MODULE  := -DMODULE
  KBUILD_CFLAGS_MODULE  := -DMODULE
10df06385   Masahiro Yamada   kbuild: rebuild m...
472
  KBUILD_LDFLAGS_MODULE :=
d503ac531   Masahiro Yamada   kbuild: rename LD...
473
  KBUILD_LDFLAGS :=
5241ab4cf   Masahiro Yamada   kbuild: initializ...
474
  CLANG_FLAGS :=
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
475

aa824e0c9   Masahiro Yamada   kbuild: remove AS...
476
  export ARCH SRCARCH CONFIG_SHELL BASH HOSTCC KBUILD_HOSTCFLAGS CROSS_COMPILE LD CC
d9b5665fb   Vasily Gorbik   kbuild: remove un...
477
  export CPP AR NM STRIP OBJCOPY OBJDUMP READELF PAHOLE RESOLVE_BTFIDS LEX YACC AWK INSTALLKERNEL
94f7345b7   Masahiro Yamada   kbuild: remove PY...
478
  export PERL PYTHON PYTHON3 CHECK CHECKFLAGS MAKE UTS_MACHINE HOSTCXX
48f7ddf78   Nick Terrell   init: Add support...
479
  export KGZIP KBZIP2 KLZOP LZMA LZ4 XZ ZSTD
7bac98707   Vasily Gorbik   kbuild: add OBJSI...
480
  export KBUILD_HOSTCXXFLAGS KBUILD_HOSTLDFLAGS KBUILD_HOSTLDLIBS LDFLAGS_MODULE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
481

d503ac531   Masahiro Yamada   kbuild: rename LD...
482
  export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINCLUDE OBJCOPYFLAGS KBUILD_LDFLAGS
0e410e158   Andrey Konovalov   kasan: don't emit...
483
  export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE
222d394d3   Sam Ravnborg   kbuild: enable 'm...
484
  export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE
6588169d5   Sam Ravnborg   kbuild: allow ass...
485
  export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_LDFLAGS_MODULE
80c00ba94   Sam Ravnborg   kbuild: allow ass...
486
  export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
487

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
488
  # Files to ignore in find ... statements
ae63b2d7b   Prarit Bhargava   scripts/tags.sh: ...
489
490
491
  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
450c6076a   Jesper Juhl   Makefile: improve...
492
493
  export RCS_TAR_IGNORE := --exclude SCCS --exclude BitKeeper --exclude .svn \
  			 --exclude CVS --exclude .pc --exclude .hg --exclude .git
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
494
495
496
  
  # ===========================================================================
  # Rules shared between *config targets and build targets
312a3d091   Cao jin   kbuild: trivial c...
497
  # Basic helpers built in scripts/basic/
4f1933620   Paul Smith   kbuild: change kb...
498
  PHONY += scripts_basic
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
499
500
  scripts_basic:
  	$(Q)$(MAKE) $(build)=scripts/basic
638adb056   Steven Rostedt   tracing: Only pri...
501
  	$(Q)rm -f .tmp_quiet_recordmcount
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
502

4f1933620   Paul Smith   kbuild: change kb...
503
  PHONY += outputmakefile
e8e83a236   Masahiro Yamada   kbuild: move the ...
504
  # Before starting out-of-tree build, make sure the source tree is clean.
fd5f0cd6b   Jan Beulich   kbuild: Do not ov...
505
506
507
  # outputmakefile generates a Makefile in the output directory, if using a
  # separate output directory. This allows convenient use of make in the
  # output directory.
3a51ff344   Vladimir Kondratiev   kbuild: gitignore...
508
509
  # At the same time when output Makefile generated, generate .gitignore to
  # ignore whole output directory
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
510
  outputmakefile:
051f278e9   Masahiro Yamada   kbuild: replace K...
511
  ifdef building_out_of_srctree
e8e83a236   Masahiro Yamada   kbuild: move the ...
512
513
514
515
516
517
518
519
520
  	$(Q)if [ -f $(srctree)/.config -o \
  		 -d $(srctree)/include/config -o \
  		 -d $(srctree)/arch/$(SRCARCH)/include/generated ]; then \
  		echo >&2 "***"; \
  		echo >&2 "*** The source tree is not clean, please run 'make$(if $(findstring command line, $(origin ARCH)), ARCH=$(ARCH)) mrproper'"; \
  		echo >&2 "*** in $(abs_srctree)";\
  		echo >&2 "***"; \
  		false; \
  	fi
929799973   Andi Kleen   kbuild: create th...
521
  	$(Q)ln -fsn $(srctree) source
4fd61277f   Masahiro Yamada   kbuild: do not pa...
522
  	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/mkmakefile $(srctree)
156e7cbb3   Masahiro Yamada   kbuild: do not ov...
523
524
  	$(Q)test -e .gitignore || \
  	{ echo "# this is build directory, ignore it"; echo "*"; } > .gitignore
fd5f0cd6b   Jan Beulich   kbuild: Do not ov...
525
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
526

995167420   Masahiro Yamada   kbuild: remove cc...
527
  ifneq ($(shell $(CC) --version 2>&1 | head -n 1 | grep clang),)
ae6b289a3   Chris Fries   kbuild: Set KBUIL...
528
  ifneq ($(CROSS_COMPILE),)
5241ab4cf   Masahiro Yamada   kbuild: initializ...
529
  CLANG_FLAGS	+= --target=$(notdir $(CROSS_COMPILE:%-=%))
ad15006cc   Nick Desaulniers   kbuild: clang: ch...
530
  GCC_TOOLCHAIN_DIR := $(dir $(shell which $(CROSS_COMPILE)elfedit))
ca9b31f6b   Fangrui Song   Makefile: Fix GCC...
531
  CLANG_FLAGS	+= --prefix=$(GCC_TOOLCHAIN_DIR)$(notdir $(CROSS_COMPILE))
ef8c4ed9d   Stefan Agner   kbuild: allow to ...
532
  GCC_TOOLCHAIN	:= $(realpath $(GCC_TOOLCHAIN_DIR)/..)
ae6b289a3   Chris Fries   kbuild: Set KBUIL...
533
534
  endif
  ifneq ($(GCC_TOOLCHAIN),)
238bcbc4e   Masahiro Yamada   kbuild: consolida...
535
  CLANG_FLAGS	+= --gcc-toolchain=$(GCC_TOOLCHAIN)
ae6b289a3   Chris Fries   kbuild: Set KBUIL...
536
  endif
7e20e47c7   Masahiro Yamada   kbuild: replace A...
537
  ifneq ($(LLVM_IAS),1)
238bcbc4e   Masahiro Yamada   kbuild: consolida...
538
  CLANG_FLAGS	+= -no-integrated-as
876a06008   Nathan Chancellor   kbuild: Add abili...
539
  endif
589834b3a   Nathan Chancellor   kbuild: Add -Werr...
540
  CLANG_FLAGS	+= -Werror=unknown-warning-option
238bcbc4e   Masahiro Yamada   kbuild: consolida...
541
542
  KBUILD_CFLAGS	+= $(CLANG_FLAGS)
  KBUILD_AFLAGS	+= $(CLANG_FLAGS)
3bd980509   Joel Stanley   Makefile: Export ...
543
  export CLANG_FLAGS
ae6b289a3   Chris Fries   kbuild: Set KBUIL...
544
  endif
315bab4e9   Masahiro Yamada   kbuild: fix endle...
545
546
547
548
  # The expansion should be delayed until arch/$(SRCARCH)/Makefile is included.
  # Some architectures define CROSS_COMPILE in arch/$(SRCARCH)/Makefile.
  # CC_VERSION_TEXT is referenced from Kconfig (so it needs export),
  # and from include/config/auto.conf.cmd to detect the compiler upgrade.
902a6898b   Masahiro Yamada   kbuild: terminate...
549
  CC_VERSION_TEXT = $(shell $(CC) --version 2>/dev/null | head -n 1)
315bab4e9   Masahiro Yamada   kbuild: fix endle...
550

2042b5486   Masahiro Yamada   kbuild: unset var...
551
  ifdef config-build
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
552
553
554
555
556
557
558
  # ===========================================================================
  # *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'
a436bb7b8   Masahiro Yamada   kbuild: use relat...
559
  include arch/$(SRCARCH)/Makefile
315bab4e9   Masahiro Yamada   kbuild: fix endle...
560
  export KBUILD_DEFCONFIG KBUILD_KCONFIG CC_VERSION_TEXT
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
561

36de077b2   Masahiro Yamada   kbuild: check cle...
562
  config: outputmakefile scripts_basic FORCE
31110ebbe   Sam Ravnborg   kbuild: fix make ...
563
  	$(Q)$(MAKE) $(build)=scripts/kconfig $@
36de077b2   Masahiro Yamada   kbuild: check cle...
564
  %config: outputmakefile scripts_basic FORCE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
565
  	$(Q)$(MAKE) $(build)=scripts/kconfig $@
2042b5486   Masahiro Yamada   kbuild: unset var...
566
  else #!config-build
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
567
568
569
  # ===========================================================================
  # Build targets only - this includes vmlinux, arch specific targets, clean
  # targets and others. In general all targets except *config targets.
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
570
  # If building an external module we do not care about the all: rule
121c2a137   Masahiro Yamada   kbuild: error out...
571
  # but instead __all depend on modules
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
572
573
  PHONY += all
  ifeq ($(KBUILD_EXTMOD),)
121c2a137   Masahiro Yamada   kbuild: error out...
574
  __all: all
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
575
  else
121c2a137   Masahiro Yamada   kbuild: error out...
576
  __all: modules
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
577
578
579
580
581
582
583
584
585
  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.
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
586
  ifeq ($(MAKECMDGOALS),modules)
4b50c8c4e   Masahiro Yamada   kbuild: force to ...
587
    KBUILD_BUILTIN :=
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
588
589
590
591
592
  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
6ad7cbc01   Nathan Huckleberry   Makefile: Add cla...
593
  ifneq ($(filter all modules nsdeps %compile_commands.json clang-%,$(MAKECMDGOALS)),)
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
594
595
596
597
598
599
600
601
    KBUILD_MODULES := 1
  endif
  
  ifeq ($(MAKECMDGOALS),)
    KBUILD_MODULES := 1
  endif
  
  export KBUILD_MODULES KBUILD_BUILTIN
2042b5486   Masahiro Yamada   kbuild: unset var...
602
  ifdef need-config
d93a18f27   Masahiro Yamada   kbuild: move samp...
603
604
  include include/config/auto.conf
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
605
  ifeq ($(KBUILD_EXTMOD),)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
606
  # Objects we will link into vmlinux / subdirs we need to visit
23febe375   Masahiro Yamada   kbuild: merge ini...
607
  core-y		:= init/ usr/
f96182e95   Masahiro Yamada   firmware_loader: ...
608
  drivers-y	:= drivers/ sound/
d93a18f27   Masahiro Yamada   kbuild: move samp...
609
  drivers-$(CONFIG_SAMPLES) += samples/
95fb6317b   Masahiro Yamada   kbuild: merge net...
610
  drivers-y	+= net/ virt/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
611
  libs-y		:= lib/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
612
  endif # KBUILD_EXTMOD
315bab4e9   Masahiro Yamada   kbuild: fix endle...
613
614
615
616
617
618
619
620
621
  # 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
  # Defaults to vmlinux, but the arch makefile usually adds further targets
  all: vmlinux
  
  CFLAGS_GCOV	:= -fprofile-arcs -ftest-coverage \
  	$(call cc-option,-fno-tree-loop-im) \
  	$(call cc-disable-warning,maybe-uninitialized,)
5aadfdeb8   Masahiro Yamada   kcov: test compil...
622
  export CFLAGS_GCOV
315bab4e9   Masahiro Yamada   kbuild: fix endle...
623

b1f4ff74f   Paulo Zanoni   tracing/Makefile:...
624
625
626
627
  # The arch Makefiles can override CC_FLAGS_FTRACE. We may also append it later.
  ifdef CONFIG_FUNCTION_TRACER
    CC_FLAGS_FTRACE := -pg
  endif
669e06b19   Masahiro Yamada   kbuild: move RETP...
628
629
630
631
632
633
634
635
  RETPOLINE_CFLAGS_GCC := -mindirect-branch=thunk-extern -mindirect-branch-register
  RETPOLINE_VDSO_CFLAGS_GCC := -mindirect-branch=thunk-inline -mindirect-branch-register
  RETPOLINE_CFLAGS_CLANG := -mretpoline-external-thunk
  RETPOLINE_VDSO_CFLAGS_CLANG := -mretpoline
  RETPOLINE_CFLAGS := $(call cc-option,$(RETPOLINE_CFLAGS_GCC),$(call cc-option,$(RETPOLINE_CFLAGS_CLANG)))
  RETPOLINE_VDSO_CFLAGS := $(call cc-option,$(RETPOLINE_VDSO_CFLAGS_GCC),$(call cc-option,$(RETPOLINE_VDSO_CFLAGS_CLANG)))
  export RETPOLINE_CFLAGS
  export RETPOLINE_VDSO_CFLAGS
315bab4e9   Masahiro Yamada   kbuild: fix endle...
636
  include arch/$(SRCARCH)/Makefile
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
637

2042b5486   Masahiro Yamada   kbuild: unset var...
638
639
  ifdef need-config
  ifdef may-sync-config
315bab4e9   Masahiro Yamada   kbuild: fix endle...
640
641
642
  # Read in dependencies to all Kconfig* files, make sure to run syncconfig if
  # changes are detected. This should be included after arch/$(SRCARCH)/Makefile
  # because some architectures define CROSS_COMPILE there.
d2f8ae0e4   Masahiro Yamada   kbuild: turn auto...
643
  include include/config/auto.conf.cmd
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
644

058507195   Masahiro Yamada   kbuild: move ".co...
645
646
647
648
649
650
651
652
  $(KCONFIG_CONFIG):
  	@echo >&2 '***'
  	@echo >&2 '*** Configuration file "$@" not found!'
  	@echo >&2 '***'
  	@echo >&2 '*** Please run some configurator (e.g. "make oldconfig" or'
  	@echo >&2 '*** "make menuconfig" or "make xconfig").'
  	@echo >&2 '***'
  	@/bin/false
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
653

61277981d   Ulf Magnusson   Makefile: Fix lyi...
654
655
656
  # The actual configuration files used during the build are stored in
  # include/generated/ and include/config/. Update them if .config is newer than
  # include/config/auto.conf (which mirrors .config).
9390dff66   Masahiro Yamada   kbuild: invoke sy...
657
658
659
  #
  # This exploits the 'multi-target pattern rule' trick.
  # The syncconfig should be executed only once to make all the targets.
f463c3510   Masahiro Yamada   kbuild: add comme...
660
  # (Note: use the grouped target '&:' when we bump to GNU Make 4.3)
23cd88c91   Masahiro Yamada   kbuild: hide comm...
661
662
  quiet_cmd_syncconfig = SYNC    $@
        cmd_syncconfig = $(MAKE) -f $(srctree)/Makefile syncconfig
3044dd052   Masahiro Yamada   kbuild: invoke sy...
663
  %/config/auto.conf %/config/auto.conf.cmd %/generated/autoconf.h: $(KCONFIG_CONFIG)
23cd88c91   Masahiro Yamada   kbuild: hide comm...
664
  	+$(call cmd,syncconfig)
2042b5486   Masahiro Yamada   kbuild: unset var...
665
  else # !may-sync-config
d79424137   Masahiro Yamada   kbuild: do not up...
666
667
668
  # External modules and some install targets need include/generated/autoconf.h
  # and include/config/auto.conf but do not care if they are up-to-date.
  # Use auto.conf to trigger the test
9ee4e3365   Sam Ravnborg   kbuild: external ...
669
670
671
  PHONY += include/config/auto.conf
  
  include/config/auto.conf:
264a26838   Sam Ravnborg   kbuild: move auto...
672
  	$(Q)test -e include/generated/autoconf.h -a -e $@ || (		\
5369f5502   Michal Marek   kbuild: Print err...
673
674
675
676
677
  	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 ;							\
9ee4e3365   Sam Ravnborg   kbuild: external ...
678
  	/bin/false)
d79424137   Masahiro Yamada   kbuild: do not up...
679
  endif # may-sync-config
2042b5486   Masahiro Yamada   kbuild: unset var...
680
  endif # need-config
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
681

a1c48bb16   Geert Uytterhoeven   Makefile: Fix unr...
682
  KBUILD_CFLAGS	+= $(call cc-option,-fno-delete-null-pointer-checks,)
ef6000b4c   Linus Torvalds   Disable the __bui...
683
  KBUILD_CFLAGS	+= $(call cc-disable-warning,frame-address,)
bd664f6b3   Linus Torvalds   disable new gcc-7...
684
685
  KBUILD_CFLAGS	+= $(call cc-disable-warning, format-truncation)
  KBUILD_CFLAGS	+= $(call cc-disable-warning, format-overflow)
6f303d605   Linus Torvalds   gcc-9: silence 'a...
686
  KBUILD_CFLAGS	+= $(call cc-disable-warning, address-of-packed-member)
a1c48bb16   Geert Uytterhoeven   Makefile: Fix unr...
687

15f5db60a   Masahiro Yamada   kbuild,arc: add C...
688
689
690
691
692
693
  ifdef CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE
  KBUILD_CFLAGS += -O2
  else ifdef CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE_O3
  KBUILD_CFLAGS += -O3
  else ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
  KBUILD_CFLAGS += -Os
815eb71e7   Arnd Bergmann   Kbuild: disable '...
694
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
695

69102311a   Jiri Kosina   ./Makefile: tell ...
696
697
  # Tell gcc to never replace conditional load with a non-conditional one
  KBUILD_CFLAGS	+= $(call cc-option,--param=allow-store-data-races=0)
b1112139a   Sergei Trofimovich   Makefile: disallo...
698
  KBUILD_CFLAGS	+= $(call cc-option,-fno-allow-store-data-races)
69102311a   Jiri Kosina   ./Makefile: tell ...
699

1873e870f   Andi Kleen   debug: Add CONFIG...
700
701
702
703
704
705
706
707
708
  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
08f67461c   Mike Frysinger   kbuild: fix detec...
709
  ifneq ($(CONFIG_FRAME_WARN),0)
a83e4ca26   Masahiro Yamada   kbuild: remove cc...
710
  KBUILD_CFLAGS += -Wframe-larger-than=$(CONFIG_FRAME_WARN)
35bb5b1e0   Andi Kleen   Add option to ena...
711
  endif
893ab0043   Masahiro Yamada   kbuild: remove cc...
712
  stackp-flags-y                                    := -fno-stack-protector
050e9baa9   Linus Torvalds   Kbuild: rename CC...
713
714
  stackp-flags-$(CONFIG_STACKPROTECTOR)             := -fstack-protector
  stackp-flags-$(CONFIG_STACKPROTECTOR_STRONG)      := -fstack-protector-strong
2a61f4747   Masahiro Yamada   stack-protector: ...
715
716
  
  KBUILD_CFLAGS += $(stackp-flags-y)
e06b8b98d   Sam Ravnborg   kbuild: allow -fs...
717

076f421da   Masahiro Yamada   kbuild: replace c...
718
  ifdef CONFIG_CC_IS_CLANG
a14943043   Masahiro Yamada   kbuild: add all C...
719
720
721
  KBUILD_CPPFLAGS += -Qunused-arguments
  KBUILD_CFLAGS += -Wno-format-invalid-specifier
  KBUILD_CFLAGS += -Wno-gnu
cfe17c9bb   Masahiro Yamada   kbuild: move cc-o...
722
723
724
  # 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
a14943043   Masahiro Yamada   kbuild: add all C...
725
  KBUILD_CFLAGS += -mno-global-merge
cfe17c9bb   Masahiro Yamada   kbuild: move cc-o...
726
727
728
729
  else
  
  # These warnings generated too much noise in a regular build.
  # Use make W=1 to enable them (see scripts/Makefile.extrawarn)
9df3e7a7d   Masahiro Yamada   kbuild: add -Wno-...
730
  KBUILD_CFLAGS += -Wno-unused-but-set-variable
e2079e93f   Nathan Chancellor   kbuild: Do not en...
731
732
733
734
735
  
  # Warn about unmarked fall-throughs in switch statement.
  # Disabled for clang while comment to attribute conversion happens and
  # https://github.com/ClangBuiltLinux/linux/issues/636 is discussed.
  KBUILD_CFLAGS += $(call cc-option,-Wimplicit-fallthrough,)
cfe17c9bb   Masahiro Yamada   kbuild: move cc-o...
736
  endif
0a5f41767   Sodagudi Prasad   kbuild: clang: di...
737
  KBUILD_CFLAGS += $(call cc-disable-warning, unused-const-variable)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
738
  ifdef CONFIG_FRAME_POINTER
a0f97e06a   Sam Ravnborg   kbuild: enable 'm...
739
  KBUILD_CFLAGS	+= -fno-omit-frame-pointer -fno-optimize-sibling-calls
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
740
  else
7e9501fde   Rabin Vincent   ARM: 6312/1: ftra...
741
742
743
744
745
746
  # 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
a0f97e06a   Sam Ravnborg   kbuild: enable 'm...
747
  KBUILD_CFLAGS	+= -fomit-frame-pointer
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
748
  endif
7e9501fde   Rabin Vincent   ARM: 6312/1: ftra...
749
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
750

f0fe00d49   glider@google.com   security: allow u...
751
752
  # Initialize all stack variables with a 0xAA pattern.
  ifdef CONFIG_INIT_STACK_ALL_PATTERN
709a972ef   Kees Cook   security: Impleme...
753
754
  KBUILD_CFLAGS	+= -ftrivial-auto-var-init=pattern
  endif
f0fe00d49   glider@google.com   security: allow u...
755
756
757
758
759
760
761
762
  # Initialize all stack variables with a zero value.
  ifdef CONFIG_INIT_STACK_ALL_ZERO
  # Future support for zero initialization is still being debated, see
  # https://bugs.llvm.org/show_bug.cgi?id=45497. These flags are subject to being
  # renamed or dropped.
  KBUILD_CFLAGS	+= -ftrivial-auto-var-init=zero
  KBUILD_CFLAGS	+= -enable-trivial-auto-var-init-zero-knowing-it-will-be-removed-from-clang
  endif
121c5d08d   Mark Wielaard   kbuild: Only add ...
763
764
765
766
767
  # Workaround for GCC versions < 5.0
  # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61801
  ifdef CONFIG_CC_IS_GCC
  DEBUG_CFLAGS	:= $(call cc-ifversion, -lt, 0500, $(call cc-option, -fno-var-tracking-assignments))
  endif
2062afb4f   Linus Torvalds   Fix gcc-4.9.0 mis...
768

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
769
  ifdef CONFIG_DEBUG_INFO
695afd3d7   Sedat Dilek   kbuild: Simplify ...
770

866ced950   Andi Kleen   kbuild: Support s...
771
  ifdef CONFIG_DEBUG_INFO_SPLIT
9d9374440   Masahiro Yamada   kbuild: move -gsp...
772
  DEBUG_CFLAGS	+= -gsplit-dwarf
866ced950   Andi Kleen   kbuild: Support s...
773
  else
1e88e415e   Masahiro Yamada   kbuild: Disable e...
774
  DEBUG_CFLAGS	+= -g
866ced950   Andi Kleen   kbuild: Support s...
775
  endif
695afd3d7   Sedat Dilek   kbuild: Simplify ...
776

b8a909233   Nick Desaulniers   Kbuild: do not em...
777
  ifneq ($(LLVM_IAS),1)
2288328ce   Behan Webster   all: LLVMLinux: C...
778
  KBUILD_AFLAGS	+= -Wa,-gdwarf-2
b8a909233   Nick Desaulniers   Kbuild: do not em...
779
  endif
695afd3d7   Sedat Dilek   kbuild: Simplify ...
780

bfaf2dd35   Andi Kleen   Kbuild: Add a opt...
781
  ifdef CONFIG_DEBUG_INFO_DWARF4
9d9374440   Masahiro Yamada   kbuild: move -gsp...
782
  DEBUG_CFLAGS	+= -gdwarf-4
bfaf2dd35   Andi Kleen   Kbuild: Add a opt...
783
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
784

d6f4ceb79   Andi Kleen   Kbuild: Add optio...
785
  ifdef CONFIG_DEBUG_INFO_REDUCED
1e88e415e   Masahiro Yamada   kbuild: Disable e...
786
  DEBUG_CFLAGS	+= $(call cc-option, -femit-struct-debug-baseonly) \
e82c4bb8b   Andi Kleen   Kbuild: Disable v...
787
  		   $(call cc-option,-fno-var-tracking)
d6f4ceb79   Andi Kleen   Kbuild: Add optio...
788
  endif
10e68b02c   Nick Desaulniers   Makefile: support...
789
790
  ifdef CONFIG_DEBUG_INFO_COMPRESSED
  DEBUG_CFLAGS	+= -gz=zlib
7b1699443   Arvind Sankar   Makefile: Improve...
791
  KBUILD_AFLAGS	+= -gz=zlib
10e68b02c   Nick Desaulniers   Makefile: support...
792
793
  KBUILD_LDFLAGS	+= --compress-debug-sections=zlib
  endif
695afd3d7   Sedat Dilek   kbuild: Simplify ...
794
  endif # CONFIG_DEBUG_INFO
1e88e415e   Masahiro Yamada   kbuild: Disable e...
795
796
  KBUILD_CFLAGS += $(DEBUG_CFLAGS)
  export DEBUG_CFLAGS
606576ce8   Steven Rostedt   ftrace: rename FT...
797
  ifdef CONFIG_FUNCTION_TRACER
07d040812   Vasily Gorbik   tracing: Avoid ca...
798
799
800
801
802
803
  ifdef CONFIG_FTRACE_MCOUNT_RECORD
    # gcc 5 supports generating the mcount tables directly
    ifeq ($(call cc-option-yn,-mrecord-mcount),y)
      CC_FLAGS_FTRACE	+= -mrecord-mcount
      export CC_USING_RECORD_MCOUNT := 1
    endif
2f4df0017   Vasily Gorbik   tracing: Add -mco...
804
805
806
807
808
809
    ifdef CONFIG_HAVE_NOP_MCOUNT
      ifeq ($(call cc-option-yn, -mnop-mcount),y)
        CC_FLAGS_FTRACE	+= -mnop-mcount
        CC_FLAGS_USING	+= -DCC_USING_NOP_MCOUNT
      endif
    endif
07d040812   Vasily Gorbik   tracing: Avoid ca...
810
  endif
a2546fae0   Steven Rostedt   ftrace: Add -mfen...
811
  ifdef CONFIG_HAVE_FENTRY
f28bc3c32   Vasily Gorbik   tracing: Handle C...
812
813
814
815
    ifeq ($(call cc-option-yn, -mfentry),y)
      CC_FLAGS_FTRACE	+= -mfentry
      CC_FLAGS_USING	+= -DCC_USING_FENTRY
    endif
a2546fae0   Steven Rostedt   ftrace: Add -mfen...
816
  endif
f28bc3c32   Vasily Gorbik   tracing: Handle C...
817
818
819
  export CC_FLAGS_FTRACE
  KBUILD_CFLAGS	+= $(CC_FLAGS_FTRACE) $(CC_FLAGS_USING)
  KBUILD_AFLAGS	+= $(CC_FLAGS_USING)
72441cb1f   Steven Rostedt   ftrace/x86: Add s...
820
  ifdef CONFIG_DYNAMIC_FTRACE
cf4db2597   Steven Rostedt   ftrace: Rename co...
821
  	ifdef CONFIG_HAVE_C_RECORDMCOUNT
72441cb1f   Steven Rostedt   ftrace/x86: Add s...
822
823
824
825
  		BUILD_C_RECORDMCOUNT := y
  		export BUILD_C_RECORDMCOUNT
  	endif
  endif
16444a8a4   Arnaldo Carvalho de Melo   ftrace: add basic...
826
  endif
91341d4b2   Sam Ravnborg   kbuild: introduce...
827
828
829
830
  # We trigger additional mismatches with less inlining
  ifdef CONFIG_DEBUG_SECTION_MISMATCH
  KBUILD_CFLAGS += $(call cc-option, -fno-inline-functions-called-once)
  endif
90ad4052e   Masahiro Yamada   kbuild: avoid con...
831
  ifdef CONFIG_LD_DEAD_CODE_DATA_ELIMINATION
e85d1d65c   Masahiro Yamada   kbuild: test dead...
832
833
  KBUILD_CFLAGS_KERNEL += -ffunction-sections -fdata-sections
  LDFLAGS_vmlinux += --gc-sections
90ad4052e   Masahiro Yamada   kbuild: avoid con...
834
  endif
d08b9f0ca   Sami Tolvanen   scs: Add support ...
835
836
837
838
839
  ifdef CONFIG_SHADOW_CALL_STACK
  CC_FLAGS_SCS	:= -fsanitize=shadow-call-stack
  KBUILD_CFLAGS	+= $(CC_FLAGS_SCS)
  export CC_FLAGS_SCS
  endif
09c60546f   Feng Tang   ./Makefile: add d...
840
841
842
  ifdef CONFIG_DEBUG_FORCE_FUNCTION_ALIGN_32B
  KBUILD_CFLAGS += -falign-functions=32
  endif
e8e699317   Sam Ravnborg   [PATCH] kbuild: S...
843
  # arch Makefile may override CC so keep this after arch Makefile is included
e08d6de4e   Masahiro Yamada   kbuild: remove kb...
844
  NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
e8e699317   Sam Ravnborg   [PATCH] kbuild: S...
845

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
846
  # warn about C99 declaration after statement
a33e7ae29   Masahiro Yamada   kbuild: add -Wdec...
847
  KBUILD_CFLAGS += -Wdeclaration-after-statement
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
848

0bb95f80a   Kees Cook   Makefile: Globall...
849
  # Variable Length Arrays (VLAs) should not be used anywhere in the kernel
8289f913f   Masahiro Yamada   kbuild: add -Wvla...
850
  KBUILD_CFLAGS += -Wvla
0bb95f80a   Kees Cook   Makefile: Globall...
851

070b98bfd   Sam Ravnborg   kbuild: trivial f...
852
  # disable pointer signed / unsigned warnings in gcc 4.0
fb073a4b4   Masahiro Yamada   kbuild: add -Wno-...
853
  KBUILD_CFLAGS += -Wno-pointer-sign
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
854

217c3e019   Stephen Rothwell   disable stringop ...
855
856
  # disable stringop warnings in gcc 8+
  KBUILD_CFLAGS += $(call cc-disable-warning, stringop-truncation)
5c45de21a   Linus Torvalds   gcc-10: disable '...
857
858
  # We'll want to enable this eventually, but it's not going away for 5.7 at least
  KBUILD_CFLAGS += $(call cc-disable-warning, zero-length-bounds)
44720996e   Linus Torvalds   gcc-10: disable '...
859
  KBUILD_CFLAGS += $(call cc-disable-warning, array-bounds)
5a76021c2   Linus Torvalds   gcc-10: disable '...
860
  KBUILD_CFLAGS += $(call cc-disable-warning, stringop-overflow)
5c45de21a   Linus Torvalds   gcc-10: disable '...
861

adc719209   Linus Torvalds   gcc-10: disable '...
862
863
  # Another good warning that we'll want to enable eventually
  KBUILD_CFLAGS += $(call cc-disable-warning, restrict)
78a5255ff   Linus Torvalds   Stop the ad-hoc g...
864
865
  # Enabled with W=2, disabled by default as noisy
  KBUILD_CFLAGS += $(call cc-disable-warning, maybe-uninitialized)
fe8d0a410   Kirill Smelkov   kbuild: fix a few...
866
  # disable invalid "can't wrap" optimizations for signed / pointers
8b42cf2fd   Masahiro Yamada   kbuild: remove cc...
867
  KBUILD_CFLAGS	+= -fno-strict-overflow
d0115552c   Linus Torvalds   Move cc-option to...
868

3ce120b16   Linus Torvalds   kbuild: add '-fno...
869
  # Make sure -fstack-check isn't enabled (like gentoo apparently did)
7d4eb0d8e   Masahiro Yamada   kbuild: remove cc...
870
  KBUILD_CFLAGS  += -fno-stack-check
3ce120b16   Linus Torvalds   kbuild: add '-fno...
871

8f7f5c9fc   Andi Kleen   kbuild: set -fcon...
872
873
  # conserve stack if available
  KBUILD_CFLAGS   += $(call cc-option,-fconserve-stack)
fe7c36c7b   Josh Triplett   Makefile: Build w...
874
  # Prohibit date/time macros, which would make the build non-deterministic
87de84c91   Masahiro Yamada   kbuild: remove cc...
875
  KBUILD_CFLAGS   += -Werror=date-time
fe7c36c7b   Josh Triplett   Makefile: Build w...
876

ea8daa7b9   Daniel Wagner   kbuild: Add optio...
877
878
  # enforce correct pointer usage
  KBUILD_CFLAGS   += $(call cc-option,-Werror=incompatible-pointer-types)
c834f0e8a   Kees Cook   Kbuild: make desi...
879
880
  # Require designated initializers for all marked structures
  KBUILD_CFLAGS   += $(call cc-option,-Werror=designated-init)
a73619a84   Masahiro Yamada   kbuild: use -fmac...
881
  # change __FILE__ to the relative path from the srctree
a716bd743   Denys Zagorui   kbuild: use -fmac...
882
  KBUILD_CPPFLAGS += $(call cc-option,-fmacro-prefix-map=$(srctree)/=)
a73619a84   Masahiro Yamada   kbuild: use -fmac...
883

29be86d7f   Seth Forshee   kbuild: add -fcf-...
884
885
886
887
888
  # 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
e0fe0bbe5   Masahiro Yamada   kbuild: include s...
889
890
891
892
893
894
895
896
897
  # include additional Makefiles when needed
  include-y			:= scripts/Makefile.extrawarn
  include-$(CONFIG_KASAN)		+= scripts/Makefile.kasan
  include-$(CONFIG_KCSAN)		+= scripts/Makefile.kcsan
  include-$(CONFIG_UBSAN)		+= scripts/Makefile.ubsan
  include-$(CONFIG_KCOV)		+= scripts/Makefile.kcov
  include-$(CONFIG_GCC_PLUGINS)	+= scripts/Makefile.gcc-plugins
  
  include $(addprefix $(srctree)/, $(include-y))
a86fe3537   Masahiro Yamada   kbuild: move extr...
898

132305b3b   Masahiro Yamada   kbuild: stop filt...
899
900
901
  # scripts/Makefile.gcc-plugins is intentionally included last.
  # Do not add $(call cc-option,...) below this line. When you build the kernel
  # from the clean source tree, the GCC plugins do not exist at this point.
a86fe3537   Masahiro Yamada   kbuild: move extr...
902

8cc7af751   Masahiro Yamada   kbuild: remove AR...
903
904
905
906
  # Add user supplied CPPFLAGS, AFLAGS and CFLAGS as the last assignments
  KBUILD_CPPFLAGS += $(KCPPFLAGS)
  KBUILD_AFLAGS   += $(KAFLAGS)
  KBUILD_CFLAGS   += $(KCFLAGS)
52bcc3308   Sam Ravnborg   kbuild: enable us...
907

a96843372   Bill Wendling   kbuild: explicitl...
908
909
  KBUILD_LDFLAGS_MODULE += --build-id=sha1
  LDFLAGS_vmlinux += --build-id=sha1
18991197b   Roland McGrath   Use --build-id ld...
910

5d7d18f5b   David Howells   kbuild: make it p...
911
  ifeq ($(CONFIG_STRIP_ASM_SYMS),y)
d79a27195   Andi Kleen   kbuild: Check if ...
912
  LDFLAGS_vmlinux	+= $(call ld-option, -X,)
5d7d18f5b   David Howells   kbuild: make it p...
913
  endif
5cf896fb6   Peter Collingbourne   arm64: Add suppor...
914
915
916
  ifeq ($(CONFIG_RELR),y)
  LDFLAGS_vmlinux	+= --pack-dyn-relocs=relr
  endif
59612b24f   Nathan Chancellor   kbuild: Hoist '--...
917
918
919
920
921
  # We never want expected sections to be placed heuristically by the
  # linker. All sections should be explicitly named in the linker script.
  ifdef CONFIG_LD_ORPHAN_WARN
  LDFLAGS_vmlinux += --orphan-handling=warn
  endif
7f3a59db2   Masahiro Yamada   kbuild: add infra...
922
  # Align the bit size of userspace programs with the kernel
7f58b487e   Masahiro Yamada   kbuild: make Clan...
923
924
  KBUILD_USERCFLAGS  += $(filter -m32 -m64 --target=%, $(KBUILD_CFLAGS))
  KBUILD_USERLDFLAGS += $(filter -m32 -m64 --target=%, $(KBUILD_CFLAGS))
7f3a59db2   Masahiro Yamada   kbuild: add infra...
925

80591e61a   Luc Van Oostenryck   kbuild: tell spar...
926
927
  # make the checker run with the right architecture
  CHECKFLAGS += --arch=$(ARCH)
145167650   Luc Van Oostenryck   kbuild: add endia...
928
929
  # insure the checker run with the right endianness
  CHECKFLAGS += $(if $(CONFIG_CPU_BIG_ENDIAN),-mbig-endian,-mlittle-endian)
1f2f01b12   Luc Van Oostenryck   kbuild: add machi...
930
931
  # the checker needs the correct machine size
  CHECKFLAGS += $(if $(CONFIG_64BIT),-m64,-m32)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
932
  # Default kernel image to build when no specific target is given.
070b98bfd   Sam Ravnborg   kbuild: trivial f...
933
  # KBUILD_IMAGE may be overruled on the command line or
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
934
935
936
937
938
939
940
941
942
943
944
  # 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
  
  #
f4d4ffc03   Jason Cooper   kbuild: dtbs_inst...
945
946
947
948
949
950
951
  # 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)
  
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
952
953
  # INSTALL_MOD_PATH specifies a prefix to MODLIB for module directory
  # relocations required by build roots.  This is not defined in the
070b98bfd   Sam Ravnborg   kbuild: trivial f...
954
  # makefile but the argument can be passed to make if needed.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
955
  #
df9df036d   Sam Ravnborg   kbuild: fix 'make...
956
  MODLIB	= $(INSTALL_MOD_PATH)/lib/modules/$(KERNELRELEASE)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
957
  export MODLIB
ac031f26e   Theodore Ts'o   kbuild: add optio...
958
  #
3fbb43df9   Masahiro Yamada   kbuild: trivial -...
959
960
961
962
  # 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.
2ea038917   Sam Ravnborg   Revert "kbuild: s...
963

ac031f26e   Theodore Ts'o   kbuild: add optio...
964
965
  ifdef INSTALL_MOD_STRIP
  ifeq ($(INSTALL_MOD_STRIP),1)
2ea038917   Sam Ravnborg   Revert "kbuild: s...
966
  mod_strip_cmd = $(STRIP) --strip-debug
ac031f26e   Theodore Ts'o   kbuild: add optio...
967
  else
2ea038917   Sam Ravnborg   Revert "kbuild: s...
968
  mod_strip_cmd = $(STRIP) $(INSTALL_MOD_STRIP)
ac031f26e   Theodore Ts'o   kbuild: add optio...
969
970
  endif # INSTALL_MOD_STRIP=1
  else
2ea038917   Sam Ravnborg   Revert "kbuild: s...
971
  mod_strip_cmd = true
ac031f26e   Theodore Ts'o   kbuild: add optio...
972
973
  endif # INSTALL_MOD_STRIP
  export mod_strip_cmd
beb50df39   Bertrand Jacquin   kbuild: handle mo...
974
975
976
977
978
979
980
  # 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
e4a42c82e   Denis Efremov   kbuild: fix broke...
981
      mod_compress_cmd = $(KGZIP) -n -f
beb50df39   Bertrand Jacquin   kbuild: handle mo...
982
983
    endif # CONFIG_MODULE_COMPRESS_GZIP
    ifdef CONFIG_MODULE_COMPRESS_XZ
8dfb61dcb   Denis Efremov   kbuild: add varia...
984
      mod_compress_cmd = $(XZ) -f
beb50df39   Bertrand Jacquin   kbuild: handle mo...
985
986
987
    endif # CONFIG_MODULE_COMPRESS_XZ
  endif # CONFIG_MODULE_COMPRESS
  export mod_compress_cmd
d9d8d7ed4   Michal Marek   MODSIGN: Add opti...
988
  ifdef CONFIG_MODULE_SIG_ALL
3ee550f12   David Woodhouse   modsign: Handle s...
989
990
991
  $(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
e2a666d52   Rusty Russell   kbuild: sign the ...
992
993
994
995
  else
  mod_sign_cmd = true
  endif
  export mod_sign_cmd
056d28d13   Rolf Eike Beer   objtool: Query pk...
996
  HOST_LIBELF_LIBS = $(shell pkg-config libelf --libs 2>/dev/null || echo -lelf)
33a57ce0a   Jiri Olsa   bpf: Compile reso...
997
998
  has_libelf = $(call try-run,\
                 echo "int main() {}" | $(HOSTCC) -xc -o /dev/null $(HOST_LIBELF_LIBS) -,1,0)
9f0c18aec   Josh Poimboeuf   objtool: Fix CONF...
999
  ifdef CONFIG_STACK_VALIDATION
9f0c18aec   Josh Poimboeuf   objtool: Fix CONF...
1000
1001
1002
    ifeq ($(has_libelf),1)
      objtool_target := tools/objtool FORCE
    else
9f0c18aec   Josh Poimboeuf   objtool: Fix CONF...
1003
1004
1005
1006
      SKIP_STACK_VALIDATION := 1
      export SKIP_STACK_VALIDATION
    endif
  endif
017dab341   Jiri Olsa   bpf: Check CONFIG...
1007
  ifdef CONFIG_BPF
33a57ce0a   Jiri Olsa   bpf: Compile reso...
1008
1009
1010
1011
1012
1013
  ifdef CONFIG_DEBUG_INFO_BTF
    ifeq ($(has_libelf),1)
      resolve_btfids_target := tools/bpf/resolve_btfids FORCE
    else
      ERROR_RESOLVE_BTFIDS := 1
    endif
017dab341   Jiri Olsa   bpf: Check CONFIG...
1014
1015
  endif # CONFIG_DEBUG_INFO_BTF
  endif # CONFIG_BPF
33a57ce0a   Jiri Olsa   bpf: Compile reso...
1016

e00d88804   Masahiro Yamada   kbuild: mark prep...
1017
  PHONY += prepare0
e2a666d52   Rusty Russell   kbuild: sign the ...
1018

394053f4a   Masahiro Yamada   kbuild: make sing...
1019
  export MODORDER := $(extmod-prefix)modules.order
bc35d4bda   Masahiro Yamada   scripts/nsdeps: s...
1020
  export MODULES_NSDEPS := $(extmod-prefix)modules.nsdeps
47801c97d   Masahiro Yamada   kbuild: revive si...
1021

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1022
  ifeq ($(KBUILD_EXTMOD),)
cfc411e7f   David Howells   Move certificate ...
1023
  core-y		+= kernel/ certs/ mm/ fs/ ipc/ security/ crypto/ block/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1024

23febe375   Masahiro Yamada   kbuild: merge ini...
1025
  vmlinux-dirs	:= $(patsubst %/,%,$(filter %/, \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1026
  		     $(core-y) $(core-m) $(drivers-y) $(drivers-m) \
95fb6317b   Masahiro Yamada   kbuild: merge net...
1027
  		     $(libs-y) $(libs-m)))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1028

1eaca4b98   Masahiro Yamada   kbuild: move Docu...
1029
  vmlinux-alldirs	:= $(sort $(vmlinux-dirs) Documentation \
23febe375   Masahiro Yamada   kbuild: merge ini...
1030
  		     $(patsubst %/,%,$(filter %/, $(core-) \
95fb6317b   Masahiro Yamada   kbuild: merge net...
1031
  			$(drivers-) $(libs-))))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1032

b2c885549   Masahiro Yamada   kbuild: update mo...
1033
1034
1035
  subdir-modorder := $(addsuffix modules.order,$(filter %/, \
  			$(core-y) $(core-m) $(libs-y) $(libs-m) \
  			$(drivers-y) $(drivers-m)))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1036

c99f3918c   Masahiro Yamada   kbuild: unify vml...
1037
  build-dirs	:= $(vmlinux-dirs)
76cd306d7   Masahiro Yamada   kbuild: unify cle...
1038
  clean-dirs	:= $(vmlinux-alldirs)
c99f3918c   Masahiro Yamada   kbuild: unify vml...
1039

f0d50ca04   Masahiro Yamada   kbuild: refactor ...
1040
1041
1042
  # Externally visible symbols (used by link-vmlinux.sh)
  KBUILD_VMLINUX_OBJS := $(head-y) $(patsubst %/,%/built-in.a, $(core-y))
  KBUILD_VMLINUX_OBJS += $(addsuffix built-in.a, $(filter %/, $(libs-y)))
7273ad2b0   Masahiro Yamada   kbuild: link lib-...
1043
  ifdef CONFIG_MODULES
f0d50ca04   Masahiro Yamada   kbuild: refactor ...
1044
1045
  KBUILD_VMLINUX_OBJS += $(patsubst %/, %/lib.a, $(filter %/, $(libs-y)))
  KBUILD_VMLINUX_LIBS := $(filter-out %/, $(libs-y))
7273ad2b0   Masahiro Yamada   kbuild: link lib-...
1046
  else
f0d50ca04   Masahiro Yamada   kbuild: refactor ...
1047
  KBUILD_VMLINUX_LIBS := $(patsubst %/,%/lib.a, $(libs-y))
7273ad2b0   Masahiro Yamada   kbuild: link lib-...
1048
  endif
f0d50ca04   Masahiro Yamada   kbuild: refactor ...
1049
  KBUILD_VMLINUX_OBJS += $(patsubst %/,%/built-in.a, $(drivers-y))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1050

f0d50ca04   Masahiro Yamada   kbuild: refactor ...
1051
  export KBUILD_VMLINUX_OBJS KBUILD_VMLINUX_LIBS
956985705   Sam Ravnborg   kbuild: refactor ...
1052
  export KBUILD_LDS          := arch/$(SRCARCH)/kernel/vmlinux.lds
85f0ae7e4   Masahiro Yamada   kbuild: update co...
1053
  # used by scripts/Makefile.package
233c741dc   Masahiro Yamada   kbuild: add LICEN...
1054
  export KBUILD_ALLDIRS := $(sort $(filter-out arch/%,$(vmlinux-alldirs)) LICENSES arch include scripts tools)
9bb482476   Jan Beulich   allow stripping o...
1055

d151e9719   Masahiro Yamada   kbuild: merge KBU...
1056
  vmlinux-deps := $(KBUILD_LDS) $(KBUILD_VMLINUX_OBJS) $(KBUILD_VMLINUX_LIBS)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1057

3fdc7d3fe   Masahiro Yamada   kbuild: link vmli...
1058
1059
  # Recurse until adjust_autoksyms.sh is satisfied
  PHONY += autoksyms_recursive
2441e78b1   Nicolas Pitre   kbuild: better ab...
1060
  ifdef CONFIG_TRIM_UNUSED_KSYMS
1f50b80a0   Masahiro Yamada   kbuild: move CONF...
1061
1062
1063
  # 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)
fb2d99be8   Masahiro Yamada   kbuild: merge two...
1064
1065
1066
1067
1068
  KBUILD_MODULES := 1
  
  autoksyms_recursive: descend modules.order
  	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/adjust_autoksyms.sh \
  	  "$(MAKE) -f $(srctree)/Makefile vmlinux"
1f50b80a0   Masahiro Yamada   kbuild: move CONF...
1069
  endif
07a422bb2   Masahiro Yamada   kbuild: restore a...
1070
  autoksyms_h := $(if $(CONFIG_TRIM_UNUSED_KSYMS), include/generated/autoksyms.h)
88694cff4   Quentin Perret   kbuild: generate ...
1071
1072
1073
  quiet_cmd_autoksyms_h = GEN     $@
        cmd_autoksyms_h = mkdir -p $(dir $@); \
  			$(CONFIG_SHELL) $(srctree)/scripts/gen_autoksyms.sh $@
07a422bb2   Masahiro Yamada   kbuild: restore a...
1074
  $(autoksyms_h):
88694cff4   Quentin Perret   kbuild: generate ...
1075
  	$(call cmd,autoksyms_h)
23121ca2b   Nicolas Pitre   kbuild: create/ad...
1076

fbe6e37da   Nicholas Piggin   kbuild: add arch ...
1077
1078
1079
  ARCH_POSTLINK := $(wildcard $(srctree)/arch/$(SRCARCH)/Makefile.postlink)
  
  # Final link of vmlinux with optional arch pass after final link
312a3d091   Cao jin   kbuild: trivial c...
1080
  cmd_link-vmlinux =                                                 \
3ec8a5b33   Masahiro Yamada   kbuild: do not ex...
1081
  	$(CONFIG_SHELL) $< "$(LD)" "$(KBUILD_LDFLAGS)" "$(LDFLAGS_vmlinux)";    \
fbe6e37da   Nicholas Piggin   kbuild: add arch ...
1082
  	$(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) $@, true)
2441e78b1   Nicolas Pitre   kbuild: better ab...
1083

3fdc7d3fe   Masahiro Yamada   kbuild: link vmli...
1084
  vmlinux: scripts/link-vmlinux.sh autoksyms_recursive $(vmlinux-deps) FORCE
1f2bfbd00   Sam Ravnborg   kbuild: link of v...
1085
  	+$(call if_changed,link-vmlinux)
741f98fe2   Sam Ravnborg   kbuild: do sectio...
1086

392885ee8   Masahiro Yamada   kbuild: let fixde...
1087
  targets := vmlinux
38385f8f0   Masahiro Yamada   kbuild: trivial -...
1088
  # The actual objects are generated when descending,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1089
  # make sure no implicit rule kicks in
b2c885549   Masahiro Yamada   kbuild: update mo...
1090
  $(sort $(vmlinux-deps) $(subdir-modorder)): descend ;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1091

ba97df455   Masahiro Yamada   kbuild: use assig...
1092
  filechk_kernel.release = \
0d0e7718a   Michal Marek   kbuild: Do not ov...
1093
  	echo "$(KERNELVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
0d0e7718a   Michal Marek   kbuild: Do not ov...
1094

83a35e360   Geert Uytterhoeven   treewide: relase ...
1095
  # Store (new) KERNELRELEASE string in include/config/kernel.release
24512795d   Masahiro Yamada   kbuild: remove un...
1096
  include/config/kernel.release: FORCE
0d0e7718a   Michal Marek   kbuild: Do not ov...
1097
  	$(call filechk,kernel.release)
cb58455c4   Sam Ravnborg   kbuild: KERNELREL...
1098

d8821622c   Masahiro Yamada   kbuild: move 'scr...
1099
1100
1101
1102
  # Additional helpers built in scripts/
  # Carefully list dependencies so we do not try to build scripts twice
  # in parallel
  PHONY += scripts
60df1aee2   Masahiro Yamada   kbuild: move modp...
1103
  scripts: scripts_basic scripts_dtc
d8821622c   Masahiro Yamada   kbuild: move 'scr...
1104
  	$(Q)$(MAKE) $(build)=$(@)
cb58455c4   Sam Ravnborg   kbuild: KERNELREL...
1105

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1106
  # Things we need to do before we recursively start building the kernel
5bb782690   Sam Ravnborg   kbuild: rename pr...
1107
1108
1109
1110
  # 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.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1111

a5139fb36   Masahiro Yamada   kbuild: remove pr...
1112
  PHONY += prepare archprepare
5bb782690   Sam Ravnborg   kbuild: rename pr...
1113

36de077b2   Masahiro Yamada   kbuild: check cle...
1114
  archprepare: outputmakefile archheaders archscripts scripts include/config/kernel.release \
3044dd052   Masahiro Yamada   kbuild: invoke sy...
1115
1116
  	asm-generic $(version_h) $(autoksyms_h) include/generated/utsrelease.h \
  	include/generated/autoconf.h
5bb782690   Sam Ravnborg   kbuild: rename pr...
1117

65bba0423   Masahiro Yamada   kbuild: fix UML b...
1118
  prepare0: archprepare
60df1aee2   Masahiro Yamada   kbuild: move modp...
1119
  	$(Q)$(MAKE) $(build)=scripts/mod
8d36a6236   Sam Ravnborg   kbuild: fix gener...
1120
  	$(Q)$(MAKE) $(build)=.
86feeaa81   Sam Ravnborg   kbuild: full depe...
1121

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1122
  # All the preparing..
33a57ce0a   Jiri Olsa   bpf: Compile reso...
1123
  prepare: prepare0 prepare-objtool prepare-resolve_btfids
b9ab5ebb1   Josh Poimboeuf   objtool: Add CONF...
1124

2c1f4f125   Masahiro Yamada   kbuild: re-order ...
1125
  # Support for using generic headers in asm-generic
7d0e5c205   Masahiro Yamada   kbuild: refactor ...
1126
  asm-generic := -f $(srctree)/scripts/Makefile.asm-generic obj
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
1127
1128
  PHONY += asm-generic uapi-asm-generic
  asm-generic: uapi-asm-generic
037fc3368   Masahiro Yamada   kbuild: force all...
1129
1130
  	$(Q)$(MAKE) $(asm-generic)=arch/$(SRCARCH)/include/generated/asm \
  	generic=include/asm-generic
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
1131
  uapi-asm-generic:
037fc3368   Masahiro Yamada   kbuild: force all...
1132
1133
  	$(Q)$(MAKE) $(asm-generic)=arch/$(SRCARCH)/include/generated/uapi/asm \
  	generic=include/uapi/asm-generic
2c1f4f125   Masahiro Yamada   kbuild: re-order ...
1134

33a57ce0a   Jiri Olsa   bpf: Compile reso...
1135
  PHONY += prepare-objtool prepare-resolve_btfids
3b27a0c85   Josh Poimboeuf   objtool: Detect a...
1136
  prepare-objtool: $(objtool_target)
ef7cfd00b   Masahiro Yamada   kbuild: fix false...
1137
1138
1139
1140
1141
1142
1143
1144
  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
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1145

33a57ce0a   Jiri Olsa   bpf: Compile reso...
1146
1147
1148
1149
1150
  prepare-resolve_btfids: $(resolve_btfids_target)
  ifeq ($(ERROR_RESOLVE_BTFIDS),1)
  	@echo "error: Cannot resolve BTF IDs for CONFIG_DEBUG_INFO_BTF, please install libelf-dev, libelf-devel or elfutils-libelf-devel" >&2
  	@false
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1151
1152
1153
1154
1155
1156
1157
  # 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
63104eec2   Sam Ravnborg   kbuild: introduce...
1158
1159
1160
1161
1162
  define filechk_utsrelease.h
  	if [ `echo -n "$(KERNELRELEASE)" | wc -c ` -gt $(uts_len) ]; then \
  	  echo '"$(KERNELRELEASE)" exceeds $(uts_len) characters' >&2;    \
  	  exit 1;                                                         \
  	fi;                                                               \
ad7740863   Masahiro Yamada   kbuild: change fi...
1163
  	echo \#define UTS_RELEASE \"$(KERNELRELEASE)\"
63104eec2   Sam Ravnborg   kbuild: introduce...
1164
  endef
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1165
1166
  
  define filechk_version.h
ad7740863   Masahiro Yamada   kbuild: change fi...
1167
  	echo \#define LINUX_VERSION_CODE $(shell                         \
450c6076a   Jesper Juhl   Makefile: improve...
1168
  	expr $(VERSION) \* 65536 + 0$(PATCHLEVEL) \* 256 + 0$(SUBLEVEL)); \
ad7740863   Masahiro Yamada   kbuild: change fi...
1169
  	echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1170
  endef
43fee2b23   Masahiro Yamada   kbuild: do not re...
1171
  $(version_h): FORCE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1172
  	$(call filechk,version.h)
223c24a7d   Michal Marek   kbuild: Automatic...
1173
  	$(Q)rm -f $(old_version_h)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1174

273b281fa   Sam Ravnborg   kbuild: move utsr...
1175
  include/generated/utsrelease.h: include/config/kernel.release FORCE
63104eec2   Sam Ravnborg   kbuild: introduce...
1176
  	$(call filechk,utsrelease.h)
179efcb47   Vegard Nossum   kbuild: add heade...
1177
1178
  PHONY += headerdep
  headerdep:
9663d9890   Peter Foley   kbuild: make head...
1179
1180
  	$(Q)find $(srctree)/include/ -name '*.h' | xargs --max-args 1 \
  	$(srctree)/scripts/headerdep.pl -I$(srctree)/include
179efcb47   Vegard Nossum   kbuild: add heade...
1181

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1182
  # ---------------------------------------------------------------------------
8d730cfb5   David Woodhouse   Basic implementat...
1183
  # Kernel headers
8d730cfb5   David Woodhouse   Basic implementat...
1184

e6883b187   Sam Ravnborg   kbuild: refactor ...
1185
1186
  #Default location for installed headers
  export INSTALL_HDR_PATH = $(objtree)/usr
6d7162758   David Woodhouse   New 'make headers...
1187

59b2bd05f   Masahiro Yamada   kbuild: add 'head...
1188
1189
1190
1191
1192
  quiet_cmd_headers_install = INSTALL $(INSTALL_HDR_PATH)/include
        cmd_headers_install = \
  	mkdir -p $(INSTALL_HDR_PATH); \
  	rsync -mrl --include='*/' --include='*\.h' --exclude='*' \
  	usr/include $(INSTALL_HDR_PATH)
e6883b187   Sam Ravnborg   kbuild: refactor ...
1193

8d730cfb5   David Woodhouse   Basic implementat...
1194
  PHONY += headers_install
59b2bd05f   Masahiro Yamada   kbuild: add 'head...
1195
1196
  headers_install: headers
  	$(call cmd,headers_install)
6520fe556   H. Peter Anvin   x86, realmode: 16...
1197

59b2bd05f   Masahiro Yamada   kbuild: add 'head...
1198
  PHONY += archheaders archscripts
e6883b187   Sam Ravnborg   kbuild: refactor ...
1199

a5bae54c1   Masahiro Yamada   kbuild: move hdr-...
1200
  hdr-inst := -f $(srctree)/scripts/Makefile.headersinst obj
6d7162758   David Woodhouse   New 'make headers...
1201

59b2bd05f   Masahiro Yamada   kbuild: add 'head...
1202
1203
  PHONY += headers
  headers: $(version_h) scripts_unifdef uapi-asm-generic archheaders archscripts
9d022c540   Masahiro Yamada   kbuild: replace $...
1204
  	$(if $(wildcard $(srctree)/arch/$(SRCARCH)/include/uapi/asm/Kbuild),, \
10b63956f   David Howells   UAPI: Plumb the U...
1205
  	  $(error Headers not exportable for the $(SRCARCH) architecture))
d5470d144   Masahiro Yamada   kbuild: re-implem...
1206
1207
  	$(Q)$(MAKE) $(hdr-inst)=include/uapi
  	$(Q)$(MAKE) $(hdr-inst)=arch/$(SRCARCH)/include/uapi
1f85712e6   Mike Frysinger   [PATCH] new tople...
1208

7ecaf069d   Masahiro Yamada   kbuild: move head...
1209
  # Deprecated. It is no-op now.
684753599   David Woodhouse   Basic implementat...
1210
  PHONY += headers_check
7ecaf069d   Masahiro Yamada   kbuild: move head...
1211
1212
  headers_check:
  	@:
684753599   David Woodhouse   Basic implementat...
1213

e949f4c2d   Masahiro Yamada   kbuild: add CONFI...
1214
  ifdef CONFIG_HEADERS_INSTALL
59b2bd05f   Masahiro Yamada   kbuild: add 'head...
1215
  prepare: headers
e949f4c2d   Masahiro Yamada   kbuild: add CONFI...
1216
  endif
684753599   David Woodhouse   Basic implementat...
1217

bdd7714b6   Masahiro Yamada   kbuild: build all...
1218
1219
1220
  PHONY += scripts_unifdef
  scripts_unifdef: scripts_basic
  	$(Q)$(MAKE) $(build)=scripts scripts/unifdef
8d730cfb5   David Woodhouse   Basic implementat...
1221
  # ---------------------------------------------------------------------------
5a5da78b3   Shuah Khan   kbuild: kselftest...
1222
1223
1224
1225
  # Kernel selftest
  
  PHONY += kselftest
  kselftest:
2bc84526d   Shuah Khan   Makefile: kselfte...
1226
  	$(Q)$(MAKE) -C $(srctree)/tools/testing/selftests run_tests
5a5da78b3   Shuah Khan   kbuild: kselftest...
1227

17eac6c2d   Shuah Khan   selftests: Add ks...
1228
1229
  kselftest-%: FORCE
  	$(Q)$(MAKE) -C $(srctree)/tools/testing/selftests $*
dcb825a9f   Wang Long   kselftest: add ks...
1230

3d6dee7af   Bamvor Jian Zhang   Makefile: add kse...
1231
1232
1233
  PHONY += kselftest-merge
  kselftest-merge:
  	$(if $(wildcard $(objtree)/.config),, $(error No .config exists, config your kernel first!))
6d3db46c8   Dan Rue   kbuild: teach kse...
1234
1235
  	$(Q)find $(srctree)/tools/testing/selftests -name config | \
  		xargs $(srctree)/scripts/kconfig/merge_config.sh -m $(objtree)/.config
3e4c6948e   Masahiro Yamada   kbuild: remove un...
1236
  	$(Q)$(MAKE) -f $(srctree)/Makefile olddefconfig
3d6dee7af   Bamvor Jian Zhang   Makefile: add kse...
1237

5a5da78b3   Shuah Khan   kbuild: kselftest...
1238
  # ---------------------------------------------------------------------------
37c8a5faf   Rob Herring   kbuild: consolida...
1239
1240
1241
1242
1243
1244
1245
  # Devicetree files
  
  ifneq ($(wildcard $(srctree)/arch/$(SRCARCH)/boot/dts/),)
  dtstree := arch/$(SRCARCH)/boot/dts
  endif
  
  ifneq ($(dtstree),)
a5139fb36   Masahiro Yamada   kbuild: remove pr...
1246
  %.dtb: include/config/kernel.release scripts_dtc
37c8a5faf   Rob Herring   kbuild: consolida...
1247
  	$(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@
c473a8d03   Masahiro Yamada   kbuild: add dt_bi...
1248
  PHONY += dtbs dtbs_install dtbs_check
b5154bf63   Masahiro Yamada   kbuild: avoid con...
1249
  dtbs: include/config/kernel.release scripts_dtc
37c8a5faf   Rob Herring   kbuild: consolida...
1250
  	$(Q)$(MAKE) $(build)=$(dtstree)
b5154bf63   Masahiro Yamada   kbuild: avoid con...
1251
  ifneq ($(filter dtbs_check, $(MAKECMDGOALS)),)
e10c4321d   Masahiro Yamada   kbuild: allow to ...
1252
  export CHECK_DTBS=y
b5154bf63   Masahiro Yamada   kbuild: avoid con...
1253
1254
  dtbs: dt_binding_check
  endif
b5154bf63   Masahiro Yamada   kbuild: avoid con...
1255
  dtbs_check: dtbs
4f0e3a57d   Rob Herring   kbuild: Add suppo...
1256

37c8a5faf   Rob Herring   kbuild: consolida...
1257
  dtbs_install:
2431f22a9   Masahiro Yamada   kbuild: compute t...
1258
  	$(Q)$(MAKE) $(dtbinst)=$(dtstree) dst=$(INSTALL_DTBS_PATH)
37c8a5faf   Rob Herring   kbuild: consolida...
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
  
  ifdef CONFIG_OF_EARLY_FLATTREE
  all: dtbs
  endif
  
  endif
  
  PHONY += scripts_dtc
  scripts_dtc: scripts_basic
  	$(Q)$(MAKE) $(build)=scripts/dtc
e10c4321d   Masahiro Yamada   kbuild: allow to ...
1269
1270
1271
  ifneq ($(filter dt_binding_check, $(MAKECMDGOALS)),)
  export CHECK_DT_BINDING=y
  endif
c473a8d03   Masahiro Yamada   kbuild: add dt_bi...
1272
  PHONY += dt_binding_check
4f0e3a57d   Rob Herring   kbuild: Add suppo...
1273
1274
  dt_binding_check: scripts_dtc
  	$(Q)$(MAKE) $(build)=Documentation/devicetree/bindings
37c8a5faf   Rob Herring   kbuild: consolida...
1275
  # ---------------------------------------------------------------------------
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1276
1277
1278
  # Modules
  
  ifdef CONFIG_MODULES
070b98bfd   Sam Ravnborg   kbuild: trivial f...
1279
  # By default, build modules as well
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1280

73d1393eb   Michal Marek   kbuild: Generate ...
1281
  all: modules
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1282

4b50c8c4e   Masahiro Yamada   kbuild: force to ...
1283
1284
1285
1286
1287
1288
  # 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.
  ifdef CONFIG_MODVERSIONS
    KBUILD_BUILTIN := 1
  endif
3fbb43df9   Masahiro Yamada   kbuild: trivial -...
1289
  # Build modules
551559e13   Tejun Heo   kbuild: implement...
1290
  #
3fbb43df9   Masahiro Yamada   kbuild: trivial -...
1291
1292
1293
  # 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.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1294

4f1933620   Paul Smith   kbuild: change kb...
1295
  PHONY += modules
596b0474d   Masahiro Yamada   kbuild: preproces...
1296
  modules: $(if $(KBUILD_BUILTIN),vmlinux) modules_check modules_prepare
b805aa0e7   Sam Ravnborg   kbuild: make -rR ...
1297
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1298

8451791d1   Masahiro Yamada   kbuild: make modu...
1299
1300
1301
  PHONY += modules_check
  modules_check: modules.order
  	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/modules-check.sh $<
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1302

b2c885549   Masahiro Yamada   kbuild: update mo...
1303
1304
1305
1306
1307
1308
  cmd_modules_order = $(AWK) '!x[$$0]++' $(real-prereqs) > $@
  
  modules.order: $(subdir-modorder) FORCE
  	$(call if_changed,modules_order)
  
  targets += modules.order
68980b470   Masahiro Yamada   kbuild: split mod...
1309

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1310
  # Target to prepare building external modules
4f1933620   Paul Smith   kbuild: change kb...
1311
  PHONY += modules_prepare
059bc9fc3   Masahiro Yamada   kbuild: make 'arc...
1312
  modules_prepare: prepare
596b0474d   Masahiro Yamada   kbuild: preproces...
1313
  	$(Q)$(MAKE) $(build)=scripts scripts/module.lds
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1314
1315
  
  # Target to install modules
4f1933620   Paul Smith   kbuild: change kb...
1316
  PHONY += modules_install
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1317
  modules_install: _modinst_ _modinst_post
4f1933620   Paul Smith   kbuild: change kb...
1318
  PHONY += _modinst_
2c6d9636a   Masahiro Yamada   Revert "Makefile:...
1319
  _modinst_:
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1320
1321
1322
  	@rm -rf $(MODLIB)/kernel
  	@rm -f $(MODLIB)/source
  	@mkdir -p $(MODLIB)/kernel
8e9b46679   Masahiro Yamada   kbuild: use $(abs...
1323
  	@ln -s $(abspath $(srctree)) $(MODLIB)/source
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1324
1325
  	@if [ ! $(objtree) -ef  $(MODLIB)/build ]; then \
  		rm -f $(MODLIB)/build ; \
7e1c04779   Michal Marek   kbuild: Use relat...
1326
  		ln -s $(CURDIR) $(MODLIB)/build ; \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1327
  	fi
1bd9a4680   Masahiro Yamada   kbuild: get rid o...
1328
  	@sed 's:^:kernel/:' modules.order > $(MODLIB)/modules.order
2c6d9636a   Masahiro Yamada   Revert "Makefile:...
1329
1330
  	@cp -f modules.builtin $(MODLIB)/
  	@cp -f $(objtree)/modules.builtin.modinfo $(MODLIB)/
b805aa0e7   Sam Ravnborg   kbuild: make -rR ...
1331
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modinst
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1332

50a8ec31c   Sam Ravnborg   kbuild: disable d...
1333
  # This depmod is only for convenience to give the initial
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1334
1335
  # boot a modules.dep even before / is mounted read-write.  However the
  # boot script depmod is the master version.
4f1933620   Paul Smith   kbuild: change kb...
1336
  PHONY += _modinst_post
6d128e1e7   Linus Torvalds   Revert "Makefile:...
1337
  _modinst_post: _modinst_
50a8ec31c   Sam Ravnborg   kbuild: disable d...
1338
  	$(call cmd,depmod)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1339

d890f510c   Josh Boyer   MODSIGN: Add modu...
1340
1341
1342
1343
1344
  ifeq ($(CONFIG_MODULE_SIG), y)
  PHONY += modules_sign
  modules_sign:
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modsign
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1345
1346
1347
1348
  else # CONFIG_MODULES
  
  # Modules not configured
  # ---------------------------------------------------------------------------
612e47cec   Masahiro Yamada   kbuild: specify m...
1349
1350
  PHONY += modules modules_install
  modules modules_install:
5369f5502   Michal Marek   kbuild: Print err...
1351
1352
1353
1354
1355
  	@echo >&2
  	@echo >&2 "The present kernel configuration has modules disabled."
  	@echo >&2 "Type 'make config' and enable loadable module support."
  	@echo >&2 "Then build a kernel with module support enabled."
  	@echo >&2
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1356
1357
1358
  	@exit 1
  
  endif # CONFIG_MODULES
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1359
1360
1361
1362
1363
1364
1365
1366
  ###
  # Cleaning is done on three levels.
  # make clean     Delete most generated files
  #                Leave enough to build external modules
  # make mrproper  Delete the current configuration, and all generated files
  # make distclean Remove editor backup files, patch leftover files and the like
  
  # Directories & files removed with 'make clean'
269a535ca   Masahiro Yamada   modpost: generate...
1367
  CLEAN_FILES += include/ksym vmlinux.symvers \
3d32285fa   Masahiro Yamada   kbuild: wire up t...
1368
1369
  	       modules.builtin modules.builtin.modinfo modules.nsdeps \
  	       compile_commands.json
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1370
1371
  
  # Directories & files removed with 'make mrproper'
0663c68c4   Masahiro Yamada   kbuild: remove {C...
1372
  MRPROPER_FILES += include/config include/generated          \
46a63d4b0   Masahiro Yamada   kbuild: pkg: clea...
1373
  		  arch/$(SRCARCH)/include/generated .tmp_objdiff \
0663c68c4   Masahiro Yamada   kbuild: remove {C...
1374
1375
  		  debian snap tar-install \
  		  .config .config.old .version \
46457133a   Masahiro Yamada   kbuild: remove ta...
1376
  		  Module.symvers \
fb1179499   David Woodhouse   modsign: Use sing...
1377
1378
  		  signing_key.pem signing_key.priv signing_key.x509	\
  		  x509.genkey extra_certificates signing_key.x509.keyid	\
46a63d4b0   Masahiro Yamada   kbuild: pkg: clea...
1379
1380
  		  signing_key.x509.signer vmlinux-gdb.py \
  		  *.spec
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1381

46457133a   Masahiro Yamada   kbuild: remove ta...
1382
  # Directories & files removed with 'make distclean'
46457133a   Masahiro Yamada   kbuild: remove ta...
1383
  DISTCLEAN_FILES += tags TAGS cscope* GPATH GTAGS GRTAGS GSYMS
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1384
1385
  # clean - Delete most, but leave enough to build external modules
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1386
  clean: rm-files := $(CLEAN_FILES)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1387

76cd306d7   Masahiro Yamada   kbuild: unify cle...
1388
  PHONY += archclean vmlinuxclean
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1389

bd1ee804a   Pawel Moll   kbuild: Do not re...
1390
1391
  vmlinuxclean:
  	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/link-vmlinux.sh clean
fbe6e37da   Nicholas Piggin   kbuild: add arch ...
1392
  	$(Q)$(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) clean)
bd1ee804a   Pawel Moll   kbuild: Do not re...
1393
1394
  
  clean: archclean vmlinuxclean
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1395
1396
1397
  
  # mrproper - Delete all generated files, including .config
  #
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1398
  mrproper: rm-files := $(wildcard $(MRPROPER_FILES))
cb43fb577   Mauro Carvalho Chehab   docs: remove DocB...
1399
  mrproper-dirs      := $(addprefix _mrproper_,scripts)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1400

b421b8a6c   Masahiro Yamada   kbuild: remove un...
1401
  PHONY += $(mrproper-dirs) mrproper
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1402
1403
  $(mrproper-dirs):
  	$(Q)$(MAKE) $(clean)=$(patsubst _mrproper_%,%,$@)
b421b8a6c   Masahiro Yamada   kbuild: remove un...
1404
  mrproper: clean $(mrproper-dirs)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1405
1406
1407
1408
  	$(call cmd,rmfiles)
  
  # distclean
  #
46457133a   Masahiro Yamada   kbuild: remove ta...
1409
  distclean: rm-files := $(wildcard $(DISTCLEAN_FILES))
4f1933620   Paul Smith   kbuild: change kb...
1410
  PHONY += distclean
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1411
1412
  
  distclean: mrproper
46457133a   Masahiro Yamada   kbuild: remove ta...
1413
  	$(call cmd,rmfiles)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1414
  	@find $(srctree) $(RCS_FIND_IGNORE) \
070b98bfd   Sam Ravnborg   kbuild: trivial f...
1415
  		\( -name '*.orig' -o -name '*.rej' -o -name '*~' \
f78271dfb   Masahiro Yamada   kbuild: drop unne...
1416
1417
  		-o -name '*.bak' -o -name '#*#' -o -name '*%' \
  		-o -name 'core' \) \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1418
1419
1420
1421
1422
  		-type f -print | xargs rm -f
  
  
  # Packaging of the kernel to various formats
  # ---------------------------------------------------------------------------
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1423

bafb67470   Arnaldo Carvalho de Melo   perf tools: Allow...
1424
  %src-pkg: FORCE
000ec95fb   Masahiro Yamada   kbuild: pkg: rena...
1425
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.package $@
031ecc6de   Zach Brown   kbuild: add depen...
1426
  %pkg: include/config/kernel.release FORCE
000ec95fb   Masahiro Yamada   kbuild: pkg: rena...
1427
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.package $@
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1428
1429
1430
  
  # Brief documentation of the typical targets used
  # ---------------------------------------------------------------------------
5dffbe811   Segher Boessenkool   kbuild: show defc...
1431
  boards := $(wildcard $(srctree)/arch/$(SRCARCH)/configs/*_defconfig)
a1e7b7bb1   Konstantin Khlebnikov   Makefile: sort li...
1432
  boards := $(sort $(notdir $(boards)))
5dffbe811   Segher Boessenkool   kbuild: show defc...
1433
1434
  board-dirs := $(dir $(wildcard $(srctree)/arch/$(SRCARCH)/configs/*/*_defconfig))
  board-dirs := $(sort $(notdir $(board-dirs:/=)))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1435

fe69b420d   Masahiro Yamada   kbuild: mark help...
1436
  PHONY += help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1437
1438
  help:
  	@echo  'Cleaning targets:'
5ea084ef9   Samuel Tardieu   Use consistent ca...
1439
  	@echo  '  clean		  - Remove most generated files but keep the config and'
5cc8d246d   Jesper Juhl   kbuild: add distc...
1440
  	@echo  '                    enough build support to build external modules'
5ea084ef9   Samuel Tardieu   Use consistent ca...
1441
  	@echo  '  mrproper	  - Remove all generated files + config + various backup files'
5cc8d246d   Jesper Juhl   kbuild: add distc...
1442
  	@echo  '  distclean	  - mrproper + remove editor backup and patch files'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1443
1444
1445
1446
1447
1448
1449
1450
  	@echo  ''
  	@echo  'Configuration targets:'
  	@$(MAKE) -f $(srctree)/scripts/kconfig/Makefile help
  	@echo  ''
  	@echo  'Other generic targets:'
  	@echo  '  all		  - Build all targets marked with [*]'
  	@echo  '* vmlinux	  - Build the bare kernel'
  	@echo  '* modules	  - Build all modules'
9cc5d74c8   Bodo Eggert   kbuild: document ...
1451
  	@echo  '  modules_install - Install all modules to INSTALL_MOD_PATH (default: /)'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1452
  	@echo  '  dir/            - Build all files in dir and below'
40ab87a40   Wang YanQing   Makefile: revert ...
1453
  	@echo  '  dir/file.[ois]  - Build specified target only'
433db3e26   Vinícius Tinti   kbuild: Add suppo...
1454
1455
  	@echo  '  dir/file.ll     - Build the LLVM assembly file'
  	@echo  '                    (requires compiler support for LLVM assembly generation)'
627189797   Joe Perches   Makefile: Documen...
1456
1457
  	@echo  '  dir/file.lst    - Build specified mixed source/assembly target only'
  	@echo  '                    (requires a recent binutils and recent build (System.map))'
155ad605b   Sam Ravnborg   [PATCH] kbuild: b...
1458
  	@echo  '  dir/file.ko     - Build module including final link'
c4d5ee67c   Robert P. J. Day   kbuild: "make pre...
1459
  	@echo  '  modules_prepare - Set up for building external modules'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1460
1461
  	@echo  '  tags/TAGS	  - Generate tags file for editors'
  	@echo  '  cscope	  - Generate cscope index'
f4ed1009f   Jianbin Kang   kbuild: add GNU G...
1462
  	@echo  '  gtags           - Generate GNU GLOBAL index'
3f1d9a6ce   Michal Marek   kbuild: make -s s...
1463
1464
1465
  	@echo  '  kernelrelease	  - Output the release version string (use with make -s)'
  	@echo  '  kernelversion	  - Output the version stored in Makefile (use with make -s)'
  	@echo  '  image_name	  - Output the image name (use with make -s)'
2fb9b1bd9   Sam Ravnborg   kbuild: prepare h...
1466
  	@echo  '  headers_install - Install sanitised kernel headers to INSTALL_HDR_PATH'; \
59df3230f   Geert Uytterhoeven   [PATCH] `make hel...
1467
  	 echo  '                    (default: $(INSTALL_HDR_PATH))'; \
2fb9b1bd9   Sam Ravnborg   kbuild: prepare h...
1468
  	 echo  ''
31b8cc807   Randy Dunlap   make help: add to...
1469
  	@echo  'Static analysers:'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1470
  	@echo  '  checkstack      - Generate a list of stack hogs'
aa025e7d5   Sam Ravnborg   kbuild: document ...
1471
  	@echo  '  versioncheck    - Sanity check on version.h usage'
ec2d987f9   Randy Dunlap   kbuild: add 'incl...
1472
  	@echo  '  includecheck    - Check for duplicate included header files'
295ac0518   Adrian Bunk   kbuild: call expo...
1473
  	@echo  '  export_report   - List the usages of all exported symbols'
74425eee7   Nicolas Palix   Add a target to u...
1474
  	@echo  '  headerdep       - Detect inclusion cycles in headers'
7f855fc80   Masahiro Yamada   kbuild: move cocc...
1475
  	@echo  '  coccicheck      - Check with Coccinelle'
6ad7cbc01   Nathan Huckleberry   Makefile: Add cla...
1476
1477
  	@echo  '  clang-analyzer  - Check with clang static analyzer'
  	@echo  '  clang-tidy      - Check with clang-tidy'
74425eee7   Nicolas Palix   Add a target to u...
1478
  	@echo  ''
eb8305aec   Matthias Maennich   scripts: Coccinel...
1479
1480
1481
  	@echo  'Tools:'
  	@echo  '  nsdeps          - Generate missing symbol namespace dependencies'
  	@echo  ''
31b8cc807   Randy Dunlap   make help: add to...
1482
  	@echo  'Kernel selftest:'
e51d8dacf   Shuah Khan   Makefile: Update ...
1483
1484
1485
1486
1487
1488
1489
1490
1491
  	@echo  '  kselftest         - Build and run kernel selftest'
  	@echo  '                      Build, install, and boot kernel before'
  	@echo  '                      running kselftest on it'
  	@echo  '                      Run as root for full coverage'
  	@echo  '  kselftest-all     - Build kernel selftest'
  	@echo  '  kselftest-install - Build and install kernel selftest'
  	@echo  '  kselftest-clean   - Remove all generated kselftest files'
  	@echo  '  kselftest-merge   - Merge all the config dependencies of'
  	@echo  '		      kselftest to existing .config.'
5a5da78b3   Shuah Khan   kbuild: kselftest...
1492
  	@echo  ''
37c8a5faf   Rob Herring   kbuild: consolida...
1493
1494
  	@$(if $(dtstree), \
  		echo 'Devicetree:'; \
7aa8dd91d   Stephen Boyd   devicetree: Expos...
1495
1496
1497
1498
  		echo '* dtbs             - Build device tree blobs for enabled boards'; \
  		echo '  dtbs_install     - Install dtbs to $(INSTALL_DTBS_PATH)'; \
  		echo '  dt_binding_check - Validate device tree binding documents'; \
  		echo '  dtbs_check       - Validate device tree source files';\
37c8a5faf   Rob Herring   kbuild: consolida...
1499
  		echo '')
31b8cc807   Randy Dunlap   make help: add to...
1500
1501
1502
1503
  	@echo 'Userspace tools targets:'
  	@echo '  use "make tools/help"'
  	@echo '  or  "cd tools; make help"'
  	@echo  ''
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1504
  	@echo  'Kernel packaging:'
000ec95fb   Masahiro Yamada   kbuild: pkg: rena...
1505
  	@$(MAKE) -f $(srctree)/scripts/Makefile.package help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1506
1507
  	@echo  ''
  	@echo  'Documentation targets:'
cb43fb577   Mauro Carvalho Chehab   docs: remove DocB...
1508
  	@$(MAKE) -f $(srctree)/Documentation/Makefile dochelp
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1509
  	@echo  ''
01dee1881   Andres Salomon   kbuild: fix help ...
1510
  	@echo  'Architecture specific targets ($(SRCARCH)):'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1511
  	@$(if $(archhelp),$(archhelp),\
01dee1881   Andres Salomon   kbuild: fix help ...
1512
  		echo '  No architecture specific help defined for $(SRCARCH)')
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1513
1514
1515
  	@echo  ''
  	@$(if $(boards), \
  		$(foreach b, $(boards), \
4234448b7   Geert Uytterhoeven   kbuild: Extend de...
1516
1517
  		printf "  %-27s - Build for %s\
  " $(b) $(subst _defconfig,,$(b));) \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1518
  		echo '')
5dffbe811   Segher Boessenkool   kbuild: show defc...
1519
1520
1521
1522
1523
1524
1525
  	@$(if $(board-dirs), \
  		$(foreach b, $(board-dirs), \
  		printf "  %-16s - Show %s-specific targets\
  " help-$(b) $(b);) \
  		printf "  %-16s - Show all of the above\
  " help-boards; \
  		echo '')
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1526
1527
  
  	@echo  '  make V=0|1 [targets] 0 => quiet build (default), 1 => verbose build'
45d506bd6   Sam Ravnborg   kbuild: make V=2 ...
1528
  	@echo  '  make V=2   [targets] 2 => give reason for rebuild of target'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1529
  	@echo  '  make O=dir [targets] Locate all output files in "dir", including .config'
a64c0440d   Geert Uytterhoeven   kbuild: Wrap long...
1530
1531
  	@echo  '  make C=1   [targets] Check re-compiled c source with $$CHECK'
  	@echo  '                       (sparse by default)'
701842e3b   Dustin Kirkland   kbuild: documenta...
1532
  	@echo  '  make C=2   [targets] Force check of all c source with $$CHECK'
af07ce3e7   Ingo Molnar   Merge branch 'tip...
1533
  	@echo  '  make RECORDMCOUNT_WARN=1 [targets] Warn about ignored mcount sections'
e27128db6   Masahiro Yamada   kbuild: rename KB...
1534
  	@echo  '  make W=n   [targets] Enable extra build checks, n=1,2,3 where'
28bc20dcc   Sam Ravnborg   kbuild: implement...
1535
1536
1537
  	@echo  '		1: warnings which may be relevant and do not occur too often'
  	@echo  '		2: warnings which occur quite often but may still be relevant'
  	@echo  '		3: more obscure warnings, can most likely be ignored'
a6de553da   Michal Marek   kbuild: Allow to ...
1538
  	@echo  '		Multiple levels can be combined with W=12 or W=123'
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1539
1540
1541
  	@echo  ''
  	@echo  'Execute "make" or "make all" to build all targets marked with [*] '
  	@echo  'For further info see the ./README file'
5dffbe811   Segher Boessenkool   kbuild: show defc...
1542
1543
1544
  help-board-dirs := $(addprefix help-,$(board-dirs))
  
  help-boards: $(help-board-dirs)
fbae4d585   Michal Marek   kbuild: Fix make ...
1545
  boards-per-dir = $(sort $(notdir $(wildcard $(srctree)/arch/$(SRCARCH)/configs/$*/*_defconfig)))
5dffbe811   Segher Boessenkool   kbuild: show defc...
1546
1547
1548
1549
1550
1551
1552
1553
  
  $(help-board-dirs): help-%:
  	@echo  'Architecture specific targets ($(SRCARCH) $*):'
  	@$(if $(boards-per-dir), \
  		$(foreach b, $(boards-per-dir), \
  		printf "  %-24s - Build for %s\
  " $*/$(b) $(subst _defconfig,,$(b));) \
  		echo '')
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1554
1555
  # Documentation targets
  # ---------------------------------------------------------------------------
e8939222d   Jani Nikula   Documentation: ad...
1556
1557
  DOC_TARGETS := xmldocs latexdocs pdfdocs htmldocs epubdocs cleandocs \
  	       linkcheckdocs dochelp refcheckdocs
22cba31ba   Jani Nikula   Documentation/sph...
1558
  PHONY += $(DOC_TARGETS)
bc7b752a7   Masahiro Yamada   kbuild: remove un...
1559
  $(DOC_TARGETS):
cb43fb577   Mauro Carvalho Chehab   docs: remove DocB...
1560
  	$(Q)$(MAKE) $(build)=Documentation $@
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1561

67274c083   Masahiro Yamada   scripts/gdb: dela...
1562
1563
1564
1565
  # Misc
  # ---------------------------------------------------------------------------
  
  PHONY += scripts_gdb
7a739ce51   Masahiro Yamada   kbuild: make gdb_...
1566
  scripts_gdb: prepare0
1e5ff84ff   Masahiro Yamada   scripts/gdb: do n...
1567
  	$(Q)$(MAKE) $(build)=scripts/gdb
8d2e52003   Masahiro Yamada   kbuild: create sy...
1568
  	$(Q)ln -fsn $(abspath $(srctree)/scripts/gdb/vmlinux-gdb.py)
67274c083   Masahiro Yamada   scripts/gdb: dela...
1569
1570
1571
1572
  
  ifdef CONFIG_GDB_SCRIPTS
  all: scripts_gdb
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
  else # KBUILD_EXTMOD
  
  ###
  # External module support.
  # When building external modules the kernel used as basis is considered
  # read-only, and no consistency checks are made and the make
  # system is not used on the basis kernel. If updates are required
  # in the basis kernel ordinary make commands (without M=...) must
  # be used.
  #
  # The following are the only valid targets when building external
  # modules.
  # make M=dir clean     Delete all automatically generated files
  # make M=dir modules   Make all modules in specified dir
  # make M=dir	       Same as 'make M=dir modules'
  # make M=dir modules_install
070b98bfd   Sam Ravnborg   kbuild: trivial f...
1589
  #                      Install the modules built in the module directory
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1590
  #                      Assumes install directory is already created
6212804f2   Masahiro Yamada   kbuild: do not cr...
1591
1592
  # We are always building only modules.
  KBUILD_BUILTIN :=
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1593
  KBUILD_MODULES := 1
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1594

c99f3918c   Masahiro Yamada   kbuild: unify vml...
1595
1596
  build-dirs := $(KBUILD_EXTMOD)
  PHONY += modules
3d32285fa   Masahiro Yamada   kbuild: wire up t...
1597
  modules: $(MODORDER)
b805aa0e7   Sam Ravnborg   kbuild: make -rR ...
1598
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1599

3d32285fa   Masahiro Yamada   kbuild: wire up t...
1600
1601
  $(MODORDER): descend
  	@:
4f1933620   Paul Smith   kbuild: change kb...
1602
  PHONY += modules_install
a67dc21a3   Sam Ravnborg   kbuild: run depmo...
1603
  modules_install: _emodinst_ _emodinst_post
e63046630   Adrian Bunk   kbuild: remove a ...
1604

4f1933620   Paul Smith   kbuild: change kb...
1605
1606
  install-dir := $(if $(INSTALL_MOD_DIR),$(INSTALL_MOD_DIR),extra)
  PHONY += _emodinst_
a67dc21a3   Sam Ravnborg   kbuild: run depmo...
1607
  _emodinst_:
a67dc21a3   Sam Ravnborg   kbuild: run depmo...
1608
  	$(Q)mkdir -p $(MODLIB)/$(install-dir)
b805aa0e7   Sam Ravnborg   kbuild: make -rR ...
1609
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modinst
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1610

4f1933620   Paul Smith   kbuild: change kb...
1611
  PHONY += _emodinst_post
a67dc21a3   Sam Ravnborg   kbuild: run depmo...
1612
1613
  _emodinst_post: _emodinst_
  	$(call cmd,depmod)
3d32285fa   Masahiro Yamada   kbuild: wire up t...
1614
1615
  compile_commands.json: $(extmod-prefix)compile_commands.json
  PHONY += compile_commands.json
76cd306d7   Masahiro Yamada   kbuild: unify cle...
1616
  clean-dirs := $(KBUILD_EXTMOD)
3d32285fa   Masahiro Yamada   kbuild: wire up t...
1617
1618
  clean: rm-files := $(KBUILD_EXTMOD)/Module.symvers $(KBUILD_EXTMOD)/modules.nsdeps \
  	$(KBUILD_EXTMOD)/compile_commands.json
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1619

fe69b420d   Masahiro Yamada   kbuild: mark help...
1620
  PHONY += help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1621
1622
1623
1624
1625
1626
1627
1628
  help:
  	@echo  '  Building external modules.'
  	@echo  '  Syntax: make -C path/to/kernel/src M=$$PWD target'
  	@echo  ''
  	@echo  '  modules         - default target, build the module(s)'
  	@echo  '  modules_install - install the module'
  	@echo  '  clean           - remove generated files in module directory only'
  	@echo  ''
06300b21f   Sam Ravnborg   kbuild: support b...
1629

596b0474d   Masahiro Yamada   kbuild: preproces...
1630
1631
  # no-op for external module builds
  PHONY += prepare modules_prepare
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1632
  endif # KBUILD_EXTMOD
b1fbfcb4a   Masahiro Yamada   kbuild: make sing...
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
  # Single targets
  # ---------------------------------------------------------------------------
  # To build individual files in subdirectories, you can do like this:
  #
  #   make foo/bar/baz.s
  #
  # The supported suffixes for single-target are listed in 'single-targets'
  #
  # To build only under specific subdirectories, you can do like this:
  #
  #   make foo/bar/baz/
  
  ifdef single-build
  
  # .ko is special because modpost is needed
  single-ko := $(sort $(filter %.ko, $(MAKECMDGOALS)))
  single-no-ko := $(sort $(patsubst %.ko,%.mod, $(MAKECMDGOALS)))
  
  $(single-ko): single_modpost
  	@:
  $(single-no-ko): descend
  	@:
  
  ifeq ($(KBUILD_EXTMOD),)
  # For the single build of in-tree modules, use a temporary file to avoid
  # the situation of modules_install installing an invalid modules.order.
  MODORDER := .modules.tmp
  endif
  
  PHONY += single_modpost
596b0474d   Masahiro Yamada   kbuild: preproces...
1663
  single_modpost: $(single-no-ko) modules_prepare
b1fbfcb4a   Masahiro Yamada   kbuild: make sing...
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
  	$(Q){ $(foreach m, $(single-ko), echo $(extmod-prefix)$m;) } > $(MODORDER)
  	$(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost
  
  KBUILD_MODULES := 1
  
  export KBUILD_SINGLE_TARGETS := $(addprefix $(extmod-prefix), $(single-no-ko))
  
  # trim unrelated directories
  build-dirs := $(foreach d, $(build-dirs), \
  			$(if $(filter $(d)/%, $(KBUILD_SINGLE_TARGETS)), $(d)))
  
  endif
b480fec98   Masahiro Yamada   kbuild: clear KBU...
1676
1677
1678
  ifndef CONFIG_MODULES
  KBUILD_MODULES :=
  endif
c99f3918c   Masahiro Yamada   kbuild: unify vml...
1679
1680
1681
1682
1683
1684
1685
1686
  # Handle descending into subdirectories listed in $(build-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
  PHONY += descend $(build-dirs)
  descend: $(build-dirs)
  $(build-dirs): prepare
b1fbfcb4a   Masahiro Yamada   kbuild: make sing...
1687
  	$(Q)$(MAKE) $(build)=$@ \
20b1be595   Masahiro Yamada   kbuild: fix singl...
1688
  	single-build=$(if $(filter-out $@/, $(filter $@/%, $(KBUILD_SINGLE_TARGETS))),1) \
b1fbfcb4a   Masahiro Yamada   kbuild: make sing...
1689
  	need-builtin=1 need-modorder=1
c99f3918c   Masahiro Yamada   kbuild: unify vml...
1690

76cd306d7   Masahiro Yamada   kbuild: unify cle...
1691
1692
1693
1694
  clean-dirs := $(addprefix _clean_, $(clean-dirs))
  PHONY += $(clean-dirs) clean
  $(clean-dirs):
  	$(Q)$(MAKE) $(clean)=$(patsubst _clean_%,%,$@)
88d7be031   Michal Marek   kbuild: Use a sin...
1695
  clean: $(clean-dirs)
88d7be031   Michal Marek   kbuild: Use a sin...
1696
  	$(call cmd,rmfiles)
43f67c981   Kevin Cernekee   kbuild: Fix GNU m...
1697
  	@find $(if $(KBUILD_EXTMOD), $(KBUILD_EXTMOD), .) $(RCS_FIND_IGNORE) \
ef46d9b3d   Masahiro Yamada   kbuild: clean up ...
1698
  		\( -name '*.[aios]' -o -name '*.ko' -o -name '.*.cmd' \
4f0e3a57d   Rob Herring   kbuild: Add suppo...
1699
1700
  		-o -name '*.ko.*' \
  		-o -name '*.dtb' -o -name '*.dtb.S' -o -name '*.dt.yaml' \
ef46d9b3d   Masahiro Yamada   kbuild: clean up ...
1701
  		-o -name '*.dwo' -o -name '*.lst' \
bbc55bded   Masahiro Yamada   modpost: dump mis...
1702
  		-o -name '*.su' -o -name '*.mod' \
88d7be031   Michal Marek   kbuild: Use a sin...
1703
  		-o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \
9a8dfb394   Masahiro Yamada   kbuild: clean up ...
1704
  		-o -name '*.lex.c' -o -name '*.tab.[ch]' \
4fa8bc949   Masahiro Yamada   kbuild: rename *-...
1705
  		-o -name '*.asn1.[ch]' \
88d7be031   Michal Marek   kbuild: Use a sin...
1706
  		-o -name '*.symtypes' -o -name 'modules.order' \
8b41fc445   Masahiro Yamada   kbuild: create mo...
1707
  		-o -name '.tmp_*.o.*' \
6b90bd4ba   Emese Revfy   GCC plugin infras...
1708
  		-o -name '*.c.[012]*.*' \
433db3e26   Vinícius Tinti   kbuild: Add suppo...
1709
  		-o -name '*.ll' \
88d7be031   Michal Marek   kbuild: Use a sin...
1710
  		-o -name '*.gcno' \) -type f -print | xargs rm -f
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1711
1712
  # Generate tags for editors
  # ---------------------------------------------------------------------------
a680eedc6   Sam Ravnborg   tags and cscope s...
1713
  quiet_cmd_tags = GEN     $@
858805b33   Masahiro Yamada   kbuild: add $(BAS...
1714
        cmd_tags = $(BASH) $(srctree)/scripts/tags.sh $@
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1715

f4ed1009f   Jianbin Kang   kbuild: add GNU G...
1716
  tags TAGS cscope gtags: FORCE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1717
  	$(call cmd,tags)
eb8305aec   Matthias Maennich   scripts: Coccinel...
1718
1719
1720
1721
  # Script to generate missing namespace dependencies
  # ---------------------------------------------------------------------------
  
  PHONY += nsdeps
bff9c62b5   Masahiro Yamada   modpost: do not i...
1722
  nsdeps: export KBUILD_NSDEPS=1
eb8305aec   Matthias Maennich   scripts: Coccinel...
1723
  nsdeps: modules
bff9c62b5   Masahiro Yamada   modpost: do not i...
1724
  	$(Q)$(CONFIG_SHELL) $(srctree)/scripts/nsdeps
eb8305aec   Matthias Maennich   scripts: Coccinel...
1725

3d32285fa   Masahiro Yamada   kbuild: wire up t...
1726
1727
1728
1729
1730
  # Clang Tooling
  # ---------------------------------------------------------------------------
  
  quiet_cmd_gen_compile_commands = GEN     $@
        cmd_gen_compile_commands = $(PYTHON3) $< -a $(AR) -o $@ $(filter-out $<, $(real-prereqs))
6ad7cbc01   Nathan Huckleberry   Makefile: Add cla...
1731
  $(extmod-prefix)compile_commands.json: scripts/clang-tools/gen_compile_commands.py \
3d32285fa   Masahiro Yamada   kbuild: wire up t...
1732
1733
1734
1735
1736
  	$(if $(KBUILD_EXTMOD),,$(KBUILD_VMLINUX_OBJS) $(KBUILD_VMLINUX_LIBS)) \
  	$(if $(CONFIG_MODULES), $(MODORDER)) FORCE
  	$(call if_changed,gen_compile_commands)
  
  targets += $(extmod-prefix)compile_commands.json
6ad7cbc01   Nathan Huckleberry   Makefile: Add cla...
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
  PHONY += clang-tidy clang-analyzer
  
  ifdef CONFIG_CC_IS_CLANG
  quiet_cmd_clang_tools = CHECK   $<
        cmd_clang_tools = $(PYTHON3) $(srctree)/scripts/clang-tools/run-clang-tools.py $@ $<
  
  clang-tidy clang-analyzer: $(extmod-prefix)compile_commands.json
  	$(call cmd,clang_tools)
  else
  clang-tidy clang-analyzer:
  	@echo "$@ requires CC=clang" >&2
  	@false
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1750
1751
  # Scripts to check various things for consistency
  # ---------------------------------------------------------------------------
7dfbea4c4   Jacob Keller   scripts: remove n...
1752
  PHONY += includecheck versioncheck coccicheck export_report
279f3dd35   Peter Foley   kbuild: add targe...
1753

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1754
  includecheck:
436f876cc   Peter Foley   kbuild: make incl...
1755
  	find $(srctree)/* $(RCS_FIND_IGNORE) \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1756
  		-name '*.[hcS]' -type f -print | sort \
800074345   Geert Uytterhoeven   kbuild: Add missi...
1757
  		| xargs $(PERL) -w $(srctree)/scripts/checkincludes.pl
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1758
1759
  
  versioncheck:
2ee2d2928   Peter Foley   kbuild: make vers...
1760
  	find $(srctree)/* $(RCS_FIND_IGNORE) \
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1761
  		-name '*.[hcS]' -type f -print | sort \
800074345   Geert Uytterhoeven   kbuild: Add missi...
1762
  		| xargs $(PERL) -w $(srctree)/scripts/checkversion.pl
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1763

74425eee7   Nicolas Palix   Add a target to u...
1764
  coccicheck:
858805b33   Masahiro Yamada   kbuild: add $(BAS...
1765
  	$(Q)$(BASH) $(srctree)/scripts/$@
74425eee7   Nicolas Palix   Add a target to u...
1766

295ac0518   Adrian Bunk   kbuild: call expo...
1767
1768
  export_report:
  	$(PERL) $(srctree)/scripts/export_report.pl
c398ff00f   Mike Marciniszyn   kbuild: fix error...
1769
  PHONY += checkstack kernelrelease kernelversion image_name
e3ccf6e36   Jeff Dike   [PATCH] uml: add ...
1770

011e3a9ad   Jeff Dike   [PATCH] Fix cross...
1771
1772
1773
1774
1775
1776
1777
1778
1779
  # UML needs a little special treatment here.  It wants to use the host
  # toolchain, so needs $(SUBARCH) passed to checkstack.pl.  Everyone
  # else wants $(ARCH), including people doing cross-builds, which means
  # that $(SUBARCH) doesn't work here.
  ifeq ($(ARCH), um)
  CHECKSTACK_ARCH := $(SUBARCH)
  else
  CHECKSTACK_ARCH := $(ARCH)
  endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1780
1781
  checkstack:
  	$(OBJDUMP) -d vmlinux $$(find . -name '*.ko') | \
75dd47472   Masahiro Yamada   kbuild: remove sr...
1782
  	$(PERL) $(srctree)/scripts/checkstack.pl $(CHECKSTACK_ARCH)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1783

7b8ea53d7   Amerigo Wang   makefile: not nee...
1784
1785
  kernelrelease:
  	@echo "$(KERNELVERSION)$$($(CONFIG_SHELL) $(srctree)/scripts/setlocalversion $(srctree))"
01ab17887   Amerigo Wang   Makefile: "make k...
1786

cb58455c4   Sam Ravnborg   kbuild: KERNELREL...
1787
  kernelversion:
2244cbd8a   Sam Ravnborg   kbuild: create .k...
1788
  	@echo $(KERNELVERSION)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1789

c398ff00f   Mike Marciniszyn   kbuild: fix error...
1790
1791
  image_name:
  	@echo $(KBUILD_IMAGE)
ea01fa9f6   Borislav Petkov   tools: Connect to...
1792
  # Clear a bunch of variables before executing the submake
f47a23ce2   Masahiro Yamada   kbuild: move tool...
1793
1794
1795
1796
  
  ifeq ($(quiet),silent_)
  tools_silent=s
  endif
ea01fa9f6   Borislav Petkov   tools: Connect to...
1797
  tools/: FORCE
bf35182ff   David Howells   tools: Honour the...
1798
  	$(Q)mkdir -p $(objtree)/tools
75dd47472   Masahiro Yamada   kbuild: remove sr...
1799
  	$(Q)$(MAKE) LDFLAGS= MAKEFLAGS="$(tools_silent) $(filter --j% -j,$(MAKEFLAGS))" O=$(abspath $(objtree)) subdir=tools -C $(srctree)/tools/
ea01fa9f6   Borislav Petkov   tools: Connect to...
1800
1801
  
  tools/%: FORCE
bf35182ff   David Howells   tools: Honour the...
1802
  	$(Q)mkdir -p $(objtree)/tools
75dd47472   Masahiro Yamada   kbuild: remove sr...
1803
  	$(Q)$(MAKE) LDFLAGS= MAKEFLAGS="$(tools_silent) $(filter --j% -j,$(MAKEFLAGS))" O=$(abspath $(objtree)) subdir=tools -C $(srctree)/tools/ $*
ea01fa9f6   Borislav Petkov   tools: Connect to...
1804

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1805
  quiet_cmd_rmfiles = $(if $(wildcard $(rm-files)),CLEAN   $(wildcard $(rm-files)))
0663c68c4   Masahiro Yamada   kbuild: remove {C...
1806
        cmd_rmfiles = rm -rf $(rm-files)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1807

bc3c26fe6   Uwe Kleine-König   fix typo "is" -> ...
1808
  # Run depmod only if we have System.map and depmod is executable
50a8ec31c   Sam Ravnborg   kbuild: disable d...
1809
  quiet_cmd_depmod = DEPMOD  $(KERNELRELEASE)
569658ddd   Michal Marek   kbuild: Call depm...
1810
        cmd_depmod = $(CONFIG_SHELL) $(srctree)/scripts/depmod.sh $(DEPMOD) \
5a144a1ac   Masahiro Yamada   depmod.sh: remove...
1811
                     $(KERNELRELEASE)
50a8ec31c   Sam Ravnborg   kbuild: disable d...
1812

392885ee8   Masahiro Yamada   kbuild: let fixde...
1813
1814
  # read saved command lines for existing targets
  existing-targets := $(wildcard $(sort $(targets)))
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1815

b999923c2   Masahiro Yamada   kbuild: remove em...
1816
  -include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1817

46b7c4925   SZ Lin (林上智)   kbuild: Fix incon...
1818
  endif # config-build
2042b5486   Masahiro Yamada   kbuild: unset var...
1819
1820
  endif # mixed-build
  endif # need-sub-make
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1821

4f1933620   Paul Smith   kbuild: change kb...
1822
  PHONY += FORCE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1823
  FORCE:
4f1933620   Paul Smith   kbuild: change kb...
1824

bd412d81b   Ulf Magnusson   kbuild: .PHONY is...
1825
  # Declare the contents of the PHONY variable as phony.  We keep that
fe8d0a410   Kirill Smelkov   kbuild: fix a few...
1826
  # information in a variable so we can use it in if_changed and friends.
4f1933620   Paul Smith   kbuild: change kb...
1827
  .PHONY: $(PHONY)