1 # SPDX-License-Identifier: GPL-2.0 1 # SPDX-License-Identifier: GPL-2.0 2 VERSION = 6 2 VERSION = 6 3 PATCHLEVEL = 11 !! 3 PATCHLEVEL = 7 4 SUBLEVEL = 5 !! 4 SUBLEVEL = 12 5 EXTRAVERSION = 5 EXTRAVERSION = 6 NAME = Baby Opossum Posse !! 6 NAME = Hurr durr I'ma ninja sloth 7 7 8 # *DOCUMENTATION* 8 # *DOCUMENTATION* 9 # To see a list of typical targets execute "ma 9 # To see a list of typical targets execute "make help" 10 # More info can be located in ./README 10 # More info can be located in ./README 11 # Comments in this file are targeted only to t 11 # Comments in this file are targeted only to the developer, do not 12 # expect to learn how to build the kernel read 12 # expect to learn how to build the kernel reading this file. 13 13 14 ifeq ($(filter output-sync,$(.FEATURES)),) !! 14 ifeq ($(filter undefine,$(.FEATURES)),) 15 $(error GNU Make >= 4.0 is required. Your Make !! 15 $(error GNU Make >= 3.82 is required. Your Make version is $(MAKE_VERSION)) 16 endif 16 endif 17 17 18 $(if $(filter __%, $(MAKECMDGOALS)), \ 18 $(if $(filter __%, $(MAKECMDGOALS)), \ 19 $(error targets prefixed with '__' are 19 $(error targets prefixed with '__' are only for internal use)) 20 20 21 # That's our default target when none is given 21 # That's our default target when none is given on the command line 22 PHONY := __all 22 PHONY := __all 23 __all: 23 __all: 24 24 25 # We are using a recursive build, so we need t 25 # We are using a recursive build, so we need to do a little thinking 26 # to get the ordering right. 26 # to get the ordering right. 27 # 27 # 28 # Most importantly: sub-Makefiles should only 28 # Most importantly: sub-Makefiles should only ever modify files in 29 # their own directory. If in some directory we 29 # their own directory. If in some directory we have a dependency on 30 # a file in another dir (which doesn't happen 30 # a file in another dir (which doesn't happen often, but it's often 31 # unavoidable when linking the built-in.a targ 31 # unavoidable when linking the built-in.a targets which finally 32 # turn into vmlinux), we will call a sub make 32 # turn into vmlinux), we will call a sub make in that other dir, and 33 # after that we are sure that everything which 33 # after that we are sure that everything which is in that other dir 34 # is now up to date. 34 # is now up to date. 35 # 35 # 36 # The only cases where we need to modify files 36 # The only cases where we need to modify files which have global 37 # effects are thus separated out and done befo 37 # effects are thus separated out and done before the recursive 38 # descending is started. They are now explicit 38 # descending is started. They are now explicitly listed as the 39 # prepare rule. 39 # prepare rule. 40 40 41 this-makefile := $(lastword $(MAKEFILE_LIST)) 41 this-makefile := $(lastword $(MAKEFILE_LIST)) 42 abs_srctree := $(realpath $(dir $(this-makefil !! 42 export abs_srctree := $(realpath $(dir $(this-makefile))) 43 abs_objtree := $(CURDIR) !! 43 export abs_objtree := $(CURDIR) 44 44 45 ifneq ($(sub_make_done),1) 45 ifneq ($(sub_make_done),1) 46 46 47 # Do not use make's built-in rules and variabl 47 # Do not use make's built-in rules and variables 48 # (this increases performance and avoids hard- 48 # (this increases performance and avoids hard-to-debug behaviour) 49 MAKEFLAGS += -rR 49 MAKEFLAGS += -rR 50 50 51 # Avoid funny character set dependencies 51 # Avoid funny character set dependencies 52 unexport LC_ALL 52 unexport LC_ALL 53 LC_COLLATE=C 53 LC_COLLATE=C 54 LC_NUMERIC=C 54 LC_NUMERIC=C 55 export LC_COLLATE LC_NUMERIC 55 export LC_COLLATE LC_NUMERIC 56 56 57 # Avoid interference with shell env settings 57 # Avoid interference with shell env settings 58 unexport GREP_OPTIONS 58 unexport GREP_OPTIONS 59 59 60 # Beautify output 60 # Beautify output 61 # -------------------------------------------- 61 # --------------------------------------------------------------------------- 62 # 62 # 63 # Most of build commands in Kbuild start with 63 # Most of build commands in Kbuild start with "cmd_". You can optionally define 64 # "quiet_cmd_*". If defined, the short log is 64 # "quiet_cmd_*". If defined, the short log is printed. Otherwise, no log from 65 # that command is printed by default. 65 # that command is printed by default. 66 # 66 # 67 # e.g.) 67 # e.g.) 68 # quiet_cmd_depmod = DEPMOD $(MODLIB) 68 # quiet_cmd_depmod = DEPMOD $(MODLIB) 69 # cmd_depmod = $(srctree)/scripts/dep 69 # cmd_depmod = $(srctree)/scripts/depmod.sh $(DEPMOD) $(KERNELRELEASE) 70 # 70 # 71 # A simple variant is to prefix commands with 71 # A simple variant is to prefix commands with $(Q) - that's useful 72 # for commands that shall be hidden in non-ver 72 # for commands that shall be hidden in non-verbose mode. 73 # 73 # 74 # $(Q)$(MAKE) $(build)=scripts/basic 74 # $(Q)$(MAKE) $(build)=scripts/basic 75 # 75 # 76 # If KBUILD_VERBOSE contains 1, the whole comm 76 # If KBUILD_VERBOSE contains 1, the whole command is echoed. 77 # If KBUILD_VERBOSE contains 2, the reason for 77 # If KBUILD_VERBOSE contains 2, the reason for rebuilding is printed. 78 # 78 # 79 # To put more focus on warnings, be less verbo 79 # To put more focus on warnings, be less verbose as default 80 # Use 'make V=1' to see the full commands 80 # Use 'make V=1' to see the full commands 81 81 82 ifeq ("$(origin V)", "command line") 82 ifeq ("$(origin V)", "command line") 83 KBUILD_VERBOSE = $(V) 83 KBUILD_VERBOSE = $(V) 84 endif 84 endif 85 85 86 quiet = quiet_ 86 quiet = quiet_ 87 Q = @ 87 Q = @ 88 88 89 ifneq ($(findstring 1, $(KBUILD_VERBOSE)),) 89 ifneq ($(findstring 1, $(KBUILD_VERBOSE)),) 90 quiet = 90 quiet = 91 Q = 91 Q = 92 endif 92 endif 93 93 94 # If the user is running make -s (silent mode) 94 # If the user is running make -s (silent mode), suppress echoing of 95 # commands 95 # commands 96 ifneq ($(findstring s,$(firstword -$(MAKEFLAGS !! 96 # make-4.0 (and later) keep single letter options in the 1st word of MAKEFLAGS. >> 97 >> 98 ifeq ($(filter 3.%,$(MAKE_VERSION)),) >> 99 short-opts := $(firstword -$(MAKEFLAGS)) >> 100 else >> 101 short-opts := $(filter-out --%,$(MAKEFLAGS)) >> 102 endif >> 103 >> 104 ifneq ($(findstring s,$(short-opts)),) 97 quiet=silent_ 105 quiet=silent_ 98 override KBUILD_VERBOSE := 106 override KBUILD_VERBOSE := 99 endif 107 endif 100 108 101 export quiet Q KBUILD_VERBOSE 109 export quiet Q KBUILD_VERBOSE 102 110 103 # Call a source code checker (by default, "spa 111 # Call a source code checker (by default, "sparse") as part of the 104 # C compilation. 112 # C compilation. 105 # 113 # 106 # Use 'make C=1' to enable checking of only re 114 # Use 'make C=1' to enable checking of only re-compiled files. 107 # Use 'make C=2' to enable checking of *all* s 115 # Use 'make C=2' to enable checking of *all* source files, regardless 108 # of whether they are re-compiled or not. 116 # of whether they are re-compiled or not. 109 # 117 # 110 # See the file "Documentation/dev-tools/sparse 118 # See the file "Documentation/dev-tools/sparse.rst" for more details, 111 # including where to get the "sparse" utility. 119 # including where to get the "sparse" utility. 112 120 113 ifeq ("$(origin C)", "command line") 121 ifeq ("$(origin C)", "command line") 114 KBUILD_CHECKSRC = $(C) 122 KBUILD_CHECKSRC = $(C) 115 endif 123 endif 116 ifndef KBUILD_CHECKSRC 124 ifndef KBUILD_CHECKSRC 117 KBUILD_CHECKSRC = 0 125 KBUILD_CHECKSRC = 0 118 endif 126 endif 119 127 120 export KBUILD_CHECKSRC 128 export KBUILD_CHECKSRC 121 129 122 # Enable "clippy" (a linter) as part of the Ru 130 # Enable "clippy" (a linter) as part of the Rust compilation. 123 # 131 # 124 # Use 'make CLIPPY=1' to enable it. 132 # Use 'make CLIPPY=1' to enable it. 125 ifeq ("$(origin CLIPPY)", "command line") 133 ifeq ("$(origin CLIPPY)", "command line") 126 KBUILD_CLIPPY := $(CLIPPY) 134 KBUILD_CLIPPY := $(CLIPPY) 127 endif 135 endif 128 136 129 export KBUILD_CLIPPY 137 export KBUILD_CLIPPY 130 138 131 # Use make M=dir or set the environment variab 139 # Use make M=dir or set the environment variable KBUILD_EXTMOD to specify the 132 # directory of external module to build. Setti 140 # directory of external module to build. Setting M= takes precedence. 133 ifeq ("$(origin M)", "command line") 141 ifeq ("$(origin M)", "command line") 134 KBUILD_EXTMOD := $(M) 142 KBUILD_EXTMOD := $(M) 135 endif 143 endif 136 144 137 $(if $(word 2, $(KBUILD_EXTMOD)), \ 145 $(if $(word 2, $(KBUILD_EXTMOD)), \ 138 $(error building multiple external mod 146 $(error building multiple external modules is not supported)) 139 147 140 $(foreach x, % :, $(if $(findstring $x, $(KBUI 148 $(foreach x, % :, $(if $(findstring $x, $(KBUILD_EXTMOD)), \ 141 $(error module directory path cannot c 149 $(error module directory path cannot contain '$x'))) 142 150 143 # Remove trailing slashes 151 # Remove trailing slashes 144 ifneq ($(filter %/, $(KBUILD_EXTMOD)),) 152 ifneq ($(filter %/, $(KBUILD_EXTMOD)),) 145 KBUILD_EXTMOD := $(shell dirname $(KBUILD_EXTM 153 KBUILD_EXTMOD := $(shell dirname $(KBUILD_EXTMOD).) 146 endif 154 endif 147 155 148 export KBUILD_EXTMOD 156 export KBUILD_EXTMOD 149 157 150 # backward compatibility << 151 KBUILD_EXTRA_WARN ?= $(KBUILD_ENABLE_EXTRA_GCC << 152 << 153 ifeq ("$(origin W)", "command line") << 154 KBUILD_EXTRA_WARN := $(W) << 155 endif << 156 << 157 export KBUILD_EXTRA_WARN << 158 << 159 # Kbuild will save output files in the current 158 # Kbuild will save output files in the current working directory. 160 # This does not need to match to the root of t 159 # This does not need to match to the root of the kernel source tree. 161 # 160 # 162 # For example, you can do this: 161 # For example, you can do this: 163 # 162 # 164 # cd /dir/to/store/output/files; make -f /dir 163 # cd /dir/to/store/output/files; make -f /dir/to/kernel/source/Makefile 165 # 164 # 166 # If you want to save output files in a differ 165 # If you want to save output files in a different location, there are 167 # two syntaxes to specify it. 166 # two syntaxes to specify it. 168 # 167 # 169 # 1) O= 168 # 1) O= 170 # Use "make O=dir/to/store/output/files/" 169 # Use "make O=dir/to/store/output/files/" 171 # 170 # 172 # 2) Set KBUILD_OUTPUT 171 # 2) Set KBUILD_OUTPUT 173 # Set the environment variable KBUILD_OUTPUT t 172 # Set the environment variable KBUILD_OUTPUT to point to the output directory. 174 # export KBUILD_OUTPUT=dir/to/store/output/fil 173 # export KBUILD_OUTPUT=dir/to/store/output/files/; make 175 # 174 # 176 # The O= assignment takes precedence over the 175 # The O= assignment takes precedence over the KBUILD_OUTPUT environment 177 # variable. 176 # variable. 178 177 179 # Do we want to change the working directory? 178 # Do we want to change the working directory? 180 ifeq ("$(origin O)", "command line") 179 ifeq ("$(origin O)", "command line") 181 KBUILD_OUTPUT := $(O) 180 KBUILD_OUTPUT := $(O) 182 endif 181 endif 183 182 184 ifneq ($(KBUILD_OUTPUT),) 183 ifneq ($(KBUILD_OUTPUT),) 185 # $(realpath ...) gets empty if the path does !! 184 # Make's built-in functions such as $(abspath ...), $(realpath ...) cannot 186 $(shell mkdir -p "$(KBUILD_OUTPUT)") !! 185 # expand a shell special character '~'. We use a somewhat tedious way here. >> 186 abs_objtree := $(shell mkdir -p $(KBUILD_OUTPUT) && cd $(KBUILD_OUTPUT) && pwd) >> 187 $(if $(abs_objtree),, \ >> 188 $(error failed to create output directory "$(KBUILD_OUTPUT)")) >> 189 187 # $(realpath ...) resolves symlinks 190 # $(realpath ...) resolves symlinks 188 abs_objtree := $(realpath $(KBUILD_OUTPUT)) !! 191 abs_objtree := $(realpath $(abs_objtree)) 189 $(if $(abs_objtree),,$(error failed to create << 190 endif # ifneq ($(KBUILD_OUTPUT),) 192 endif # ifneq ($(KBUILD_OUTPUT),) 191 193 192 ifneq ($(words $(subst :, ,$(abs_srctree))), 1 194 ifneq ($(words $(subst :, ,$(abs_srctree))), 1) 193 $(error source directory cannot contain spaces 195 $(error source directory cannot contain spaces or colons) 194 endif 196 endif 195 197 >> 198 ifneq ($(filter 3.%,$(MAKE_VERSION)),) >> 199 # 'MAKEFLAGS += -rR' does not immediately become effective for GNU Make 3.x >> 200 # We need to invoke sub-make to avoid implicit rules in the top Makefile. >> 201 need-sub-make := 1 >> 202 # Cancel implicit rules for this Makefile. >> 203 $(this-makefile): ; >> 204 endif >> 205 196 export sub_make_done := 1 206 export sub_make_done := 1 197 207 198 endif # sub_make_done 208 endif # sub_make_done 199 209 200 ifeq ($(abs_objtree),$(CURDIR)) 210 ifeq ($(abs_objtree),$(CURDIR)) 201 # Suppress "Entering directory ..." if we are 211 # Suppress "Entering directory ..." if we are at the final work directory. 202 no-print-directory := --no-print-directory 212 no-print-directory := --no-print-directory 203 else 213 else 204 # Recursion to show "Entering directory ..." 214 # Recursion to show "Entering directory ..." 205 need-sub-make := 1 215 need-sub-make := 1 206 endif 216 endif 207 217 208 ifeq ($(filter --no-print-directory, $(MAKEFLA 218 ifeq ($(filter --no-print-directory, $(MAKEFLAGS)),) 209 # If --no-print-directory is unset, recurse on 219 # If --no-print-directory is unset, recurse once again to set it. 210 # You may end up recursing into __sub-make twi 220 # You may end up recursing into __sub-make twice. This is needed due to the 211 # behavior change in GNU Make 4.4.1. 221 # behavior change in GNU Make 4.4.1. 212 need-sub-make := 1 222 need-sub-make := 1 213 endif 223 endif 214 224 215 ifeq ($(need-sub-make),1) 225 ifeq ($(need-sub-make),1) 216 226 217 PHONY += $(MAKECMDGOALS) __sub-make 227 PHONY += $(MAKECMDGOALS) __sub-make 218 228 219 $(filter-out $(this-makefile), $(MAKECMDGOALS) 229 $(filter-out $(this-makefile), $(MAKECMDGOALS)) __all: __sub-make 220 @: 230 @: 221 231 222 # Invoke a second make in the output directory 232 # Invoke a second make in the output directory, passing relevant variables 223 __sub-make: 233 __sub-make: 224 $(Q)$(MAKE) $(no-print-directory) -C $ 234 $(Q)$(MAKE) $(no-print-directory) -C $(abs_objtree) \ 225 -f $(abs_srctree)/Makefile $(MAKECMDGO 235 -f $(abs_srctree)/Makefile $(MAKECMDGOALS) 226 236 227 else # need-sub-make 237 else # need-sub-make 228 238 229 # We process the rest of the Makefile if this 239 # We process the rest of the Makefile if this is the final invocation of make 230 240 231 ifeq ($(abs_srctree),$(abs_objtree)) 241 ifeq ($(abs_srctree),$(abs_objtree)) 232 # building in the source tree 242 # building in the source tree 233 srctree := . 243 srctree := . 234 building_out_of_srctree := 244 building_out_of_srctree := 235 else 245 else 236 ifeq ($(abs_srctree)/,$(dir $(abs_objt 246 ifeq ($(abs_srctree)/,$(dir $(abs_objtree))) 237 # building in a subdirectory o 247 # building in a subdirectory of the source tree 238 srctree := .. 248 srctree := .. 239 else 249 else 240 srctree := $(abs_srctree) 250 srctree := $(abs_srctree) 241 endif 251 endif 242 building_out_of_srctree := 1 252 building_out_of_srctree := 1 243 endif 253 endif 244 254 245 ifneq ($(KBUILD_ABS_SRCTREE),) 255 ifneq ($(KBUILD_ABS_SRCTREE),) 246 srctree := $(abs_srctree) 256 srctree := $(abs_srctree) 247 endif 257 endif 248 258 249 objtree := . 259 objtree := . 250 << 251 VPATH := << 252 << 253 ifeq ($(KBUILD_EXTMOD),) << 254 ifdef building_out_of_srctree << 255 VPATH := $(srctree) 260 VPATH := $(srctree) 256 endif << 257 endif << 258 261 259 export building_out_of_srctree srctree objtree 262 export building_out_of_srctree srctree objtree VPATH 260 263 261 # To make sure we do not include .config for a 264 # To make sure we do not include .config for any of the *config targets 262 # catch them early, and hand them over to scri 265 # catch them early, and hand them over to scripts/kconfig/Makefile 263 # It is allowed to specify more targets when c 266 # It is allowed to specify more targets when calling make, including 264 # mixing *config targets and build targets. 267 # mixing *config targets and build targets. 265 # For example 'make oldconfig all'. 268 # For example 'make oldconfig all'. 266 # Detect when mixed targets is specified, and 269 # Detect when mixed targets is specified, and make a second invocation 267 # of make so .config is not included in this c 270 # of make so .config is not included in this case either (for *config). 268 271 269 version_h := include/generated/uapi/linux/vers 272 version_h := include/generated/uapi/linux/version.h 270 273 271 clean-targets := %clean mrproper cleandocs 274 clean-targets := %clean mrproper cleandocs 272 no-dot-config-targets := $(clean-targets) \ 275 no-dot-config-targets := $(clean-targets) \ 273 cscope gtags TAGS tag 276 cscope gtags TAGS tags help% %docs check% coccicheck \ 274 $(version_h) headers 277 $(version_h) headers headers_% archheaders archscripts \ 275 %asm-generic kernelve 278 %asm-generic kernelversion %src-pkg dt_binding_check \ 276 outputmakefile rustav 279 outputmakefile rustavailable rustfmt rustfmtcheck 277 no-sync-config-targets := $(no-dot-config-targ 280 no-sync-config-targets := $(no-dot-config-targets) %install modules_sign kernelrelease \ 278 image_name 281 image_name 279 single-targets := %.a %.i %.ko %.lds %.ll %.ls 282 single-targets := %.a %.i %.ko %.lds %.ll %.lst %.mod %.o %.rsi %.s %.symtypes %/ 280 283 281 config-build := 284 config-build := 282 mixed-build := 285 mixed-build := 283 need-config := 1 286 need-config := 1 284 may-sync-config := 1 287 may-sync-config := 1 285 single-build := 288 single-build := 286 289 287 ifneq ($(filter $(no-dot-config-targets), $(MA 290 ifneq ($(filter $(no-dot-config-targets), $(MAKECMDGOALS)),) 288 ifeq ($(filter-out $(no-dot-config-targets !! 291 ifeq ($(filter-out $(no-dot-config-targets), $(MAKECMDGOALS)),) 289 need-config := !! 292 need-config := 290 endif !! 293 endif 291 endif 294 endif 292 295 293 ifneq ($(filter $(no-sync-config-targets), $(M 296 ifneq ($(filter $(no-sync-config-targets), $(MAKECMDGOALS)),) 294 ifeq ($(filter-out $(no-sync-config-target !! 297 ifeq ($(filter-out $(no-sync-config-targets), $(MAKECMDGOALS)),) 295 may-sync-config := !! 298 may-sync-config := 296 endif !! 299 endif 297 endif 300 endif 298 301 299 need-compiler := $(may-sync-config) 302 need-compiler := $(may-sync-config) 300 303 301 ifneq ($(KBUILD_EXTMOD),) 304 ifneq ($(KBUILD_EXTMOD),) 302 may-sync-config := !! 305 may-sync-config := 303 endif 306 endif 304 307 305 ifeq ($(KBUILD_EXTMOD),) 308 ifeq ($(KBUILD_EXTMOD),) 306 ifneq ($(filter %config,$(MAKECMDGOALS)),) !! 309 ifneq ($(filter %config,$(MAKECMDGOALS)),) 307 config-build := 1 !! 310 config-build := 1 308 ifneq ($(words $(MAKECMDGOALS)),1) !! 311 ifneq ($(words $(MAKECMDGOALS)),1) 309 mixed-build := 1 !! 312 mixed-build := 1 >> 313 endif 310 endif 314 endif 311 endif << 312 endif 315 endif 313 316 314 # We cannot build single targets and the other 317 # We cannot build single targets and the others at the same time 315 ifneq ($(filter $(single-targets), $(MAKECMDGO 318 ifneq ($(filter $(single-targets), $(MAKECMDGOALS)),) 316 single-build := 1 !! 319 single-build := 1 317 ifneq ($(filter-out $(single-targets), $(M !! 320 ifneq ($(filter-out $(single-targets), $(MAKECMDGOALS)),) 318 mixed-build := 1 !! 321 mixed-build := 1 319 endif !! 322 endif 320 endif 323 endif 321 324 322 # For "make -j clean all", "make -j mrproper d 325 # For "make -j clean all", "make -j mrproper defconfig all", etc. 323 ifneq ($(filter $(clean-targets),$(MAKECMDGOAL 326 ifneq ($(filter $(clean-targets),$(MAKECMDGOALS)),) 324 ifneq ($(filter-out $(clean-targets),$(MAK !! 327 ifneq ($(filter-out $(clean-targets),$(MAKECMDGOALS)),) 325 mixed-build := 1 !! 328 mixed-build := 1 326 endif !! 329 endif 327 endif 330 endif 328 331 329 # install and modules_install need also be pro 332 # install and modules_install need also be processed one by one 330 ifneq ($(filter install,$(MAKECMDGOALS)),) 333 ifneq ($(filter install,$(MAKECMDGOALS)),) 331 ifneq ($(filter modules_install,$(MAKECMDG !! 334 ifneq ($(filter modules_install,$(MAKECMDGOALS)),) 332 mixed-build := 1 !! 335 mixed-build := 1 333 endif !! 336 endif 334 endif 337 endif 335 338 336 ifdef mixed-build 339 ifdef mixed-build 337 # ============================================ 340 # =========================================================================== 338 # We're called with mixed targets (*config and 341 # We're called with mixed targets (*config and build targets). 339 # Handle them one by one. 342 # Handle them one by one. 340 343 341 PHONY += $(MAKECMDGOALS) __build_one_by_one 344 PHONY += $(MAKECMDGOALS) __build_one_by_one 342 345 343 $(MAKECMDGOALS): __build_one_by_one 346 $(MAKECMDGOALS): __build_one_by_one 344 @: 347 @: 345 348 346 __build_one_by_one: 349 __build_one_by_one: 347 $(Q)set -e; \ 350 $(Q)set -e; \ 348 for i in $(MAKECMDGOALS); do \ 351 for i in $(MAKECMDGOALS); do \ 349 $(MAKE) -f $(srctree)/Makefile 352 $(MAKE) -f $(srctree)/Makefile $$i; \ 350 done 353 done 351 354 352 else # !mixed-build 355 else # !mixed-build 353 356 354 include $(srctree)/scripts/Kbuild.include 357 include $(srctree)/scripts/Kbuild.include 355 358 356 # Read KERNELRELEASE from include/config/kerne 359 # Read KERNELRELEASE from include/config/kernel.release (if it exists) 357 KERNELRELEASE = $(call read-file, include/conf 360 KERNELRELEASE = $(call read-file, include/config/kernel.release) 358 KERNELVERSION = $(VERSION)$(if $(PATCHLEVEL),. 361 KERNELVERSION = $(VERSION)$(if $(PATCHLEVEL),.$(PATCHLEVEL)$(if $(SUBLEVEL),.$(SUBLEVEL)))$(EXTRAVERSION) 359 export VERSION PATCHLEVEL SUBLEVEL KERNELRELEA 362 export VERSION PATCHLEVEL SUBLEVEL KERNELRELEASE KERNELVERSION 360 363 361 include $(srctree)/scripts/subarch.include 364 include $(srctree)/scripts/subarch.include 362 365 363 # Cross compiling and selecting different set 366 # Cross compiling and selecting different set of gcc/bin-utils 364 # -------------------------------------------- 367 # --------------------------------------------------------------------------- 365 # 368 # 366 # When performing cross compilation for other 369 # When performing cross compilation for other architectures ARCH shall be set 367 # to the target architecture. (See arch/* for 370 # to the target architecture. (See arch/* for the possibilities). 368 # ARCH can be set during invocation of make: 371 # ARCH can be set during invocation of make: 369 # make ARCH=arm64 372 # make ARCH=arm64 370 # Another way is to have ARCH set in the envir 373 # Another way is to have ARCH set in the environment. 371 # The default ARCH is the host where make is e 374 # The default ARCH is the host where make is executed. 372 375 373 # CROSS_COMPILE specify the prefix used for al 376 # CROSS_COMPILE specify the prefix used for all executables used 374 # during compilation. Only gcc and related bin 377 # during compilation. Only gcc and related bin-utils executables 375 # are prefixed with $(CROSS_COMPILE). 378 # are prefixed with $(CROSS_COMPILE). 376 # CROSS_COMPILE can be set on the command line 379 # CROSS_COMPILE can be set on the command line 377 # make CROSS_COMPILE=aarch64-linux-gnu- 380 # make CROSS_COMPILE=aarch64-linux-gnu- 378 # Alternatively CROSS_COMPILE can be set in th 381 # Alternatively CROSS_COMPILE can be set in the environment. 379 # Default value for CROSS_COMPILE is not to pr 382 # Default value for CROSS_COMPILE is not to prefix executables 380 # Note: Some architectures assign CROSS_COMPIL 383 # Note: Some architectures assign CROSS_COMPILE in their arch/*/Makefile 381 ARCH ?= $(SUBARCH) 384 ARCH ?= $(SUBARCH) 382 385 383 # Architecture as present in compile.h 386 # Architecture as present in compile.h 384 UTS_MACHINE := $(ARCH) 387 UTS_MACHINE := $(ARCH) 385 SRCARCH := $(ARCH) 388 SRCARCH := $(ARCH) 386 389 387 # Additional ARCH settings for x86 390 # Additional ARCH settings for x86 388 ifeq ($(ARCH),i386) 391 ifeq ($(ARCH),i386) 389 SRCARCH := x86 392 SRCARCH := x86 390 endif 393 endif 391 ifeq ($(ARCH),x86_64) 394 ifeq ($(ARCH),x86_64) 392 SRCARCH := x86 395 SRCARCH := x86 393 endif 396 endif 394 397 395 # Additional ARCH settings for sparc 398 # Additional ARCH settings for sparc 396 ifeq ($(ARCH),sparc32) 399 ifeq ($(ARCH),sparc32) 397 SRCARCH := sparc 400 SRCARCH := sparc 398 endif 401 endif 399 ifeq ($(ARCH),sparc64) 402 ifeq ($(ARCH),sparc64) 400 SRCARCH := sparc 403 SRCARCH := sparc 401 endif 404 endif 402 405 403 # Additional ARCH settings for parisc 406 # Additional ARCH settings for parisc 404 ifeq ($(ARCH),parisc64) 407 ifeq ($(ARCH),parisc64) 405 SRCARCH := parisc 408 SRCARCH := parisc 406 endif 409 endif 407 410 408 export cross_compiling := 411 export cross_compiling := 409 ifneq ($(SRCARCH),$(SUBARCH)) 412 ifneq ($(SRCARCH),$(SUBARCH)) 410 cross_compiling := 1 413 cross_compiling := 1 411 endif 414 endif 412 415 413 KCONFIG_CONFIG ?= .config 416 KCONFIG_CONFIG ?= .config 414 export KCONFIG_CONFIG 417 export KCONFIG_CONFIG 415 418 416 # SHELL used by kbuild 419 # SHELL used by kbuild 417 CONFIG_SHELL := sh 420 CONFIG_SHELL := sh 418 421 419 HOST_LFS_CFLAGS := $(shell getconf LFS_CFLAGS 422 HOST_LFS_CFLAGS := $(shell getconf LFS_CFLAGS 2>/dev/null) 420 HOST_LFS_LDFLAGS := $(shell getconf LFS_LDFLAG 423 HOST_LFS_LDFLAGS := $(shell getconf LFS_LDFLAGS 2>/dev/null) 421 HOST_LFS_LIBS := $(shell getconf LFS_LIBS 2>/d 424 HOST_LFS_LIBS := $(shell getconf LFS_LIBS 2>/dev/null) 422 425 423 ifneq ($(LLVM),) 426 ifneq ($(LLVM),) 424 ifneq ($(filter %/,$(LLVM)),) 427 ifneq ($(filter %/,$(LLVM)),) 425 LLVM_PREFIX := $(LLVM) 428 LLVM_PREFIX := $(LLVM) 426 else ifneq ($(filter -%,$(LLVM)),) 429 else ifneq ($(filter -%,$(LLVM)),) 427 LLVM_SUFFIX := $(LLVM) 430 LLVM_SUFFIX := $(LLVM) 428 endif 431 endif 429 432 430 HOSTCC = $(LLVM_PREFIX)clang$(LLVM_SUFFIX) 433 HOSTCC = $(LLVM_PREFIX)clang$(LLVM_SUFFIX) 431 HOSTCXX = $(LLVM_PREFIX)clang++$(LLVM_SUFFIX) 434 HOSTCXX = $(LLVM_PREFIX)clang++$(LLVM_SUFFIX) 432 else 435 else 433 HOSTCC = gcc 436 HOSTCC = gcc 434 HOSTCXX = g++ 437 HOSTCXX = g++ 435 endif 438 endif 436 HOSTRUSTC = rustc 439 HOSTRUSTC = rustc 437 HOSTPKG_CONFIG = pkg-config 440 HOSTPKG_CONFIG = pkg-config 438 441 439 KBUILD_USERHOSTCFLAGS := -Wall -Wmissing-proto 442 KBUILD_USERHOSTCFLAGS := -Wall -Wmissing-prototypes -Wstrict-prototypes \ 440 -O2 -fomit-frame-poin 443 -O2 -fomit-frame-pointer -std=gnu11 441 KBUILD_USERCFLAGS := $(KBUILD_USERHOSTCFLAGS) 444 KBUILD_USERCFLAGS := $(KBUILD_USERHOSTCFLAGS) $(USERCFLAGS) 442 KBUILD_USERLDFLAGS := $(USERLDFLAGS) 445 KBUILD_USERLDFLAGS := $(USERLDFLAGS) 443 446 444 # These flags apply to all Rust code in the tr 447 # These flags apply to all Rust code in the tree, including the kernel and 445 # host programs. 448 # host programs. 446 export rust_common_flags := --edition=2021 \ 449 export rust_common_flags := --edition=2021 \ 447 -Zbinary_dep_depin 450 -Zbinary_dep_depinfo=y \ 448 -Astable_features !! 451 -Dunsafe_op_in_unsafe_fn -Drust_2018_idioms \ 449 -Dunsafe_op_in_uns !! 452 -Dunreachable_pub -Dnon_ascii_idents \ 450 -Dnon_ascii_idents << 451 -Wrust_2018_idioms << 452 -Wunreachable_pub << 453 -Wmissing_docs \ 453 -Wmissing_docs \ 454 -Wrustdoc::missing !! 454 -Drustdoc::missing_crate_level_docs \ 455 -Wclippy::all \ !! 455 -Dclippy::correctness -Dclippy::style \ 456 -Wclippy::mut_mut !! 456 -Dclippy::suspicious -Dclippy::complexity \ 457 -Wclippy::needless !! 457 -Dclippy::perf \ 458 -Wclippy::needless !! 458 -Dclippy::let_unit_value -Dclippy::mut_mut \ 459 -Wclippy::no_mangl !! 459 -Dclippy::needless_bitwise_bool \ >> 460 -Dclippy::needless_continue \ >> 461 -Dclippy::no_mangle_with_rust_abi \ 460 -Wclippy::dbg_macr 462 -Wclippy::dbg_macro 461 463 462 KBUILD_HOSTCFLAGS := $(KBUILD_USERHOSTCFLAGS !! 464 KBUILD_HOSTCFLAGS := $(KBUILD_USERHOSTCFLAGS) $(HOST_LFS_CFLAGS) $(HOSTCFLAGS) 463 $(HOSTCFLAGS) -I $(srct !! 465 KBUILD_HOSTCXXFLAGS := -Wall -O2 $(HOST_LFS_CFLAGS) $(HOSTCXXFLAGS) 464 KBUILD_HOSTCXXFLAGS := -Wall -O2 $(HOST_LFS_CF << 465 -I $(srctree)/scripts/i << 466 KBUILD_HOSTRUSTFLAGS := $(rust_common_flags) - 466 KBUILD_HOSTRUSTFLAGS := $(rust_common_flags) -O -Cstrip=debuginfo \ 467 -Zallow-features= $(HO 467 -Zallow-features= $(HOSTRUSTFLAGS) 468 KBUILD_HOSTLDFLAGS := $(HOST_LFS_LDFLAGS) $(H 468 KBUILD_HOSTLDFLAGS := $(HOST_LFS_LDFLAGS) $(HOSTLDFLAGS) 469 KBUILD_HOSTLDLIBS := $(HOST_LFS_LIBS) $(HOST 469 KBUILD_HOSTLDLIBS := $(HOST_LFS_LIBS) $(HOSTLDLIBS) 470 470 471 # Make variables (CC, etc...) 471 # Make variables (CC, etc...) 472 CPP = $(CC) -E 472 CPP = $(CC) -E 473 ifneq ($(LLVM),) 473 ifneq ($(LLVM),) 474 CC = $(LLVM_PREFIX)clang$(LLVM_SU 474 CC = $(LLVM_PREFIX)clang$(LLVM_SUFFIX) 475 LD = $(LLVM_PREFIX)ld.lld$(LLVM_S 475 LD = $(LLVM_PREFIX)ld.lld$(LLVM_SUFFIX) 476 AR = $(LLVM_PREFIX)llvm-ar$(LLVM_ 476 AR = $(LLVM_PREFIX)llvm-ar$(LLVM_SUFFIX) 477 NM = $(LLVM_PREFIX)llvm-nm$(LLVM_ 477 NM = $(LLVM_PREFIX)llvm-nm$(LLVM_SUFFIX) 478 OBJCOPY = $(LLVM_PREFIX)llvm-objcopy$( 478 OBJCOPY = $(LLVM_PREFIX)llvm-objcopy$(LLVM_SUFFIX) 479 OBJDUMP = $(LLVM_PREFIX)llvm-objdump$( 479 OBJDUMP = $(LLVM_PREFIX)llvm-objdump$(LLVM_SUFFIX) 480 READELF = $(LLVM_PREFIX)llvm-readelf$( 480 READELF = $(LLVM_PREFIX)llvm-readelf$(LLVM_SUFFIX) 481 STRIP = $(LLVM_PREFIX)llvm-strip$(LL 481 STRIP = $(LLVM_PREFIX)llvm-strip$(LLVM_SUFFIX) 482 else 482 else 483 CC = $(CROSS_COMPILE)gcc 483 CC = $(CROSS_COMPILE)gcc 484 LD = $(CROSS_COMPILE)ld 484 LD = $(CROSS_COMPILE)ld 485 AR = $(CROSS_COMPILE)ar 485 AR = $(CROSS_COMPILE)ar 486 NM = $(CROSS_COMPILE)nm 486 NM = $(CROSS_COMPILE)nm 487 OBJCOPY = $(CROSS_COMPILE)objcopy 487 OBJCOPY = $(CROSS_COMPILE)objcopy 488 OBJDUMP = $(CROSS_COMPILE)objdump 488 OBJDUMP = $(CROSS_COMPILE)objdump 489 READELF = $(CROSS_COMPILE)readelf 489 READELF = $(CROSS_COMPILE)readelf 490 STRIP = $(CROSS_COMPILE)strip 490 STRIP = $(CROSS_COMPILE)strip 491 endif 491 endif 492 RUSTC = rustc 492 RUSTC = rustc 493 RUSTDOC = rustdoc 493 RUSTDOC = rustdoc 494 RUSTFMT = rustfmt 494 RUSTFMT = rustfmt 495 CLIPPY_DRIVER = clippy-driver 495 CLIPPY_DRIVER = clippy-driver 496 BINDGEN = bindgen 496 BINDGEN = bindgen >> 497 CARGO = cargo 497 PAHOLE = pahole 498 PAHOLE = pahole 498 RESOLVE_BTFIDS = $(objtree)/tools/bpf/resolve 499 RESOLVE_BTFIDS = $(objtree)/tools/bpf/resolve_btfids/resolve_btfids 499 LEX = flex 500 LEX = flex 500 YACC = bison 501 YACC = bison 501 AWK = awk 502 AWK = awk 502 INSTALLKERNEL := installkernel 503 INSTALLKERNEL := installkernel 503 PERL = perl 504 PERL = perl 504 PYTHON3 = python3 505 PYTHON3 = python3 505 CHECK = sparse 506 CHECK = sparse 506 BASH = bash 507 BASH = bash 507 KGZIP = gzip 508 KGZIP = gzip 508 KBZIP2 = bzip2 509 KBZIP2 = bzip2 509 KLZOP = lzop 510 KLZOP = lzop 510 LZMA = lzma 511 LZMA = lzma 511 LZ4 = lz4c 512 LZ4 = lz4c 512 XZ = xz 513 XZ = xz 513 ZSTD = zstd 514 ZSTD = zstd 514 515 515 CHECKFLAGS := -D__linux__ -Dlinux -D__STDC 516 CHECKFLAGS := -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ \ 516 -Wbitwise -Wno-return-void - 517 -Wbitwise -Wno-return-void -Wno-unknown-attribute $(CF) 517 NOSTDINC_FLAGS := 518 NOSTDINC_FLAGS := 518 CFLAGS_MODULE = 519 CFLAGS_MODULE = 519 RUSTFLAGS_MODULE = 520 RUSTFLAGS_MODULE = 520 AFLAGS_MODULE = 521 AFLAGS_MODULE = 521 LDFLAGS_MODULE = 522 LDFLAGS_MODULE = 522 CFLAGS_KERNEL = 523 CFLAGS_KERNEL = 523 RUSTFLAGS_KERNEL = 524 RUSTFLAGS_KERNEL = 524 AFLAGS_KERNEL = 525 AFLAGS_KERNEL = 525 LDFLAGS_vmlinux = 526 LDFLAGS_vmlinux = 526 527 527 # Use USERINCLUDE when you must reference the 528 # Use USERINCLUDE when you must reference the UAPI directories only. 528 USERINCLUDE := \ 529 USERINCLUDE := \ 529 -I$(srctree)/arch/$(SRCARCH)/i 530 -I$(srctree)/arch/$(SRCARCH)/include/uapi \ 530 -I$(objtree)/arch/$(SRCARCH)/i 531 -I$(objtree)/arch/$(SRCARCH)/include/generated/uapi \ 531 -I$(srctree)/include/uapi \ 532 -I$(srctree)/include/uapi \ 532 -I$(objtree)/include/generated 533 -I$(objtree)/include/generated/uapi \ 533 -include $(srctree)/include/li 534 -include $(srctree)/include/linux/compiler-version.h \ 534 -include $(srctree)/include/li 535 -include $(srctree)/include/linux/kconfig.h 535 536 536 # Use LINUXINCLUDE when you must reference the 537 # Use LINUXINCLUDE when you must reference the include/ directory. 537 # Needed to be compatible with the O= option 538 # Needed to be compatible with the O= option 538 LINUXINCLUDE := \ 539 LINUXINCLUDE := \ 539 -I$(srctree)/arch/$(SRCARCH)/i 540 -I$(srctree)/arch/$(SRCARCH)/include \ 540 -I$(objtree)/arch/$(SRCARCH)/i 541 -I$(objtree)/arch/$(SRCARCH)/include/generated \ 541 $(if $(building_out_of_srctree 542 $(if $(building_out_of_srctree),-I$(srctree)/include) \ 542 -I$(objtree)/include \ 543 -I$(objtree)/include \ 543 $(USERINCLUDE) 544 $(USERINCLUDE) 544 545 545 KBUILD_AFLAGS := -D__ASSEMBLY__ -fno-PIE 546 KBUILD_AFLAGS := -D__ASSEMBLY__ -fno-PIE 546 547 547 KBUILD_CFLAGS := 548 KBUILD_CFLAGS := 548 KBUILD_CFLAGS += -std=gnu11 549 KBUILD_CFLAGS += -std=gnu11 549 KBUILD_CFLAGS += -fshort-wchar 550 KBUILD_CFLAGS += -fshort-wchar 550 KBUILD_CFLAGS += -funsigned-char 551 KBUILD_CFLAGS += -funsigned-char 551 KBUILD_CFLAGS += -fno-common 552 KBUILD_CFLAGS += -fno-common 552 KBUILD_CFLAGS += -fno-PIE 553 KBUILD_CFLAGS += -fno-PIE 553 KBUILD_CFLAGS += -fno-strict-aliasing 554 KBUILD_CFLAGS += -fno-strict-aliasing 554 555 555 KBUILD_CPPFLAGS := -D__KERNEL__ 556 KBUILD_CPPFLAGS := -D__KERNEL__ 556 KBUILD_RUSTFLAGS := $(rust_common_flags) \ 557 KBUILD_RUSTFLAGS := $(rust_common_flags) \ >> 558 --target=$(objtree)/scripts/target.json \ 557 -Cpanic=abort -Cembed-bitc 559 -Cpanic=abort -Cembed-bitcode=n -Clto=n \ 558 -Cforce-unwind-tables=n -C 560 -Cforce-unwind-tables=n -Ccodegen-units=1 \ 559 -Csymbol-mangling-version= 561 -Csymbol-mangling-version=v0 \ 560 -Crelocation-model=static 562 -Crelocation-model=static \ 561 -Zfunction-sections=n \ 563 -Zfunction-sections=n \ 562 -Wclippy::float_arithmetic !! 564 -Dclippy::float_arithmetic 563 565 564 KBUILD_AFLAGS_KERNEL := 566 KBUILD_AFLAGS_KERNEL := 565 KBUILD_CFLAGS_KERNEL := 567 KBUILD_CFLAGS_KERNEL := 566 KBUILD_RUSTFLAGS_KERNEL := 568 KBUILD_RUSTFLAGS_KERNEL := 567 KBUILD_AFLAGS_MODULE := -DMODULE 569 KBUILD_AFLAGS_MODULE := -DMODULE 568 KBUILD_CFLAGS_MODULE := -DMODULE 570 KBUILD_CFLAGS_MODULE := -DMODULE 569 KBUILD_RUSTFLAGS_MODULE := --cfg MODULE 571 KBUILD_RUSTFLAGS_MODULE := --cfg MODULE 570 KBUILD_LDFLAGS_MODULE := 572 KBUILD_LDFLAGS_MODULE := 571 KBUILD_LDFLAGS := 573 KBUILD_LDFLAGS := 572 CLANG_FLAGS := 574 CLANG_FLAGS := 573 575 574 ifeq ($(KBUILD_CLIPPY),1) 576 ifeq ($(KBUILD_CLIPPY),1) 575 RUSTC_OR_CLIPPY_QUIET := CLIPPY 577 RUSTC_OR_CLIPPY_QUIET := CLIPPY 576 RUSTC_OR_CLIPPY = $(CLIPPY_DRIVER) 578 RUSTC_OR_CLIPPY = $(CLIPPY_DRIVER) 577 else 579 else 578 RUSTC_OR_CLIPPY_QUIET := RUSTC 580 RUSTC_OR_CLIPPY_QUIET := RUSTC 579 RUSTC_OR_CLIPPY = $(RUSTC) 581 RUSTC_OR_CLIPPY = $(RUSTC) 580 endif 582 endif 581 583 582 ifdef RUST_LIB_SRC 584 ifdef RUST_LIB_SRC 583 export RUST_LIB_SRC 585 export RUST_LIB_SRC 584 endif 586 endif 585 587 586 # Allows the usage of unstable features in sta 588 # Allows the usage of unstable features in stable compilers. 587 export RUSTC_BOOTSTRAP := 1 589 export RUSTC_BOOTSTRAP := 1 588 590 589 export ARCH SRCARCH CONFIG_SHELL BASH HOSTCC K 591 export ARCH SRCARCH CONFIG_SHELL BASH HOSTCC KBUILD_HOSTCFLAGS CROSS_COMPILE LD CC HOSTPKG_CONFIG 590 export RUSTC RUSTDOC RUSTFMT RUSTC_OR_CLIPPY_Q !! 592 export RUSTC RUSTDOC RUSTFMT RUSTC_OR_CLIPPY_QUIET RUSTC_OR_CLIPPY BINDGEN CARGO 591 export HOSTRUSTC KBUILD_HOSTRUSTFLAGS 593 export HOSTRUSTC KBUILD_HOSTRUSTFLAGS 592 export CPP AR NM STRIP OBJCOPY OBJDUMP READELF 594 export CPP AR NM STRIP OBJCOPY OBJDUMP READELF PAHOLE RESOLVE_BTFIDS LEX YACC AWK INSTALLKERNEL 593 export PERL PYTHON3 CHECK CHECKFLAGS MAKE UTS_ 595 export PERL PYTHON3 CHECK CHECKFLAGS MAKE UTS_MACHINE HOSTCXX 594 export KGZIP KBZIP2 KLZOP LZMA LZ4 XZ ZSTD 596 export KGZIP KBZIP2 KLZOP LZMA LZ4 XZ ZSTD 595 export KBUILD_HOSTCXXFLAGS KBUILD_HOSTLDFLAGS 597 export KBUILD_HOSTCXXFLAGS KBUILD_HOSTLDFLAGS KBUILD_HOSTLDLIBS LDFLAGS_MODULE 596 export KBUILD_USERCFLAGS KBUILD_USERLDFLAGS 598 export KBUILD_USERCFLAGS KBUILD_USERLDFLAGS 597 599 598 export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINC 600 export KBUILD_CPPFLAGS NOSTDINC_FLAGS LINUXINCLUDE OBJCOPYFLAGS KBUILD_LDFLAGS 599 export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODU 601 export KBUILD_CFLAGS CFLAGS_KERNEL CFLAGS_MODULE 600 export KBUILD_RUSTFLAGS RUSTFLAGS_KERNEL RUSTF 602 export KBUILD_RUSTFLAGS RUSTFLAGS_KERNEL RUSTFLAGS_MODULE 601 export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODU 603 export KBUILD_AFLAGS AFLAGS_KERNEL AFLAGS_MODULE 602 export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODU 604 export KBUILD_AFLAGS_MODULE KBUILD_CFLAGS_MODULE KBUILD_RUSTFLAGS_MODULE KBUILD_LDFLAGS_MODULE 603 export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERN 605 export KBUILD_AFLAGS_KERNEL KBUILD_CFLAGS_KERNEL KBUILD_RUSTFLAGS_KERNEL 604 606 605 # Files to ignore in find ... statements 607 # Files to ignore in find ... statements 606 608 607 export RCS_FIND_IGNORE := \( -name SCCS -o -na 609 export RCS_FIND_IGNORE := \( -name SCCS -o -name BitKeeper -o -name .svn -o \ 608 -name CVS -o -name . 610 -name CVS -o -name .pc -o -name .hg -o -name .git \) \ 609 -prune -o 611 -prune -o >> 612 export RCS_TAR_IGNORE := --exclude SCCS --exclude BitKeeper --exclude .svn \ >> 613 --exclude CVS --exclude .pc --exclude .hg --exclude .git 610 614 611 # ============================================ 615 # =========================================================================== 612 # Rules shared between *config targets and bui 616 # Rules shared between *config targets and build targets 613 617 614 # Basic helpers built in scripts/basic/ 618 # Basic helpers built in scripts/basic/ 615 PHONY += scripts_basic 619 PHONY += scripts_basic 616 scripts_basic: 620 scripts_basic: 617 $(Q)$(MAKE) $(build)=scripts/basic 621 $(Q)$(MAKE) $(build)=scripts/basic 618 622 619 PHONY += outputmakefile 623 PHONY += outputmakefile 620 ifdef building_out_of_srctree 624 ifdef building_out_of_srctree 621 # Before starting out-of-tree build, make sure 625 # Before starting out-of-tree build, make sure the source tree is clean. 622 # outputmakefile generates a Makefile in the o 626 # outputmakefile generates a Makefile in the output directory, if using a 623 # separate output directory. This allows conve 627 # separate output directory. This allows convenient use of make in the 624 # output directory. 628 # output directory. 625 # At the same time when output Makefile genera 629 # At the same time when output Makefile generated, generate .gitignore to 626 # ignore whole output directory 630 # ignore whole output directory 627 631 628 quiet_cmd_makefile = GEN Makefile 632 quiet_cmd_makefile = GEN Makefile 629 cmd_makefile = { \ 633 cmd_makefile = { \ 630 echo "\# Automatically generated by $( 634 echo "\# Automatically generated by $(srctree)/Makefile: don't edit"; \ 631 echo "include $(srctree)/Makefile"; \ 635 echo "include $(srctree)/Makefile"; \ 632 } > Makefile 636 } > Makefile 633 637 634 outputmakefile: 638 outputmakefile: 635 @if [ -f $(srctree)/.config -o \ 639 @if [ -f $(srctree)/.config -o \ 636 -d $(srctree)/include/config 640 -d $(srctree)/include/config -o \ 637 -d $(srctree)/arch/$(SRCARCH) 641 -d $(srctree)/arch/$(SRCARCH)/include/generated ]; then \ 638 echo >&2 "***"; \ 642 echo >&2 "***"; \ 639 echo >&2 "*** The source tree 643 echo >&2 "*** The source tree is not clean, please run 'make$(if $(findstring command line, $(origin ARCH)), ARCH=$(ARCH)) mrproper'"; \ 640 echo >&2 "*** in $(abs_srctree 644 echo >&2 "*** in $(abs_srctree)";\ 641 echo >&2 "***"; \ 645 echo >&2 "***"; \ 642 false; \ 646 false; \ 643 fi 647 fi 644 $(Q)ln -fsn $(srctree) source 648 $(Q)ln -fsn $(srctree) source 645 $(call cmd,makefile) 649 $(call cmd,makefile) 646 $(Q)test -e .gitignore || \ 650 $(Q)test -e .gitignore || \ 647 { echo "# this is build directory, ign 651 { echo "# this is build directory, ignore it"; echo "*"; } > .gitignore 648 endif 652 endif 649 653 650 # The expansion should be delayed until arch/$ 654 # The expansion should be delayed until arch/$(SRCARCH)/Makefile is included. 651 # Some architectures define CROSS_COMPILE in a 655 # Some architectures define CROSS_COMPILE in arch/$(SRCARCH)/Makefile. 652 # CC_VERSION_TEXT is referenced from Kconfig ( 656 # CC_VERSION_TEXT is referenced from Kconfig (so it needs export), 653 # and from include/config/auto.conf.cmd to det 657 # and from include/config/auto.conf.cmd to detect the compiler upgrade. 654 CC_VERSION_TEXT = $(subst $(pound),,$(shell LC 658 CC_VERSION_TEXT = $(subst $(pound),,$(shell LC_ALL=C $(CC) --version 2>/dev/null | head -n 1)) 655 659 656 ifneq ($(findstring clang,$(CC_VERSION_TEXT)), 660 ifneq ($(findstring clang,$(CC_VERSION_TEXT)),) 657 include $(srctree)/scripts/Makefile.clang 661 include $(srctree)/scripts/Makefile.clang 658 endif 662 endif 659 663 660 # Include this also for config targets because 664 # Include this also for config targets because some architectures need 661 # cc-cross-prefix to determine CROSS_COMPILE. 665 # cc-cross-prefix to determine CROSS_COMPILE. 662 ifdef need-compiler 666 ifdef need-compiler 663 include $(srctree)/scripts/Makefile.compiler 667 include $(srctree)/scripts/Makefile.compiler 664 endif 668 endif 665 669 666 ifdef config-build 670 ifdef config-build 667 # ============================================ 671 # =========================================================================== 668 # *config targets only - make sure prerequisit 672 # *config targets only - make sure prerequisites are updated, and descend 669 # in scripts/kconfig to make the *config targe 673 # in scripts/kconfig to make the *config target 670 674 671 # Read arch-specific Makefile to set KBUILD_DE 675 # Read arch-specific Makefile to set KBUILD_DEFCONFIG as needed. 672 # KBUILD_DEFCONFIG may point out an alternativ 676 # KBUILD_DEFCONFIG may point out an alternative default configuration 673 # used for 'make defconfig' 677 # used for 'make defconfig' 674 include $(srctree)/arch/$(SRCARCH)/Makefile 678 include $(srctree)/arch/$(SRCARCH)/Makefile 675 export KBUILD_DEFCONFIG KBUILD_KCONFIG CC_VERS 679 export KBUILD_DEFCONFIG KBUILD_KCONFIG CC_VERSION_TEXT 676 680 677 config: outputmakefile scripts_basic FORCE 681 config: outputmakefile scripts_basic FORCE 678 $(Q)$(MAKE) $(build)=scripts/kconfig $ 682 $(Q)$(MAKE) $(build)=scripts/kconfig $@ 679 683 680 %config: outputmakefile scripts_basic FORCE 684 %config: outputmakefile scripts_basic FORCE 681 $(Q)$(MAKE) $(build)=scripts/kconfig $ 685 $(Q)$(MAKE) $(build)=scripts/kconfig $@ 682 686 683 else #!config-build 687 else #!config-build 684 # ============================================ 688 # =========================================================================== 685 # Build targets only - this includes vmlinux, 689 # Build targets only - this includes vmlinux, arch-specific targets, clean 686 # targets and others. In general all targets e 690 # targets and others. In general all targets except *config targets. 687 691 688 # If building an external module we do not car 692 # If building an external module we do not care about the all: rule 689 # but instead __all depend on modules 693 # but instead __all depend on modules 690 PHONY += all 694 PHONY += all 691 ifeq ($(KBUILD_EXTMOD),) 695 ifeq ($(KBUILD_EXTMOD),) 692 __all: all 696 __all: all 693 else 697 else 694 __all: modules 698 __all: modules 695 endif 699 endif 696 700 697 targets := 701 targets := 698 702 699 # Decide whether to build built-in, modular, o 703 # Decide whether to build built-in, modular, or both. 700 # Normally, just do built-in. 704 # Normally, just do built-in. 701 705 702 KBUILD_MODULES := 706 KBUILD_MODULES := 703 KBUILD_BUILTIN := 1 707 KBUILD_BUILTIN := 1 704 708 705 # If we have only "make modules", don't compil 709 # If we have only "make modules", don't compile built-in objects. 706 ifeq ($(MAKECMDGOALS),modules) 710 ifeq ($(MAKECMDGOALS),modules) 707 KBUILD_BUILTIN := 711 KBUILD_BUILTIN := 708 endif 712 endif 709 713 710 # If we have "make <whatever> modules", compil 714 # If we have "make <whatever> modules", compile modules 711 # in addition to whatever we do anyway. 715 # in addition to whatever we do anyway. 712 # Just "make" or "make all" shall build module 716 # Just "make" or "make all" shall build modules as well 713 717 714 ifneq ($(filter all modules nsdeps %compile_co 718 ifneq ($(filter all modules nsdeps %compile_commands.json clang-%,$(MAKECMDGOALS)),) 715 KBUILD_MODULES := 1 719 KBUILD_MODULES := 1 716 endif 720 endif 717 721 718 ifeq ($(MAKECMDGOALS),) 722 ifeq ($(MAKECMDGOALS),) 719 KBUILD_MODULES := 1 723 KBUILD_MODULES := 1 720 endif 724 endif 721 725 722 export KBUILD_MODULES KBUILD_BUILTIN 726 export KBUILD_MODULES KBUILD_BUILTIN 723 727 724 ifdef need-config 728 ifdef need-config 725 include include/config/auto.conf 729 include include/config/auto.conf 726 endif 730 endif 727 731 728 ifeq ($(KBUILD_EXTMOD),) 732 ifeq ($(KBUILD_EXTMOD),) 729 # Objects we will link into vmlinux / subdirs 733 # Objects we will link into vmlinux / subdirs we need to visit 730 core-y := 734 core-y := 731 drivers-y := 735 drivers-y := 732 libs-y := lib/ 736 libs-y := lib/ 733 endif # KBUILD_EXTMOD 737 endif # KBUILD_EXTMOD 734 738 735 # The all: target is the default when no targe 739 # The all: target is the default when no target is given on the 736 # command line. 740 # command line. 737 # This allow a user to issue only 'make' to bu 741 # This allow a user to issue only 'make' to build a kernel including modules 738 # Defaults to vmlinux, but the arch makefile u 742 # Defaults to vmlinux, but the arch makefile usually adds further targets 739 all: vmlinux 743 all: vmlinux 740 744 741 CFLAGS_GCOV := -fprofile-arcs -ftest-cover 745 CFLAGS_GCOV := -fprofile-arcs -ftest-coverage 742 ifdef CONFIG_CC_IS_GCC 746 ifdef CONFIG_CC_IS_GCC 743 CFLAGS_GCOV += -fno-tree-loop-im 747 CFLAGS_GCOV += -fno-tree-loop-im 744 endif 748 endif 745 export CFLAGS_GCOV 749 export CFLAGS_GCOV 746 750 747 # The arch Makefiles can override CC_FLAGS_FTR 751 # The arch Makefiles can override CC_FLAGS_FTRACE. We may also append it later. 748 ifdef CONFIG_FUNCTION_TRACER 752 ifdef CONFIG_FUNCTION_TRACER 749 CC_FLAGS_FTRACE := -pg 753 CC_FLAGS_FTRACE := -pg 750 endif 754 endif 751 755 752 include $(srctree)/arch/$(SRCARCH)/Makefile 756 include $(srctree)/arch/$(SRCARCH)/Makefile 753 757 754 ifdef need-config 758 ifdef need-config 755 ifdef may-sync-config 759 ifdef may-sync-config 756 # Read in dependencies to all Kconfig* files, 760 # Read in dependencies to all Kconfig* files, make sure to run syncconfig if 757 # changes are detected. This should be include 761 # changes are detected. This should be included after arch/$(SRCARCH)/Makefile 758 # because some architectures define CROSS_COMP 762 # because some architectures define CROSS_COMPILE there. 759 include include/config/auto.conf.cmd 763 include include/config/auto.conf.cmd 760 764 761 $(KCONFIG_CONFIG): 765 $(KCONFIG_CONFIG): 762 @echo >&2 '***' 766 @echo >&2 '***' 763 @echo >&2 '*** Configuration file "$@" 767 @echo >&2 '*** Configuration file "$@" not found!' 764 @echo >&2 '***' 768 @echo >&2 '***' 765 @echo >&2 '*** Please run some configu 769 @echo >&2 '*** Please run some configurator (e.g. "make oldconfig" or' 766 @echo >&2 '*** "make menuconfig" or "m 770 @echo >&2 '*** "make menuconfig" or "make xconfig").' 767 @echo >&2 '***' 771 @echo >&2 '***' 768 @/bin/false 772 @/bin/false 769 773 770 # The actual configuration files used during t 774 # The actual configuration files used during the build are stored in 771 # include/generated/ and include/config/. Upda 775 # include/generated/ and include/config/. Update them if .config is newer than 772 # include/config/auto.conf (which mirrors .con 776 # include/config/auto.conf (which mirrors .config). 773 # 777 # 774 # This exploits the 'multi-target pattern rule 778 # This exploits the 'multi-target pattern rule' trick. 775 # The syncconfig should be executed only once 779 # The syncconfig should be executed only once to make all the targets. 776 # (Note: use the grouped target '&:' when we b 780 # (Note: use the grouped target '&:' when we bump to GNU Make 4.3) 777 # 781 # 778 # Do not use $(call cmd,...) here. That would 782 # Do not use $(call cmd,...) here. That would suppress prompts from syncconfig, 779 # so you cannot notice that Kconfig is waiting 783 # so you cannot notice that Kconfig is waiting for the user input. 780 %/config/auto.conf %/config/auto.conf.cmd %/ge 784 %/config/auto.conf %/config/auto.conf.cmd %/generated/autoconf.h %/generated/rustc_cfg: $(KCONFIG_CONFIG) 781 $(Q)$(kecho) " SYNC $@" 785 $(Q)$(kecho) " SYNC $@" 782 $(Q)$(MAKE) -f $(srctree)/Makefile syn 786 $(Q)$(MAKE) -f $(srctree)/Makefile syncconfig 783 else # !may-sync-config 787 else # !may-sync-config 784 # External modules and some install targets ne 788 # External modules and some install targets need include/generated/autoconf.h 785 # and include/config/auto.conf but do not care 789 # and include/config/auto.conf but do not care if they are up-to-date. 786 # Use auto.conf to trigger the test 790 # Use auto.conf to trigger the test 787 PHONY += include/config/auto.conf 791 PHONY += include/config/auto.conf 788 792 789 include/config/auto.conf: 793 include/config/auto.conf: 790 @test -e include/generated/autoconf.h 794 @test -e include/generated/autoconf.h -a -e $@ || ( \ 791 echo >&2; 795 echo >&2; \ 792 echo >&2 " ERROR: Kernel configuratio 796 echo >&2 " ERROR: Kernel configuration is invalid."; \ 793 echo >&2 " include/generated/a 797 echo >&2 " include/generated/autoconf.h or $@ are missing.";\ 794 echo >&2 " Run 'make oldconfig 798 echo >&2 " Run 'make oldconfig && make prepare' on kernel src to fix it."; \ 795 echo >&2 ; 799 echo >&2 ; \ 796 /bin/false) 800 /bin/false) 797 801 798 endif # may-sync-config 802 endif # may-sync-config 799 endif # need-config 803 endif # need-config 800 804 801 KBUILD_CFLAGS += -fno-delete-null-pointer-ch 805 KBUILD_CFLAGS += -fno-delete-null-pointer-checks 802 806 803 ifdef CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE 807 ifdef CONFIG_CC_OPTIMIZE_FOR_PERFORMANCE 804 KBUILD_CFLAGS += -O2 808 KBUILD_CFLAGS += -O2 805 KBUILD_RUSTFLAGS += -Copt-level=2 809 KBUILD_RUSTFLAGS += -Copt-level=2 806 else ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE 810 else ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE 807 KBUILD_CFLAGS += -Os 811 KBUILD_CFLAGS += -Os 808 KBUILD_RUSTFLAGS += -Copt-level=s 812 KBUILD_RUSTFLAGS += -Copt-level=s 809 endif 813 endif 810 814 811 # Always set `debug-assertions` and `overflow- 815 # Always set `debug-assertions` and `overflow-checks` because their default 812 # depends on `opt-level` and `debug-assertions 816 # depends on `opt-level` and `debug-assertions`, respectively. 813 KBUILD_RUSTFLAGS += -Cdebug-assertions=$(if $( 817 KBUILD_RUSTFLAGS += -Cdebug-assertions=$(if $(CONFIG_RUST_DEBUG_ASSERTIONS),y,n) 814 KBUILD_RUSTFLAGS += -Coverflow-checks=$(if $(C 818 KBUILD_RUSTFLAGS += -Coverflow-checks=$(if $(CONFIG_RUST_OVERFLOW_CHECKS),y,n) 815 819 816 # Tell gcc to never replace conditional load w 820 # Tell gcc to never replace conditional load with a non-conditional one 817 ifdef CONFIG_CC_IS_GCC 821 ifdef CONFIG_CC_IS_GCC 818 # gcc-10 renamed --param=allow-store-data-race 822 # gcc-10 renamed --param=allow-store-data-races=0 to 819 # -fno-allow-store-data-races. 823 # -fno-allow-store-data-races. 820 KBUILD_CFLAGS += $(call cc-option,--param=al 824 KBUILD_CFLAGS += $(call cc-option,--param=allow-store-data-races=0) 821 KBUILD_CFLAGS += $(call cc-option,-fno-allow 825 KBUILD_CFLAGS += $(call cc-option,-fno-allow-store-data-races) 822 endif 826 endif 823 827 824 ifdef CONFIG_READABLE_ASM 828 ifdef CONFIG_READABLE_ASM 825 # Disable optimizations that make assembler li 829 # Disable optimizations that make assembler listings hard to read. 826 # reorder blocks reorders the control in the f 830 # reorder blocks reorders the control in the function 827 # ipa clone creates specialized cloned functio 831 # ipa clone creates specialized cloned functions 828 # partial inlining inlines only parts of funct 832 # partial inlining inlines only parts of functions 829 KBUILD_CFLAGS += -fno-reorder-blocks -fno-ipa- 833 KBUILD_CFLAGS += -fno-reorder-blocks -fno-ipa-cp-clone -fno-partial-inlining 830 endif 834 endif 831 835 832 stackp-flags-y 836 stackp-flags-y := -fno-stack-protector 833 stackp-flags-$(CONFIG_STACKPROTECTOR) 837 stackp-flags-$(CONFIG_STACKPROTECTOR) := -fstack-protector 834 stackp-flags-$(CONFIG_STACKPROTECTOR_STRONG) 838 stackp-flags-$(CONFIG_STACKPROTECTOR_STRONG) := -fstack-protector-strong 835 839 836 KBUILD_CFLAGS += $(stackp-flags-y) 840 KBUILD_CFLAGS += $(stackp-flags-y) 837 841 838 KBUILD_RUSTFLAGS-$(CONFIG_WERROR) += -Dwarning 842 KBUILD_RUSTFLAGS-$(CONFIG_WERROR) += -Dwarnings 839 KBUILD_RUSTFLAGS += $(KBUILD_RUSTFLAGS-y) 843 KBUILD_RUSTFLAGS += $(KBUILD_RUSTFLAGS-y) 840 844 841 ifdef CONFIG_FRAME_POINTER 845 ifdef CONFIG_FRAME_POINTER 842 KBUILD_CFLAGS += -fno-omit-frame-pointer -fn 846 KBUILD_CFLAGS += -fno-omit-frame-pointer -fno-optimize-sibling-calls 843 KBUILD_RUSTFLAGS += -Cforce-frame-pointers=y 847 KBUILD_RUSTFLAGS += -Cforce-frame-pointers=y 844 else 848 else 845 # Some targets (ARM with Thumb2, for example), 849 # Some targets (ARM with Thumb2, for example), can't be built with frame 846 # pointers. For those, we don't have FUNCTION 850 # pointers. For those, we don't have FUNCTION_TRACER automatically 847 # select FRAME_POINTER. However, FUNCTION_TRA 851 # select FRAME_POINTER. However, FUNCTION_TRACER adds -pg, and this is 848 # incompatible with -fomit-frame-pointer with 852 # incompatible with -fomit-frame-pointer with current GCC, so we don't use 849 # -fomit-frame-pointer with FUNCTION_TRACER. 853 # -fomit-frame-pointer with FUNCTION_TRACER. 850 # In the Rust target specification, "frame-poi 854 # In the Rust target specification, "frame-pointer" is set explicitly 851 # to "may-omit". 855 # to "may-omit". 852 ifndef CONFIG_FUNCTION_TRACER 856 ifndef CONFIG_FUNCTION_TRACER 853 KBUILD_CFLAGS += -fomit-frame-pointer 857 KBUILD_CFLAGS += -fomit-frame-pointer 854 endif 858 endif 855 endif 859 endif 856 860 857 # Initialize all stack variables with a 0xAA p 861 # Initialize all stack variables with a 0xAA pattern. 858 ifdef CONFIG_INIT_STACK_ALL_PATTERN 862 ifdef CONFIG_INIT_STACK_ALL_PATTERN 859 KBUILD_CFLAGS += -ftrivial-auto-var-init=pat 863 KBUILD_CFLAGS += -ftrivial-auto-var-init=pattern 860 endif 864 endif 861 865 862 # Initialize all stack variables with a zero v 866 # Initialize all stack variables with a zero value. 863 ifdef CONFIG_INIT_STACK_ALL_ZERO 867 ifdef CONFIG_INIT_STACK_ALL_ZERO 864 KBUILD_CFLAGS += -ftrivial-auto-var-init=zer 868 KBUILD_CFLAGS += -ftrivial-auto-var-init=zero 865 ifdef CONFIG_CC_HAS_AUTO_VAR_INIT_ZERO_ENABLER 869 ifdef CONFIG_CC_HAS_AUTO_VAR_INIT_ZERO_ENABLER 866 # https://github.com/llvm/llvm-project/issues/ 870 # https://github.com/llvm/llvm-project/issues/44842 867 CC_AUTO_VAR_INIT_ZERO_ENABLER := -enable-trivi 871 CC_AUTO_VAR_INIT_ZERO_ENABLER := -enable-trivial-auto-var-init-zero-knowing-it-will-be-removed-from-clang 868 export CC_AUTO_VAR_INIT_ZERO_ENABLER 872 export CC_AUTO_VAR_INIT_ZERO_ENABLER 869 KBUILD_CFLAGS += $(CC_AUTO_VAR_INIT_ZERO_ENA 873 KBUILD_CFLAGS += $(CC_AUTO_VAR_INIT_ZERO_ENABLER) 870 endif 874 endif 871 endif 875 endif 872 876 873 # While VLAs have been removed, GCC produces u 877 # While VLAs have been removed, GCC produces unreachable stack probes 874 # for the randomize_kstack_offset feature. Dis 878 # for the randomize_kstack_offset feature. Disable it for all compilers. 875 KBUILD_CFLAGS += $(call cc-option, -fno-stac 879 KBUILD_CFLAGS += $(call cc-option, -fno-stack-clash-protection) 876 880 877 # Clear used registers at func exit (to reduce 881 # Clear used registers at func exit (to reduce data lifetime and ROP gadgets). 878 ifdef CONFIG_ZERO_CALL_USED_REGS 882 ifdef CONFIG_ZERO_CALL_USED_REGS 879 KBUILD_CFLAGS += -fzero-call-used-regs=used- 883 KBUILD_CFLAGS += -fzero-call-used-regs=used-gpr 880 endif 884 endif 881 885 882 ifdef CONFIG_FUNCTION_TRACER 886 ifdef CONFIG_FUNCTION_TRACER 883 ifdef CONFIG_FTRACE_MCOUNT_USE_CC 887 ifdef CONFIG_FTRACE_MCOUNT_USE_CC 884 CC_FLAGS_FTRACE += -mrecord-mcount 888 CC_FLAGS_FTRACE += -mrecord-mcount 885 ifdef CONFIG_HAVE_NOP_MCOUNT 889 ifdef CONFIG_HAVE_NOP_MCOUNT 886 ifeq ($(call cc-option-yn, -mnop-mcount),y 890 ifeq ($(call cc-option-yn, -mnop-mcount),y) 887 CC_FLAGS_FTRACE += -mnop-mcount 891 CC_FLAGS_FTRACE += -mnop-mcount 888 CC_FLAGS_USING += -DCC_USING_NOP_MCOU 892 CC_FLAGS_USING += -DCC_USING_NOP_MCOUNT 889 endif 893 endif 890 endif 894 endif 891 endif 895 endif 892 ifdef CONFIG_FTRACE_MCOUNT_USE_OBJTOOL 896 ifdef CONFIG_FTRACE_MCOUNT_USE_OBJTOOL 893 ifdef CONFIG_HAVE_OBJTOOL_NOP_MCOUNT 897 ifdef CONFIG_HAVE_OBJTOOL_NOP_MCOUNT 894 CC_FLAGS_USING += -DCC_USING_NOP_MCOU 898 CC_FLAGS_USING += -DCC_USING_NOP_MCOUNT 895 endif 899 endif 896 endif 900 endif 897 ifdef CONFIG_FTRACE_MCOUNT_USE_RECORDMCOUNT 901 ifdef CONFIG_FTRACE_MCOUNT_USE_RECORDMCOUNT 898 ifdef CONFIG_HAVE_C_RECORDMCOUNT 902 ifdef CONFIG_HAVE_C_RECORDMCOUNT 899 BUILD_C_RECORDMCOUNT := y 903 BUILD_C_RECORDMCOUNT := y 900 export BUILD_C_RECORDMCOUNT 904 export BUILD_C_RECORDMCOUNT 901 endif 905 endif 902 endif 906 endif 903 ifdef CONFIG_HAVE_FENTRY 907 ifdef CONFIG_HAVE_FENTRY 904 # s390-linux-gnu-gcc did not support -mfentr 908 # s390-linux-gnu-gcc did not support -mfentry until gcc-9. 905 ifeq ($(call cc-option-yn, -mfentry),y) 909 ifeq ($(call cc-option-yn, -mfentry),y) 906 CC_FLAGS_FTRACE += -mfentry 910 CC_FLAGS_FTRACE += -mfentry 907 CC_FLAGS_USING += -DCC_USING_FENTRY 911 CC_FLAGS_USING += -DCC_USING_FENTRY 908 endif 912 endif 909 endif 913 endif 910 export CC_FLAGS_FTRACE 914 export CC_FLAGS_FTRACE 911 KBUILD_CFLAGS += $(CC_FLAGS_FTRACE) $(CC_FLA 915 KBUILD_CFLAGS += $(CC_FLAGS_FTRACE) $(CC_FLAGS_USING) 912 KBUILD_AFLAGS += $(CC_FLAGS_USING) 916 KBUILD_AFLAGS += $(CC_FLAGS_USING) 913 endif 917 endif 914 918 915 # We trigger additional mismatches with less i 919 # We trigger additional mismatches with less inlining 916 ifdef CONFIG_DEBUG_SECTION_MISMATCH 920 ifdef CONFIG_DEBUG_SECTION_MISMATCH 917 KBUILD_CFLAGS += -fno-inline-functions-called- 921 KBUILD_CFLAGS += -fno-inline-functions-called-once 918 endif 922 endif 919 923 920 # `rustc`'s `-Zfunction-sections` applies to d 924 # `rustc`'s `-Zfunction-sections` applies to data too (as of 1.59.0). 921 ifdef CONFIG_LD_DEAD_CODE_DATA_ELIMINATION 925 ifdef CONFIG_LD_DEAD_CODE_DATA_ELIMINATION 922 KBUILD_CFLAGS_KERNEL += -ffunction-sections -f 926 KBUILD_CFLAGS_KERNEL += -ffunction-sections -fdata-sections 923 KBUILD_RUSTFLAGS_KERNEL += -Zfunction-sections 927 KBUILD_RUSTFLAGS_KERNEL += -Zfunction-sections=y 924 LDFLAGS_vmlinux += --gc-sections 928 LDFLAGS_vmlinux += --gc-sections 925 endif 929 endif 926 930 927 ifdef CONFIG_SHADOW_CALL_STACK 931 ifdef CONFIG_SHADOW_CALL_STACK 928 ifndef CONFIG_DYNAMIC_SCS 932 ifndef CONFIG_DYNAMIC_SCS 929 CC_FLAGS_SCS := -fsanitize=shadow-call-stac 933 CC_FLAGS_SCS := -fsanitize=shadow-call-stack 930 KBUILD_CFLAGS += $(CC_FLAGS_SCS) 934 KBUILD_CFLAGS += $(CC_FLAGS_SCS) 931 endif 935 endif 932 export CC_FLAGS_SCS 936 export CC_FLAGS_SCS 933 endif 937 endif 934 938 935 ifdef CONFIG_LTO_CLANG 939 ifdef CONFIG_LTO_CLANG 936 ifdef CONFIG_LTO_CLANG_THIN 940 ifdef CONFIG_LTO_CLANG_THIN 937 CC_FLAGS_LTO := -flto=thin -fsplit-lto-unit 941 CC_FLAGS_LTO := -flto=thin -fsplit-lto-unit >> 942 KBUILD_LDFLAGS += --thinlto-cache-dir=$(extmod_prefix).thinlto-cache 938 else 943 else 939 CC_FLAGS_LTO := -flto 944 CC_FLAGS_LTO := -flto 940 endif 945 endif 941 CC_FLAGS_LTO += -fvisibility=hidden 946 CC_FLAGS_LTO += -fvisibility=hidden 942 947 943 # Limit inlining across translation units to r 948 # Limit inlining across translation units to reduce binary size 944 KBUILD_LDFLAGS += -mllvm -import-instr-limit=5 949 KBUILD_LDFLAGS += -mllvm -import-instr-limit=5 >> 950 >> 951 # Check for frame size exceeding threshold during prolog/epilog insertion >> 952 # when using lld < 13.0.0. >> 953 ifneq ($(CONFIG_FRAME_WARN),0) >> 954 ifeq ($(call test-lt, $(CONFIG_LLD_VERSION), 130000),y) >> 955 KBUILD_LDFLAGS += -plugin-opt=-warn-stack-size=$(CONFIG_FRAME_WARN) >> 956 endif >> 957 endif 945 endif 958 endif 946 959 947 ifdef CONFIG_LTO 960 ifdef CONFIG_LTO 948 KBUILD_CFLAGS += -fno-lto $(CC_FLAGS_LTO) 961 KBUILD_CFLAGS += -fno-lto $(CC_FLAGS_LTO) 949 KBUILD_AFLAGS += -fno-lto 962 KBUILD_AFLAGS += -fno-lto 950 export CC_FLAGS_LTO 963 export CC_FLAGS_LTO 951 endif 964 endif 952 965 953 ifdef CONFIG_CFI_CLANG 966 ifdef CONFIG_CFI_CLANG 954 CC_FLAGS_CFI := -fsanitize=kcfi 967 CC_FLAGS_CFI := -fsanitize=kcfi 955 KBUILD_CFLAGS += $(CC_FLAGS_CFI) 968 KBUILD_CFLAGS += $(CC_FLAGS_CFI) 956 export CC_FLAGS_CFI 969 export CC_FLAGS_CFI 957 endif 970 endif 958 971 959 # Architectures can define flags to add/remove << 960 CC_FLAGS_FPU += -D_LINUX_FPU_COMPILATION_UN << 961 export CC_FLAGS_FPU << 962 export CC_FLAGS_NO_FPU << 963 << 964 ifneq ($(CONFIG_FUNCTION_ALIGNMENT),0) 972 ifneq ($(CONFIG_FUNCTION_ALIGNMENT),0) 965 # Set the minimal function alignment. Use the << 966 # -fmin-function-alignment if it is available, << 967 # See also CONFIG_CC_HAS_SANE_FUNCTION_ALIGNME << 968 ifdef CONFIG_CC_HAS_MIN_FUNCTION_ALIGNMENT << 969 KBUILD_CFLAGS += -fmin-function-alignment=$(CO << 970 else << 971 KBUILD_CFLAGS += -falign-functions=$(CONFIG_FU 973 KBUILD_CFLAGS += -falign-functions=$(CONFIG_FUNCTION_ALIGNMENT) 972 endif 974 endif 973 endif << 974 975 975 # arch Makefile may override CC so keep this a 976 # arch Makefile may override CC so keep this after arch Makefile is included 976 NOSTDINC_FLAGS += -nostdinc 977 NOSTDINC_FLAGS += -nostdinc 977 978 978 # To gain proper coverage for CONFIG_UBSAN_BOU 979 # To gain proper coverage for CONFIG_UBSAN_BOUNDS and CONFIG_FORTIFY_SOURCE, 979 # the kernel uses only C99 flexible arrays for 980 # the kernel uses only C99 flexible arrays for dynamically sized trailing 980 # arrays. Enforce this for everything that may 981 # arrays. Enforce this for everything that may examine structure sizes and 981 # perform bounds checking. 982 # perform bounds checking. 982 KBUILD_CFLAGS += $(call cc-option, -fstrict-fl 983 KBUILD_CFLAGS += $(call cc-option, -fstrict-flex-arrays=3) 983 984 984 #Currently, disable -Wstringop-overflow for GC << 985 KBUILD_CFLAGS-$(CONFIG_CC_NO_STRINGOP_OVERFLOW << 986 KBUILD_CFLAGS-$(CONFIG_CC_STRINGOP_OVERFLOW) + << 987 << 988 # disable invalid "can't wrap" optimizations f 985 # disable invalid "can't wrap" optimizations for signed / pointers 989 KBUILD_CFLAGS += -fno-strict-overflow 986 KBUILD_CFLAGS += -fno-strict-overflow 990 987 991 # Make sure -fstack-check isn't enabled (like 988 # Make sure -fstack-check isn't enabled (like gentoo apparently did) 992 KBUILD_CFLAGS += -fno-stack-check 989 KBUILD_CFLAGS += -fno-stack-check 993 990 994 # conserve stack if available 991 # conserve stack if available 995 ifdef CONFIG_CC_IS_GCC 992 ifdef CONFIG_CC_IS_GCC 996 KBUILD_CFLAGS += -fconserve-stack 993 KBUILD_CFLAGS += -fconserve-stack 997 endif 994 endif 998 995 999 # change __FILE__ to the relative path from th 996 # change __FILE__ to the relative path from the srctree 1000 KBUILD_CPPFLAGS += $(call cc-option,-fmacro-p 997 KBUILD_CPPFLAGS += $(call cc-option,-fmacro-prefix-map=$(srctree)/=) 1001 998 1002 # include additional Makefiles when needed 999 # include additional Makefiles when needed 1003 include-y := scripts/Ma 1000 include-y := scripts/Makefile.extrawarn 1004 include-$(CONFIG_DEBUG_INFO) += scripts/Ma 1001 include-$(CONFIG_DEBUG_INFO) += scripts/Makefile.debug 1005 include-$(CONFIG_DEBUG_INFO_BTF)+= scripts/Ma 1002 include-$(CONFIG_DEBUG_INFO_BTF)+= scripts/Makefile.btf 1006 include-$(CONFIG_KASAN) += scripts/Ma 1003 include-$(CONFIG_KASAN) += scripts/Makefile.kasan 1007 include-$(CONFIG_KCSAN) += scripts/Ma 1004 include-$(CONFIG_KCSAN) += scripts/Makefile.kcsan 1008 include-$(CONFIG_KMSAN) += scripts/Ma 1005 include-$(CONFIG_KMSAN) += scripts/Makefile.kmsan 1009 include-$(CONFIG_UBSAN) += scripts/Ma 1006 include-$(CONFIG_UBSAN) += scripts/Makefile.ubsan 1010 include-$(CONFIG_KCOV) += scripts/Ma 1007 include-$(CONFIG_KCOV) += scripts/Makefile.kcov 1011 include-$(CONFIG_RANDSTRUCT) += scripts/Ma 1008 include-$(CONFIG_RANDSTRUCT) += scripts/Makefile.randstruct 1012 include-$(CONFIG_GCC_PLUGINS) += scripts/Ma 1009 include-$(CONFIG_GCC_PLUGINS) += scripts/Makefile.gcc-plugins 1013 1010 1014 include $(addprefix $(srctree)/, $(include-y) 1011 include $(addprefix $(srctree)/, $(include-y)) 1015 1012 1016 # scripts/Makefile.gcc-plugins is intentional 1013 # scripts/Makefile.gcc-plugins is intentionally included last. 1017 # Do not add $(call cc-option,...) below this 1014 # Do not add $(call cc-option,...) below this line. When you build the kernel 1018 # from the clean source tree, the GCC plugins 1015 # from the clean source tree, the GCC plugins do not exist at this point. 1019 1016 1020 # Add user supplied CPPFLAGS, AFLAGS, CFLAGS 1017 # Add user supplied CPPFLAGS, AFLAGS, CFLAGS and RUSTFLAGS as the last assignments 1021 KBUILD_CPPFLAGS += $(KCPPFLAGS) 1018 KBUILD_CPPFLAGS += $(KCPPFLAGS) 1022 KBUILD_AFLAGS += $(KAFLAGS) 1019 KBUILD_AFLAGS += $(KAFLAGS) 1023 KBUILD_CFLAGS += $(KCFLAGS) 1020 KBUILD_CFLAGS += $(KCFLAGS) 1024 KBUILD_RUSTFLAGS += $(KRUSTFLAGS) 1021 KBUILD_RUSTFLAGS += $(KRUSTFLAGS) 1025 1022 1026 KBUILD_LDFLAGS_MODULE += --build-id=sha1 1023 KBUILD_LDFLAGS_MODULE += --build-id=sha1 1027 LDFLAGS_vmlinux += --build-id=sha1 1024 LDFLAGS_vmlinux += --build-id=sha1 1028 1025 1029 KBUILD_LDFLAGS += -z noexecstack 1026 KBUILD_LDFLAGS += -z noexecstack 1030 ifeq ($(CONFIG_LD_IS_BFD),y) 1027 ifeq ($(CONFIG_LD_IS_BFD),y) 1031 KBUILD_LDFLAGS += $(call ld-option,--no-warn 1028 KBUILD_LDFLAGS += $(call ld-option,--no-warn-rwx-segments) 1032 endif 1029 endif 1033 1030 1034 ifeq ($(CONFIG_STRIP_ASM_SYMS),y) 1031 ifeq ($(CONFIG_STRIP_ASM_SYMS),y) 1035 LDFLAGS_vmlinux += -X 1032 LDFLAGS_vmlinux += -X 1036 endif 1033 endif 1037 1034 1038 ifeq ($(CONFIG_RELR),y) 1035 ifeq ($(CONFIG_RELR),y) 1039 # ld.lld before 15 did not support -z pack-re 1036 # ld.lld before 15 did not support -z pack-relative-relocs. 1040 LDFLAGS_vmlinux += $(call ld-option,--pack-dy 1037 LDFLAGS_vmlinux += $(call ld-option,--pack-dyn-relocs=relr,-z pack-relative-relocs) 1041 endif 1038 endif 1042 1039 1043 # We never want expected sections to be place 1040 # We never want expected sections to be placed heuristically by the 1044 # linker. All sections should be explicitly n 1041 # linker. All sections should be explicitly named in the linker script. 1045 ifdef CONFIG_LD_ORPHAN_WARN 1042 ifdef CONFIG_LD_ORPHAN_WARN 1046 LDFLAGS_vmlinux += --orphan-handling=$(CONFIG 1043 LDFLAGS_vmlinux += --orphan-handling=$(CONFIG_LD_ORPHAN_WARN_LEVEL) 1047 endif 1044 endif 1048 1045 1049 # Align the bit size of userspace programs wi 1046 # Align the bit size of userspace programs with the kernel 1050 KBUILD_USERCFLAGS += $(filter -m32 -m64 --ta 1047 KBUILD_USERCFLAGS += $(filter -m32 -m64 --target=%, $(KBUILD_CFLAGS)) 1051 KBUILD_USERLDFLAGS += $(filter -m32 -m64 --ta 1048 KBUILD_USERLDFLAGS += $(filter -m32 -m64 --target=%, $(KBUILD_CFLAGS)) 1052 1049 1053 # make the checker run with the right archite 1050 # make the checker run with the right architecture 1054 CHECKFLAGS += --arch=$(ARCH) 1051 CHECKFLAGS += --arch=$(ARCH) 1055 1052 1056 # insure the checker run with the right endia 1053 # insure the checker run with the right endianness 1057 CHECKFLAGS += $(if $(CONFIG_CPU_BIG_ENDIAN),- 1054 CHECKFLAGS += $(if $(CONFIG_CPU_BIG_ENDIAN),-mbig-endian,-mlittle-endian) 1058 1055 1059 # the checker needs the correct machine size 1056 # the checker needs the correct machine size 1060 CHECKFLAGS += $(if $(CONFIG_64BIT),-m64,-m32) 1057 CHECKFLAGS += $(if $(CONFIG_64BIT),-m64,-m32) 1061 1058 1062 # Default kernel image to build when no speci 1059 # Default kernel image to build when no specific target is given. 1063 # KBUILD_IMAGE may be overruled on the comman 1060 # KBUILD_IMAGE may be overruled on the command line or 1064 # set in the environment 1061 # set in the environment 1065 # Also any assignments in arch/$(ARCH)/Makefi 1062 # Also any assignments in arch/$(ARCH)/Makefile take precedence over 1066 # this default value 1063 # this default value 1067 export KBUILD_IMAGE ?= vmlinux 1064 export KBUILD_IMAGE ?= vmlinux 1068 1065 1069 # 1066 # 1070 # INSTALL_PATH specifies where to place the u 1067 # INSTALL_PATH specifies where to place the updated kernel and system map 1071 # images. Default is /boot, but you can set i 1068 # images. Default is /boot, but you can set it to other values 1072 export INSTALL_PATH ?= /boot 1069 export INSTALL_PATH ?= /boot 1073 1070 1074 # 1071 # 1075 # INSTALL_DTBS_PATH specifies a prefix for re 1072 # INSTALL_DTBS_PATH specifies a prefix for relocations required by build roots. 1076 # Like INSTALL_MOD_PATH, it isn't defined in 1073 # Like INSTALL_MOD_PATH, it isn't defined in the Makefile, but can be passed as 1077 # an argument if needed. Otherwise it default 1074 # an argument if needed. Otherwise it defaults to the kernel install path 1078 # 1075 # 1079 export INSTALL_DTBS_PATH ?= $(INSTALL_PATH)/d 1076 export INSTALL_DTBS_PATH ?= $(INSTALL_PATH)/dtbs/$(KERNELRELEASE) 1080 1077 1081 # 1078 # 1082 # INSTALL_MOD_PATH specifies a prefix to MODL 1079 # INSTALL_MOD_PATH specifies a prefix to MODLIB for module directory 1083 # relocations required by build roots. This 1080 # relocations required by build roots. This is not defined in the 1084 # makefile but the argument can be passed to 1081 # makefile but the argument can be passed to make if needed. 1085 # 1082 # 1086 1083 1087 MODLIB = $(INSTALL_MOD_PATH)/lib/modules/$(K 1084 MODLIB = $(INSTALL_MOD_PATH)/lib/modules/$(KERNELRELEASE) 1088 export MODLIB 1085 export MODLIB 1089 1086 1090 PHONY += prepare0 1087 PHONY += prepare0 1091 1088 1092 export extmod_prefix = $(if $(KBUILD_EXTMOD), 1089 export extmod_prefix = $(if $(KBUILD_EXTMOD),$(KBUILD_EXTMOD)/) 1093 export MODORDER := $(extmod_prefix)modules.or 1090 export MODORDER := $(extmod_prefix)modules.order 1094 export MODULES_NSDEPS := $(extmod_prefix)modu 1091 export MODULES_NSDEPS := $(extmod_prefix)modules.nsdeps 1095 1092 1096 ifeq ($(KBUILD_EXTMOD),) 1093 ifeq ($(KBUILD_EXTMOD),) 1097 1094 1098 build-dir := . 1095 build-dir := . 1099 clean-dirs := $(sort . Documentation \ 1096 clean-dirs := $(sort . Documentation \ 1100 $(patsubst %/,%,$(filter 1097 $(patsubst %/,%,$(filter %/, $(core-) \ 1101 $(drivers-) $(libs-)) 1098 $(drivers-) $(libs-)))) 1102 1099 1103 export ARCH_CORE := $(core-y) 1100 export ARCH_CORE := $(core-y) 1104 export ARCH_LIB := $(filter %/, $(lib 1101 export ARCH_LIB := $(filter %/, $(libs-y)) 1105 export ARCH_DRIVERS := $(drivers-y) $(dri 1102 export ARCH_DRIVERS := $(drivers-y) $(drivers-m) 1106 # Externally visible symbols (used by link-vm 1103 # Externally visible symbols (used by link-vmlinux.sh) 1107 1104 1108 KBUILD_VMLINUX_OBJS := ./built-in.a 1105 KBUILD_VMLINUX_OBJS := ./built-in.a 1109 ifdef CONFIG_MODULES 1106 ifdef CONFIG_MODULES 1110 KBUILD_VMLINUX_OBJS += $(patsubst %/, %/lib.a 1107 KBUILD_VMLINUX_OBJS += $(patsubst %/, %/lib.a, $(filter %/, $(libs-y))) 1111 KBUILD_VMLINUX_LIBS := $(filter-out %/, $(lib 1108 KBUILD_VMLINUX_LIBS := $(filter-out %/, $(libs-y)) 1112 else 1109 else 1113 KBUILD_VMLINUX_LIBS := $(patsubst %/,%/lib.a, 1110 KBUILD_VMLINUX_LIBS := $(patsubst %/,%/lib.a, $(libs-y)) 1114 endif 1111 endif 1115 1112 1116 export KBUILD_VMLINUX_LIBS 1113 export KBUILD_VMLINUX_LIBS 1117 export KBUILD_LDS := arch/$(SRCARCH) 1114 export KBUILD_LDS := arch/$(SRCARCH)/kernel/vmlinux.lds 1118 1115 1119 ifdef CONFIG_TRIM_UNUSED_KSYMS 1116 ifdef CONFIG_TRIM_UNUSED_KSYMS 1120 # For the kernel to actually contain only the 1117 # For the kernel to actually contain only the needed exported symbols, 1121 # we have to build modules as well to determi 1118 # we have to build modules as well to determine what those symbols are. 1122 KBUILD_MODULES := 1 1119 KBUILD_MODULES := 1 1123 endif 1120 endif 1124 1121 1125 # '$(AR) mPi' needs 'T' to workaround the bug 1122 # '$(AR) mPi' needs 'T' to workaround the bug of llvm-ar <= 14 1126 quiet_cmd_ar_vmlinux.a = AR $@ 1123 quiet_cmd_ar_vmlinux.a = AR $@ 1127 cmd_ar_vmlinux.a = \ 1124 cmd_ar_vmlinux.a = \ 1128 rm -f $@; \ 1125 rm -f $@; \ 1129 $(AR) cDPrST $@ $(KBUILD_VMLINUX_OBJS 1126 $(AR) cDPrST $@ $(KBUILD_VMLINUX_OBJS); \ 1130 $(AR) mPiT $$($(AR) t $@ | sed -n 1p) 1127 $(AR) mPiT $$($(AR) t $@ | sed -n 1p) $@ $$($(AR) t $@ | grep -F -f $(srctree)/scripts/head-object-list.txt) 1131 1128 1132 targets += vmlinux.a 1129 targets += vmlinux.a 1133 vmlinux.a: $(KBUILD_VMLINUX_OBJS) scripts/hea 1130 vmlinux.a: $(KBUILD_VMLINUX_OBJS) scripts/head-object-list.txt FORCE 1134 $(call if_changed,ar_vmlinux.a) 1131 $(call if_changed,ar_vmlinux.a) 1135 1132 1136 PHONY += vmlinux_o 1133 PHONY += vmlinux_o 1137 vmlinux_o: vmlinux.a $(KBUILD_VMLINUX_LIBS) 1134 vmlinux_o: vmlinux.a $(KBUILD_VMLINUX_LIBS) 1138 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1135 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.vmlinux_o 1139 1136 1140 vmlinux.o modules.builtin.modinfo modules.bui 1137 vmlinux.o modules.builtin.modinfo modules.builtin: vmlinux_o 1141 @: 1138 @: 1142 1139 1143 PHONY += vmlinux 1140 PHONY += vmlinux 1144 # LDFLAGS_vmlinux in the top Makefile defines 1141 # LDFLAGS_vmlinux in the top Makefile defines linker flags for the top vmlinux, 1145 # not for decompressors. LDFLAGS_vmlinux in a 1142 # not for decompressors. LDFLAGS_vmlinux in arch/*/boot/compressed/Makefile is 1146 # unrelated; the decompressors just happen to 1143 # unrelated; the decompressors just happen to have the same base name, 1147 # arch/*/boot/compressed/vmlinux. 1144 # arch/*/boot/compressed/vmlinux. 1148 # Export LDFLAGS_vmlinux only to scripts/Make 1145 # Export LDFLAGS_vmlinux only to scripts/Makefile.vmlinux. 1149 # 1146 # 1150 # _LDFLAGS_vmlinux is a workaround for the 'p 1147 # _LDFLAGS_vmlinux is a workaround for the 'private export' bug: 1151 # https://savannah.gnu.org/bugs/?61463 1148 # https://savannah.gnu.org/bugs/?61463 1152 # For Make > 4.4, the following simple code w 1149 # For Make > 4.4, the following simple code will work: 1153 # vmlinux: private export LDFLAGS_vmlinux := 1150 # vmlinux: private export LDFLAGS_vmlinux := $(LDFLAGS_vmlinux) 1154 vmlinux: private _LDFLAGS_vmlinux := $(LDFLAG 1151 vmlinux: private _LDFLAGS_vmlinux := $(LDFLAGS_vmlinux) 1155 vmlinux: export LDFLAGS_vmlinux = $(_LDFLAGS_ 1152 vmlinux: export LDFLAGS_vmlinux = $(_LDFLAGS_vmlinux) 1156 vmlinux: vmlinux.o $(KBUILD_LDS) modpost 1153 vmlinux: vmlinux.o $(KBUILD_LDS) modpost 1157 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1154 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.vmlinux 1158 1155 1159 # The actual objects are generated when desce 1156 # The actual objects are generated when descending, 1160 # make sure no implicit rule kicks in 1157 # make sure no implicit rule kicks in 1161 $(sort $(KBUILD_LDS) $(KBUILD_VMLINUX_OBJS) $ 1158 $(sort $(KBUILD_LDS) $(KBUILD_VMLINUX_OBJS) $(KBUILD_VMLINUX_LIBS)): . ; 1162 1159 1163 ifeq ($(origin KERNELRELEASE),file) 1160 ifeq ($(origin KERNELRELEASE),file) 1164 filechk_kernel.release = $(srctree)/scripts/s 1161 filechk_kernel.release = $(srctree)/scripts/setlocalversion $(srctree) 1165 else 1162 else 1166 filechk_kernel.release = echo $(KERNELRELEASE 1163 filechk_kernel.release = echo $(KERNELRELEASE) 1167 endif 1164 endif 1168 1165 1169 # Store (new) KERNELRELEASE string in include 1166 # Store (new) KERNELRELEASE string in include/config/kernel.release 1170 include/config/kernel.release: FORCE 1167 include/config/kernel.release: FORCE 1171 $(call filechk,kernel.release) 1168 $(call filechk,kernel.release) 1172 1169 1173 # Additional helpers built in scripts/ 1170 # Additional helpers built in scripts/ 1174 # Carefully list dependencies so we do not tr 1171 # Carefully list dependencies so we do not try to build scripts twice 1175 # in parallel 1172 # in parallel 1176 PHONY += scripts 1173 PHONY += scripts 1177 scripts: scripts_basic scripts_dtc 1174 scripts: scripts_basic scripts_dtc 1178 $(Q)$(MAKE) $(build)=$(@) 1175 $(Q)$(MAKE) $(build)=$(@) 1179 1176 1180 # Things we need to do before we recursively 1177 # Things we need to do before we recursively start building the kernel 1181 # or the modules are listed in "prepare". 1178 # or the modules are listed in "prepare". 1182 # A multi level approach is used. prepareN is 1179 # A multi level approach is used. prepareN is processed before prepareN-1. 1183 # archprepare is used in arch Makefiles and w 1180 # archprepare is used in arch Makefiles and when processed asm symlink, 1184 # version.h and scripts_basic is processed / 1181 # version.h and scripts_basic is processed / created. 1185 1182 1186 PHONY += prepare archprepare 1183 PHONY += prepare archprepare 1187 1184 1188 archprepare: outputmakefile archheaders archs 1185 archprepare: outputmakefile archheaders archscripts scripts include/config/kernel.release \ 1189 asm-generic $(version_h) include/gene 1186 asm-generic $(version_h) include/generated/utsrelease.h \ 1190 include/generated/compile.h include/g 1187 include/generated/compile.h include/generated/autoconf.h remove-stale-files 1191 1188 1192 prepare0: archprepare 1189 prepare0: archprepare 1193 $(Q)$(MAKE) $(build)=scripts/mod 1190 $(Q)$(MAKE) $(build)=scripts/mod 1194 $(Q)$(MAKE) $(build)=. prepare 1191 $(Q)$(MAKE) $(build)=. prepare 1195 1192 1196 # All the preparing.. 1193 # All the preparing.. 1197 prepare: prepare0 1194 prepare: prepare0 1198 ifdef CONFIG_RUST 1195 ifdef CONFIG_RUST 1199 +$(Q)$(CONFIG_SHELL) $(srctree)/scrip !! 1196 $(Q)$(CONFIG_SHELL) $(srctree)/scripts/rust_is_available.sh 1200 $(Q)$(MAKE) $(build)=rust 1197 $(Q)$(MAKE) $(build)=rust 1201 endif 1198 endif 1202 1199 1203 PHONY += remove-stale-files 1200 PHONY += remove-stale-files 1204 remove-stale-files: 1201 remove-stale-files: 1205 $(Q)$(srctree)/scripts/remove-stale-f 1202 $(Q)$(srctree)/scripts/remove-stale-files 1206 1203 1207 # Support for using generic headers in asm-ge 1204 # Support for using generic headers in asm-generic 1208 asm-generic := -f $(srctree)/scripts/Makefile !! 1205 asm-generic := -f $(srctree)/scripts/Makefile.asm-generic obj 1209 1206 1210 PHONY += asm-generic uapi-asm-generic 1207 PHONY += asm-generic uapi-asm-generic 1211 asm-generic: uapi-asm-generic 1208 asm-generic: uapi-asm-generic 1212 $(Q)$(MAKE) $(asm-generic)=arch/$(SRC 1209 $(Q)$(MAKE) $(asm-generic)=arch/$(SRCARCH)/include/generated/asm \ 1213 generic=include/asm-generic 1210 generic=include/asm-generic 1214 uapi-asm-generic: 1211 uapi-asm-generic: 1215 $(Q)$(MAKE) $(asm-generic)=arch/$(SRC 1212 $(Q)$(MAKE) $(asm-generic)=arch/$(SRCARCH)/include/generated/uapi/asm \ 1216 generic=include/uapi/asm-generic 1213 generic=include/uapi/asm-generic 1217 1214 1218 # Generate some files 1215 # Generate some files 1219 # ------------------------------------------- 1216 # --------------------------------------------------------------------------- 1220 1217 1221 # KERNELRELEASE can change from a few differe 1218 # KERNELRELEASE can change from a few different places, meaning version.h 1222 # needs to be updated, so this check is force 1219 # needs to be updated, so this check is forced on all builds 1223 1220 1224 uts_len := 64 1221 uts_len := 64 1225 define filechk_utsrelease.h 1222 define filechk_utsrelease.h 1226 if [ `echo -n "$(KERNELRELEASE)" | wc 1223 if [ `echo -n "$(KERNELRELEASE)" | wc -c ` -gt $(uts_len) ]; then \ 1227 echo '"$(KERNELRELEASE)" exceeds $( 1224 echo '"$(KERNELRELEASE)" exceeds $(uts_len) characters' >&2; \ 1228 exit 1; 1225 exit 1; \ 1229 fi; 1226 fi; \ 1230 echo \#define UTS_RELEASE \"$(KERNELR 1227 echo \#define UTS_RELEASE \"$(KERNELRELEASE)\" 1231 endef 1228 endef 1232 1229 1233 define filechk_version.h 1230 define filechk_version.h 1234 if [ $(SUBLEVEL) -gt 255 ]; then 1231 if [ $(SUBLEVEL) -gt 255 ]; then \ 1235 echo \#define LINUX_VERSION_C 1232 echo \#define LINUX_VERSION_CODE $(shell \ 1236 expr $(VERSION) \* 65536 + $( 1233 expr $(VERSION) \* 65536 + $(PATCHLEVEL) \* 256 + 255); \ 1237 else 1234 else \ 1238 echo \#define LINUX_VERSION_C 1235 echo \#define LINUX_VERSION_CODE $(shell \ 1239 expr $(VERSION) \* 65536 + $( 1236 expr $(VERSION) \* 65536 + $(PATCHLEVEL) \* 256 + $(SUBLEVEL)); \ 1240 fi; 1237 fi; \ 1241 echo '#define KERNEL_VERSION(a,b,c) ( 1238 echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + \ 1242 ((c) > 255 ? 255 : (c)))'; 1239 ((c) > 255 ? 255 : (c)))'; \ 1243 echo \#define LINUX_VERSION_MAJOR $(V 1240 echo \#define LINUX_VERSION_MAJOR $(VERSION); \ 1244 echo \#define LINUX_VERSION_PATCHLEVE 1241 echo \#define LINUX_VERSION_PATCHLEVEL $(PATCHLEVEL); \ 1245 echo \#define LINUX_VERSION_SUBLEVEL 1242 echo \#define LINUX_VERSION_SUBLEVEL $(SUBLEVEL) 1246 endef 1243 endef 1247 1244 1248 $(version_h): private PATCHLEVEL := $(or $(PA !! 1245 $(version_h): PATCHLEVEL := $(or $(PATCHLEVEL), 0) 1249 $(version_h): private SUBLEVEL := $(or $(SUBL !! 1246 $(version_h): SUBLEVEL := $(or $(SUBLEVEL), 0) 1250 $(version_h): FORCE 1247 $(version_h): FORCE 1251 $(call filechk,version.h) 1248 $(call filechk,version.h) 1252 1249 1253 include/generated/utsrelease.h: include/confi 1250 include/generated/utsrelease.h: include/config/kernel.release FORCE 1254 $(call filechk,utsrelease.h) 1251 $(call filechk,utsrelease.h) 1255 1252 1256 filechk_compile.h = $(srctree)/scripts/mkcomp 1253 filechk_compile.h = $(srctree)/scripts/mkcompile_h \ 1257 "$(UTS_MACHINE)" "$(CONFIG_CC_VERSION 1254 "$(UTS_MACHINE)" "$(CONFIG_CC_VERSION_TEXT)" "$(LD)" 1258 1255 1259 include/generated/compile.h: FORCE 1256 include/generated/compile.h: FORCE 1260 $(call filechk,compile.h) 1257 $(call filechk,compile.h) 1261 1258 1262 PHONY += headerdep 1259 PHONY += headerdep 1263 headerdep: 1260 headerdep: 1264 $(Q)find $(srctree)/include/ -name '* 1261 $(Q)find $(srctree)/include/ -name '*.h' | xargs --max-args 1 \ 1265 $(srctree)/scripts/headerdep.pl -I$(s 1262 $(srctree)/scripts/headerdep.pl -I$(srctree)/include 1266 1263 1267 # ------------------------------------------- 1264 # --------------------------------------------------------------------------- 1268 # Kernel headers 1265 # Kernel headers 1269 1266 1270 #Default location for installed headers 1267 #Default location for installed headers 1271 export INSTALL_HDR_PATH = $(objtree)/usr 1268 export INSTALL_HDR_PATH = $(objtree)/usr 1272 1269 1273 quiet_cmd_headers_install = INSTALL $(INSTALL 1270 quiet_cmd_headers_install = INSTALL $(INSTALL_HDR_PATH)/include 1274 cmd_headers_install = \ 1271 cmd_headers_install = \ 1275 mkdir -p $(INSTALL_HDR_PATH); \ 1272 mkdir -p $(INSTALL_HDR_PATH); \ 1276 rsync -mrl --include='*/' --include=' 1273 rsync -mrl --include='*/' --include='*\.h' --exclude='*' \ 1277 usr/include $(INSTALL_HDR_PATH) 1274 usr/include $(INSTALL_HDR_PATH) 1278 1275 1279 PHONY += headers_install 1276 PHONY += headers_install 1280 headers_install: headers 1277 headers_install: headers 1281 $(call cmd,headers_install) 1278 $(call cmd,headers_install) 1282 1279 1283 PHONY += archheaders archscripts 1280 PHONY += archheaders archscripts 1284 1281 1285 hdr-inst := -f $(srctree)/scripts/Makefile.he 1282 hdr-inst := -f $(srctree)/scripts/Makefile.headersinst obj 1286 1283 1287 PHONY += headers 1284 PHONY += headers 1288 headers: $(version_h) scripts_unifdef uapi-as 1285 headers: $(version_h) scripts_unifdef uapi-asm-generic archheaders archscripts 1289 $(if $(filter um, $(SRCARCH)), $(erro 1286 $(if $(filter um, $(SRCARCH)), $(error Headers not exportable for UML)) 1290 $(Q)$(MAKE) $(hdr-inst)=include/uapi 1287 $(Q)$(MAKE) $(hdr-inst)=include/uapi 1291 $(Q)$(MAKE) $(hdr-inst)=arch/$(SRCARC 1288 $(Q)$(MAKE) $(hdr-inst)=arch/$(SRCARCH)/include/uapi 1292 1289 1293 ifdef CONFIG_HEADERS_INSTALL 1290 ifdef CONFIG_HEADERS_INSTALL 1294 prepare: headers 1291 prepare: headers 1295 endif 1292 endif 1296 1293 1297 PHONY += scripts_unifdef 1294 PHONY += scripts_unifdef 1298 scripts_unifdef: scripts_basic 1295 scripts_unifdef: scripts_basic 1299 $(Q)$(MAKE) $(build)=scripts scripts/ 1296 $(Q)$(MAKE) $(build)=scripts scripts/unifdef 1300 1297 1301 # ------------------------------------------- 1298 # --------------------------------------------------------------------------- 1302 # Install 1299 # Install 1303 1300 1304 # Many distributions have the custom install 1301 # Many distributions have the custom install script, /sbin/installkernel. 1305 # If DKMS is installed, 'make install' will e 1302 # If DKMS is installed, 'make install' will eventually recurse back 1306 # to this Makefile to build and install exter 1303 # to this Makefile to build and install external modules. 1307 # Cancel sub_make_done so that options such a 1304 # Cancel sub_make_done so that options such as M=, V=, etc. are parsed. 1308 1305 1309 quiet_cmd_install = INSTALL $(INSTALL_PATH) 1306 quiet_cmd_install = INSTALL $(INSTALL_PATH) 1310 cmd_install = unset sub_make_done; $(sr 1307 cmd_install = unset sub_make_done; $(srctree)/scripts/install.sh 1311 1308 1312 # ------------------------------------------- 1309 # --------------------------------------------------------------------------- 1313 # vDSO install 1310 # vDSO install 1314 1311 1315 PHONY += vdso_install 1312 PHONY += vdso_install 1316 vdso_install: export INSTALL_FILES = $(vdso-i 1313 vdso_install: export INSTALL_FILES = $(vdso-install-y) 1317 vdso_install: 1314 vdso_install: 1318 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1315 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.vdsoinst 1319 1316 1320 # ------------------------------------------- 1317 # --------------------------------------------------------------------------- 1321 # Tools 1318 # Tools 1322 1319 1323 ifdef CONFIG_OBJTOOL 1320 ifdef CONFIG_OBJTOOL 1324 prepare: tools/objtool 1321 prepare: tools/objtool 1325 endif 1322 endif 1326 1323 1327 ifdef CONFIG_BPF 1324 ifdef CONFIG_BPF 1328 ifdef CONFIG_DEBUG_INFO_BTF 1325 ifdef CONFIG_DEBUG_INFO_BTF 1329 prepare: tools/bpf/resolve_btfids 1326 prepare: tools/bpf/resolve_btfids 1330 endif 1327 endif 1331 endif 1328 endif 1332 1329 1333 # The tools build system is not a part of Kbu << 1334 # its own unique issues. If you need to integ << 1335 # please consider locating that tool outside << 1336 # standard Kbuild "hostprogs" syntax instead << 1337 # here. See Documentation/kbuild/makefiles.rs << 1338 << 1339 PHONY += resolve_btfids_clean 1330 PHONY += resolve_btfids_clean 1340 1331 1341 resolve_btfids_O = $(abspath $(objtree))/tool 1332 resolve_btfids_O = $(abspath $(objtree))/tools/bpf/resolve_btfids 1342 1333 1343 # tools/bpf/resolve_btfids directory might no 1334 # tools/bpf/resolve_btfids directory might not exist 1344 # in output directory, skip its clean in that 1335 # in output directory, skip its clean in that case 1345 resolve_btfids_clean: 1336 resolve_btfids_clean: 1346 ifneq ($(wildcard $(resolve_btfids_O)),) 1337 ifneq ($(wildcard $(resolve_btfids_O)),) 1347 $(Q)$(MAKE) -sC $(srctree)/tools/bpf/ 1338 $(Q)$(MAKE) -sC $(srctree)/tools/bpf/resolve_btfids O=$(resolve_btfids_O) clean 1348 endif 1339 endif 1349 1340 1350 # Clear a bunch of variables before executing 1341 # Clear a bunch of variables before executing the submake 1351 ifeq ($(quiet),silent_) 1342 ifeq ($(quiet),silent_) 1352 tools_silent=s 1343 tools_silent=s 1353 endif 1344 endif 1354 1345 1355 tools/: FORCE 1346 tools/: FORCE 1356 $(Q)mkdir -p $(objtree)/tools 1347 $(Q)mkdir -p $(objtree)/tools 1357 $(Q)$(MAKE) LDFLAGS= MAKEFLAGS="$(too 1348 $(Q)$(MAKE) LDFLAGS= MAKEFLAGS="$(tools_silent) $(filter --j% -j,$(MAKEFLAGS))" O=$(abspath $(objtree)) subdir=tools -C $(srctree)/tools/ 1358 1349 1359 tools/%: FORCE 1350 tools/%: FORCE 1360 $(Q)mkdir -p $(objtree)/tools 1351 $(Q)mkdir -p $(objtree)/tools 1361 $(Q)$(MAKE) LDFLAGS= MAKEFLAGS="$(too 1352 $(Q)$(MAKE) LDFLAGS= MAKEFLAGS="$(tools_silent) $(filter --j% -j,$(MAKEFLAGS))" O=$(abspath $(objtree)) subdir=tools -C $(srctree)/tools/ $* 1362 1353 1363 # ------------------------------------------- 1354 # --------------------------------------------------------------------------- 1364 # Kernel selftest 1355 # Kernel selftest 1365 1356 1366 PHONY += kselftest 1357 PHONY += kselftest 1367 kselftest: headers 1358 kselftest: headers 1368 $(Q)$(MAKE) -C $(srctree)/tools/testi 1359 $(Q)$(MAKE) -C $(srctree)/tools/testing/selftests run_tests 1369 1360 1370 kselftest-%: headers FORCE 1361 kselftest-%: headers FORCE 1371 $(Q)$(MAKE) -C $(srctree)/tools/testi 1362 $(Q)$(MAKE) -C $(srctree)/tools/testing/selftests $* 1372 1363 1373 PHONY += kselftest-merge 1364 PHONY += kselftest-merge 1374 kselftest-merge: 1365 kselftest-merge: 1375 $(if $(wildcard $(objtree)/.config),, 1366 $(if $(wildcard $(objtree)/.config),, $(error No .config exists, config your kernel first!)) 1376 $(Q)find $(srctree)/tools/testing/sel 1367 $(Q)find $(srctree)/tools/testing/selftests -name config -o -name config.$(UTS_MACHINE) | \ 1377 xargs $(srctree)/scripts/kcon 1368 xargs $(srctree)/scripts/kconfig/merge_config.sh -y -m $(objtree)/.config 1378 $(Q)$(MAKE) -f $(srctree)/Makefile ol 1369 $(Q)$(MAKE) -f $(srctree)/Makefile olddefconfig 1379 1370 1380 # ------------------------------------------- 1371 # --------------------------------------------------------------------------- 1381 # Devicetree files 1372 # Devicetree files 1382 1373 1383 ifneq ($(wildcard $(srctree)/arch/$(SRCARCH)/ 1374 ifneq ($(wildcard $(srctree)/arch/$(SRCARCH)/boot/dts/),) 1384 dtstree := arch/$(SRCARCH)/boot/dts 1375 dtstree := arch/$(SRCARCH)/boot/dts 1385 endif 1376 endif 1386 1377 1387 ifneq ($(dtstree),) 1378 ifneq ($(dtstree),) 1388 1379 1389 %.dtb: dtbs_prepare 1380 %.dtb: dtbs_prepare 1390 $(Q)$(MAKE) $(build)=$(dtstree) $(dts 1381 $(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@ 1391 1382 1392 %.dtbo: dtbs_prepare 1383 %.dtbo: dtbs_prepare 1393 $(Q)$(MAKE) $(build)=$(dtstree) $(dts 1384 $(Q)$(MAKE) $(build)=$(dtstree) $(dtstree)/$@ 1394 1385 1395 PHONY += dtbs dtbs_prepare dtbs_install dtbs_ 1386 PHONY += dtbs dtbs_prepare dtbs_install dtbs_check 1396 dtbs: dtbs_prepare 1387 dtbs: dtbs_prepare 1397 $(Q)$(MAKE) $(build)=$(dtstree) need- !! 1388 $(Q)$(MAKE) $(build)=$(dtstree) 1398 1389 1399 # include/config/kernel.release is actually n 1390 # include/config/kernel.release is actually needed when installing DTBs because 1400 # INSTALL_DTBS_PATH contains $(KERNELRELEASE) 1391 # INSTALL_DTBS_PATH contains $(KERNELRELEASE). However, we do not want to make 1401 # dtbs_install depend on it as dtbs_install m 1392 # dtbs_install depend on it as dtbs_install may run as root. 1402 dtbs_prepare: include/config/kernel.release s 1393 dtbs_prepare: include/config/kernel.release scripts_dtc 1403 1394 1404 ifneq ($(filter dtbs_check, $(MAKECMDGOALS)), 1395 ifneq ($(filter dtbs_check, $(MAKECMDGOALS)),) 1405 export CHECK_DTBS=y 1396 export CHECK_DTBS=y 1406 endif 1397 endif 1407 1398 1408 ifneq ($(CHECK_DTBS),) 1399 ifneq ($(CHECK_DTBS),) 1409 dtbs_prepare: dt_binding_schemas !! 1400 dtbs_prepare: dt_binding_check 1410 endif 1401 endif 1411 1402 1412 dtbs_check: dtbs 1403 dtbs_check: dtbs 1413 1404 1414 dtbs_install: 1405 dtbs_install: 1415 $(Q)$(MAKE) -f $(srctree)/scripts/Mak !! 1406 $(Q)$(MAKE) $(dtbinst)=$(dtstree) dst=$(INSTALL_DTBS_PATH) 1416 1407 1417 ifdef CONFIG_OF_EARLY_FLATTREE 1408 ifdef CONFIG_OF_EARLY_FLATTREE 1418 all: dtbs 1409 all: dtbs 1419 endif 1410 endif 1420 1411 1421 endif 1412 endif 1422 1413 1423 PHONY += scripts_dtc 1414 PHONY += scripts_dtc 1424 scripts_dtc: scripts_basic 1415 scripts_dtc: scripts_basic 1425 $(Q)$(MAKE) $(build)=scripts/dtc 1416 $(Q)$(MAKE) $(build)=scripts/dtc 1426 1417 1427 ifneq ($(filter dt_binding_check, $(MAKECMDGO 1418 ifneq ($(filter dt_binding_check, $(MAKECMDGOALS)),) 1428 export CHECK_DTBS=y !! 1419 export CHECK_DT_BINDING=y 1429 endif 1420 endif 1430 1421 1431 PHONY += dt_binding_check dt_binding_schemas !! 1422 PHONY += dt_binding_check 1432 dt_binding_check: dt_binding_schemas scripts_ !! 1423 dt_binding_check: scripts_dtc 1433 $(Q)$(MAKE) $(build)=Documentation/de << 1434 << 1435 dt_binding_schemas: << 1436 $(Q)$(MAKE) $(build)=Documentation/de 1424 $(Q)$(MAKE) $(build)=Documentation/devicetree/bindings 1437 1425 1438 PHONY += dt_compatible_check 1426 PHONY += dt_compatible_check 1439 dt_compatible_check: dt_binding_schemas !! 1427 dt_compatible_check: dt_binding_check 1440 $(Q)$(MAKE) $(build)=Documentation/de 1428 $(Q)$(MAKE) $(build)=Documentation/devicetree/bindings $@ 1441 1429 1442 # ------------------------------------------- 1430 # --------------------------------------------------------------------------- 1443 # Modules 1431 # Modules 1444 1432 1445 ifdef CONFIG_MODULES 1433 ifdef CONFIG_MODULES 1446 1434 1447 # By default, build modules as well 1435 # By default, build modules as well 1448 1436 1449 all: modules 1437 all: modules 1450 1438 1451 # When we're building modules with modversion 1439 # When we're building modules with modversions, we need to consider 1452 # the built-in objects during the descend as 1440 # the built-in objects during the descend as well, in order to 1453 # make sure the checksums are up to date befo 1441 # make sure the checksums are up to date before we record them. 1454 ifdef CONFIG_MODVERSIONS 1442 ifdef CONFIG_MODVERSIONS 1455 KBUILD_BUILTIN := 1 1443 KBUILD_BUILTIN := 1 1456 endif 1444 endif 1457 1445 1458 # Build modules 1446 # Build modules 1459 # 1447 # 1460 1448 1461 # *.ko are usually independent of vmlinux, bu 1449 # *.ko are usually independent of vmlinux, but CONFIG_DEBUG_INFO_BTF_MODULES 1462 # is an exception. 1450 # is an exception. 1463 ifdef CONFIG_DEBUG_INFO_BTF_MODULES 1451 ifdef CONFIG_DEBUG_INFO_BTF_MODULES 1464 KBUILD_BUILTIN := 1 1452 KBUILD_BUILTIN := 1 1465 modules: vmlinux 1453 modules: vmlinux 1466 endif 1454 endif 1467 1455 1468 modules: modules_prepare 1456 modules: modules_prepare 1469 1457 1470 # Target to prepare building external modules 1458 # Target to prepare building external modules 1471 modules_prepare: prepare 1459 modules_prepare: prepare 1472 $(Q)$(MAKE) $(build)=scripts scripts/ 1460 $(Q)$(MAKE) $(build)=scripts scripts/module.lds 1473 1461 1474 endif # CONFIG_MODULES 1462 endif # CONFIG_MODULES 1475 1463 1476 ### 1464 ### 1477 # Cleaning is done on three levels. 1465 # Cleaning is done on three levels. 1478 # make clean Delete most generated files 1466 # make clean Delete most generated files 1479 # Leave enough to build extern 1467 # Leave enough to build external modules 1480 # make mrproper Delete the current configura 1468 # make mrproper Delete the current configuration, and all generated files 1481 # make distclean Remove editor backup files, 1469 # make distclean Remove editor backup files, patch leftover files and the like 1482 1470 1483 # Directories & files removed with 'make clea 1471 # Directories & files removed with 'make clean' 1484 CLEAN_FILES += vmlinux.symvers modules-only.s 1472 CLEAN_FILES += vmlinux.symvers modules-only.symvers \ 1485 modules.builtin modules.builti 1473 modules.builtin modules.builtin.modinfo modules.nsdeps \ 1486 compile_commands.json rust/tes !! 1474 compile_commands.json .thinlto-cache rust/test \ 1487 rust-project.json .vmlinux.obj 1475 rust-project.json .vmlinux.objs .vmlinux.export.c 1488 1476 1489 # Directories & files removed with 'make mrpr 1477 # Directories & files removed with 'make mrproper' 1490 MRPROPER_FILES += include/config include/gene 1478 MRPROPER_FILES += include/config include/generated \ 1491 arch/$(SRCARCH)/include/gen 1479 arch/$(SRCARCH)/include/generated .objdiff \ 1492 debian snap tar-install PKG !! 1480 debian snap tar-install \ 1493 .config .config.old .versio 1481 .config .config.old .version \ 1494 Module.symvers \ 1482 Module.symvers \ 1495 certs/signing_key.pem \ 1483 certs/signing_key.pem \ 1496 certs/x509.genkey \ 1484 certs/x509.genkey \ 1497 vmlinux-gdb.py \ 1485 vmlinux-gdb.py \ 1498 rpmbuild \ 1486 rpmbuild \ 1499 rust/libmacros.so 1487 rust/libmacros.so 1500 1488 1501 # clean - Delete most, but leave enough to bu 1489 # clean - Delete most, but leave enough to build external modules 1502 # 1490 # 1503 clean: private rm-files := $(CLEAN_FILES) !! 1491 clean: rm-files := $(CLEAN_FILES) 1504 1492 1505 PHONY += archclean vmlinuxclean 1493 PHONY += archclean vmlinuxclean 1506 1494 1507 vmlinuxclean: 1495 vmlinuxclean: 1508 $(Q)$(CONFIG_SHELL) $(srctree)/script 1496 $(Q)$(CONFIG_SHELL) $(srctree)/scripts/link-vmlinux.sh clean 1509 $(Q)$(if $(ARCH_POSTLINK), $(MAKE) -f 1497 $(Q)$(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) clean) 1510 1498 1511 clean: archclean vmlinuxclean resolve_btfids_ 1499 clean: archclean vmlinuxclean resolve_btfids_clean 1512 1500 1513 # mrproper - Delete all generated files, incl 1501 # mrproper - Delete all generated files, including .config 1514 # 1502 # 1515 mrproper: private rm-files := $(MRPROPER_FILE !! 1503 mrproper: rm-files := $(wildcard $(MRPROPER_FILES)) 1516 mrproper-dirs := $(addprefix _mrproper_, 1504 mrproper-dirs := $(addprefix _mrproper_,scripts) 1517 1505 1518 PHONY += $(mrproper-dirs) mrproper 1506 PHONY += $(mrproper-dirs) mrproper 1519 $(mrproper-dirs): 1507 $(mrproper-dirs): 1520 $(Q)$(MAKE) $(clean)=$(patsubst _mrpr 1508 $(Q)$(MAKE) $(clean)=$(patsubst _mrproper_%,%,$@) 1521 1509 1522 mrproper: clean $(mrproper-dirs) 1510 mrproper: clean $(mrproper-dirs) 1523 $(call cmd,rmfiles) 1511 $(call cmd,rmfiles) 1524 @find . $(RCS_FIND_IGNORE) \ 1512 @find . $(RCS_FIND_IGNORE) \ 1525 \( -name '*.rmeta' \) \ 1513 \( -name '*.rmeta' \) \ 1526 -type f -print | xargs rm -f 1514 -type f -print | xargs rm -f 1527 1515 1528 # distclean 1516 # distclean 1529 # 1517 # 1530 PHONY += distclean 1518 PHONY += distclean 1531 1519 1532 distclean: mrproper 1520 distclean: mrproper 1533 @find . $(RCS_FIND_IGNORE) \ 1521 @find . $(RCS_FIND_IGNORE) \ 1534 \( -name '*.orig' -o -name '* 1522 \( -name '*.orig' -o -name '*.rej' -o -name '*~' \ 1535 -o -name '*.bak' -o -name '#* 1523 -o -name '*.bak' -o -name '#*#' -o -name '*%' \ 1536 -o -name 'core' -o -name tags 1524 -o -name 'core' -o -name tags -o -name TAGS -o -name 'cscope*' \ 1537 -o -name GPATH -o -name GRTAG 1525 -o -name GPATH -o -name GRTAGS -o -name GSYMS -o -name GTAGS \) \ 1538 -type f -print | xargs rm -f 1526 -type f -print | xargs rm -f 1539 1527 1540 1528 1541 # Packaging of the kernel to various formats 1529 # Packaging of the kernel to various formats 1542 # ------------------------------------------- 1530 # --------------------------------------------------------------------------- 1543 1531 1544 %src-pkg: FORCE 1532 %src-pkg: FORCE 1545 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1533 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.package $@ 1546 %pkg: include/config/kernel.release FORCE 1534 %pkg: include/config/kernel.release FORCE 1547 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1535 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.package $@ 1548 1536 1549 # Brief documentation of the typical targets 1537 # Brief documentation of the typical targets used 1550 # ------------------------------------------- 1538 # --------------------------------------------------------------------------- 1551 1539 1552 boards := $(wildcard $(srctree)/arch/$(SRCARC 1540 boards := $(wildcard $(srctree)/arch/$(SRCARCH)/configs/*_defconfig) 1553 boards := $(sort $(notdir $(boards))) 1541 boards := $(sort $(notdir $(boards))) 1554 board-dirs := $(dir $(wildcard $(srctree)/arc 1542 board-dirs := $(dir $(wildcard $(srctree)/arch/$(SRCARCH)/configs/*/*_defconfig)) 1555 board-dirs := $(sort $(notdir $(board-dirs:/= 1543 board-dirs := $(sort $(notdir $(board-dirs:/=))) 1556 1544 1557 PHONY += help 1545 PHONY += help 1558 help: 1546 help: 1559 @echo 'Cleaning targets:' 1547 @echo 'Cleaning targets:' 1560 @echo ' clean - Remove mo 1548 @echo ' clean - Remove most generated files but keep the config and' 1561 @echo ' enough bu 1549 @echo ' enough build support to build external modules' 1562 @echo ' mrproper - Remove al 1550 @echo ' mrproper - Remove all generated files + config + various backup files' 1563 @echo ' distclean - mrproper 1551 @echo ' distclean - mrproper + remove editor backup and patch files' 1564 @echo '' 1552 @echo '' 1565 @$(MAKE) -f $(srctree)/scripts/kconfi 1553 @$(MAKE) -f $(srctree)/scripts/kconfig/Makefile help 1566 @echo '' 1554 @echo '' 1567 @echo 'Other generic targets:' 1555 @echo 'Other generic targets:' 1568 @echo ' all - Build all 1556 @echo ' all - Build all targets marked with [*]' 1569 @echo '* vmlinux - Build the 1557 @echo '* vmlinux - Build the bare kernel' 1570 @echo '* modules - Build all 1558 @echo '* modules - Build all modules' 1571 @echo ' modules_install - Install a 1559 @echo ' modules_install - Install all modules to INSTALL_MOD_PATH (default: /)' 1572 @echo ' vdso_install - Install u 1560 @echo ' vdso_install - Install unstripped vdso to INSTALL_MOD_PATH (default: /)' 1573 @echo ' dir/ - Build all 1561 @echo ' dir/ - Build all files in dir and below' 1574 @echo ' dir/file.[ois] - Build spe 1562 @echo ' dir/file.[ois] - Build specified target only' 1575 @echo ' dir/file.ll - Build the 1563 @echo ' dir/file.ll - Build the LLVM assembly file' 1576 @echo ' (requires 1564 @echo ' (requires compiler support for LLVM assembly generation)' 1577 @echo ' dir/file.lst - Build spe 1565 @echo ' dir/file.lst - Build specified mixed source/assembly target only' 1578 @echo ' (requires 1566 @echo ' (requires a recent binutils and recent build (System.map))' 1579 @echo ' dir/file.ko - Build mod 1567 @echo ' dir/file.ko - Build module including final link' 1580 @echo ' modules_prepare - Set up fo 1568 @echo ' modules_prepare - Set up for building external modules' 1581 @echo ' tags/TAGS - Generate 1569 @echo ' tags/TAGS - Generate tags file for editors' 1582 @echo ' cscope - Generate 1570 @echo ' cscope - Generate cscope index' 1583 @echo ' gtags - Generate 1571 @echo ' gtags - Generate GNU GLOBAL index' 1584 @echo ' kernelrelease - Output th 1572 @echo ' kernelrelease - Output the release version string (use with make -s)' 1585 @echo ' kernelversion - Output th 1573 @echo ' kernelversion - Output the version stored in Makefile (use with make -s)' 1586 @echo ' image_name - Output th 1574 @echo ' image_name - Output the image name (use with make -s)' 1587 @echo ' headers_install - Install s 1575 @echo ' headers_install - Install sanitised kernel headers to INSTALL_HDR_PATH'; \ 1588 echo ' (default: 1576 echo ' (default: $(INSTALL_HDR_PATH))'; \ 1589 echo '' 1577 echo '' 1590 @echo 'Static analysers:' 1578 @echo 'Static analysers:' 1591 @echo ' checkstack - Generate !! 1579 @echo ' checkstack - Generate a list of stack hogs' 1592 @echo ' with a st << 1593 @echo ' versioncheck - Sanity ch 1580 @echo ' versioncheck - Sanity check on version.h usage' 1594 @echo ' includecheck - Check for 1581 @echo ' includecheck - Check for duplicate included header files' 1595 @echo ' export_report - List the 1582 @echo ' export_report - List the usages of all exported symbols' 1596 @echo ' headerdep - Detect in 1583 @echo ' headerdep - Detect inclusion cycles in headers' 1597 @echo ' coccicheck - Check wit 1584 @echo ' coccicheck - Check with Coccinelle' 1598 @echo ' clang-analyzer - Check wit 1585 @echo ' clang-analyzer - Check with clang static analyzer' 1599 @echo ' clang-tidy - Check wit 1586 @echo ' clang-tidy - Check with clang-tidy' 1600 @echo '' 1587 @echo '' 1601 @echo 'Tools:' 1588 @echo 'Tools:' 1602 @echo ' nsdeps - Generate 1589 @echo ' nsdeps - Generate missing symbol namespace dependencies' 1603 @echo '' 1590 @echo '' 1604 @echo 'Kernel selftest:' 1591 @echo 'Kernel selftest:' 1605 @echo ' kselftest - Build a 1592 @echo ' kselftest - Build and run kernel selftest' 1606 @echo ' Build, 1593 @echo ' Build, install, and boot kernel before' 1607 @echo ' running 1594 @echo ' running kselftest on it' 1608 @echo ' Run as 1595 @echo ' Run as root for full coverage' 1609 @echo ' kselftest-all - Build k 1596 @echo ' kselftest-all - Build kernel selftest' 1610 @echo ' kselftest-install - Build a 1597 @echo ' kselftest-install - Build and install kernel selftest' 1611 @echo ' kselftest-clean - Remove 1598 @echo ' kselftest-clean - Remove all generated kselftest files' 1612 @echo ' kselftest-merge - Merge a 1599 @echo ' kselftest-merge - Merge all the config dependencies of' 1613 @echo ' kselfte 1600 @echo ' kselftest to existing .config.' 1614 @echo '' 1601 @echo '' 1615 @echo 'Rust targets:' 1602 @echo 'Rust targets:' 1616 @echo ' rustavailable - Checks wh 1603 @echo ' rustavailable - Checks whether the Rust toolchain is' 1617 @echo ' available 1604 @echo ' available and, if not, explains why.' 1618 @echo ' rustfmt - Reformat 1605 @echo ' rustfmt - Reformat all the Rust code in the kernel' 1619 @echo ' rustfmtcheck - Checks if 1606 @echo ' rustfmtcheck - Checks if all the Rust code in the kernel' 1620 @echo ' is format 1607 @echo ' is formatted, printing a diff otherwise.' 1621 @echo ' rustdoc - Generate 1608 @echo ' rustdoc - Generate Rust documentation' 1622 @echo ' (requires 1609 @echo ' (requires kernel .config)' 1623 @echo ' rusttest - Runs the 1610 @echo ' rusttest - Runs the Rust tests' 1624 @echo ' (requires 1611 @echo ' (requires kernel .config; downloads external repos)' 1625 @echo ' rust-analyzer - Generate 1612 @echo ' rust-analyzer - Generate rust-project.json rust-analyzer support file' 1626 @echo ' (requires 1613 @echo ' (requires kernel .config)' 1627 @echo ' dir/file.[os] - Build spe 1614 @echo ' dir/file.[os] - Build specified target only' 1628 @echo ' dir/file.rsi - Build mac 1615 @echo ' dir/file.rsi - Build macro expanded source, similar to C preprocessing.' 1629 @echo ' Run with 1616 @echo ' Run with RUSTFMT=n to skip reformatting if needed.' 1630 @echo ' The outpu 1617 @echo ' The output is not intended to be compilable.' 1631 @echo ' dir/file.ll - Build the 1618 @echo ' dir/file.ll - Build the LLVM assembly file' 1632 @echo '' 1619 @echo '' 1633 @$(if $(dtstree), \ 1620 @$(if $(dtstree), \ 1634 echo 'Devicetree:'; \ 1621 echo 'Devicetree:'; \ 1635 echo '* dtbs - !! 1622 echo '* dtbs - Build device tree blobs for enabled boards'; \ 1636 echo ' dtbs_install - !! 1623 echo ' dtbs_install - Install dtbs to $(INSTALL_DTBS_PATH)'; \ 1637 echo ' dt_binding_check - !! 1624 echo ' dt_binding_check - Validate device tree binding documents'; \ 1638 echo ' dt_binding_schema - !! 1625 echo ' dtbs_check - Validate device tree source files';\ 1639 echo ' dtbs_check - << 1640 echo '') 1626 echo '') 1641 1627 1642 @echo 'Userspace tools targets:' 1628 @echo 'Userspace tools targets:' 1643 @echo ' use "make tools/help"' 1629 @echo ' use "make tools/help"' 1644 @echo ' or "cd tools; make help"' 1630 @echo ' or "cd tools; make help"' 1645 @echo '' 1631 @echo '' 1646 @echo 'Kernel packaging:' 1632 @echo 'Kernel packaging:' 1647 @$(MAKE) -f $(srctree)/scripts/Makefi 1633 @$(MAKE) -f $(srctree)/scripts/Makefile.package help 1648 @echo '' 1634 @echo '' 1649 @echo 'Documentation targets:' 1635 @echo 'Documentation targets:' 1650 @$(MAKE) -f $(srctree)/Documentation/ 1636 @$(MAKE) -f $(srctree)/Documentation/Makefile dochelp 1651 @echo '' 1637 @echo '' 1652 @echo 'Architecture-specific targets 1638 @echo 'Architecture-specific targets ($(SRCARCH)):' 1653 @$(or $(archhelp),\ 1639 @$(or $(archhelp),\ 1654 echo ' No architecture-speci 1640 echo ' No architecture-specific help defined for $(SRCARCH)') 1655 @echo '' 1641 @echo '' 1656 @$(if $(boards), \ 1642 @$(if $(boards), \ 1657 $(foreach b, $(boards), \ 1643 $(foreach b, $(boards), \ 1658 printf " %-27s - Build for % 1644 printf " %-27s - Build for %s\\n" $(b) $(subst _defconfig,,$(b));) \ 1659 echo '') 1645 echo '') 1660 @$(if $(board-dirs), \ 1646 @$(if $(board-dirs), \ 1661 $(foreach b, $(board-dirs), \ 1647 $(foreach b, $(board-dirs), \ 1662 printf " %-16s - Show %s-spe 1648 printf " %-16s - Show %s-specific targets\\n" help-$(b) $(b);) \ 1663 printf " %-16s - Show all of 1649 printf " %-16s - Show all of the above\\n" help-boards; \ 1664 echo '') 1650 echo '') 1665 1651 1666 @echo ' make V=n [targets] 1: ver 1652 @echo ' make V=n [targets] 1: verbose build' 1667 @echo ' 2: giv 1653 @echo ' 2: give reason for rebuild of target' 1668 @echo ' V=1 an 1654 @echo ' V=1 and V=2 can be combined with V=12' 1669 @echo ' make O=dir [targets] Locate 1655 @echo ' make O=dir [targets] Locate all output files in "dir", including .config' 1670 @echo ' make C=1 [targets] Check 1656 @echo ' make C=1 [targets] Check re-compiled c source with $$CHECK' 1671 @echo ' (spars 1657 @echo ' (sparse by default)' 1672 @echo ' make C=2 [targets] Force 1658 @echo ' make C=2 [targets] Force check of all c source with $$CHECK' 1673 @echo ' make RECORDMCOUNT_WARN=1 [t 1659 @echo ' make RECORDMCOUNT_WARN=1 [targets] Warn about ignored mcount sections' 1674 @echo ' make W=n [targets] Enable !! 1660 @echo ' make W=n [targets] Enable extra build checks, n=1,2,3 where' 1675 @echo ' 1: warnings w 1661 @echo ' 1: warnings which may be relevant and do not occur too often' 1676 @echo ' 2: warnings w 1662 @echo ' 2: warnings which occur quite often but may still be relevant' 1677 @echo ' 3: more obscu 1663 @echo ' 3: more obscure warnings, can most likely be ignored' 1678 @echo ' c: extra chec << 1679 @echo ' e: warnings a 1664 @echo ' e: warnings are being treated as errors' 1680 @echo ' Multiple leve 1665 @echo ' Multiple levels can be combined with W=12 or W=123' 1681 @$(if $(dtstree), \ 1666 @$(if $(dtstree), \ 1682 echo ' make CHECK_DTBS=1 [ta 1667 echo ' make CHECK_DTBS=1 [targets] Check all generated dtb files against schema'; \ 1683 echo ' This can be ap 1668 echo ' This can be applied both to "dtbs" and to individual "foo.dtb" targets' ; \ 1684 ) 1669 ) 1685 @echo '' 1670 @echo '' 1686 @echo 'Execute "make" or "make all" 1671 @echo 'Execute "make" or "make all" to build all targets marked with [*] ' 1687 @echo 'For further info see the ./RE 1672 @echo 'For further info see the ./README file' 1688 1673 1689 1674 1690 help-board-dirs := $(addprefix help-,$(board- 1675 help-board-dirs := $(addprefix help-,$(board-dirs)) 1691 1676 1692 help-boards: $(help-board-dirs) 1677 help-boards: $(help-board-dirs) 1693 1678 1694 boards-per-dir = $(sort $(notdir $(wildcard $ 1679 boards-per-dir = $(sort $(notdir $(wildcard $(srctree)/arch/$(SRCARCH)/configs/$*/*_defconfig))) 1695 1680 1696 $(help-board-dirs): help-%: 1681 $(help-board-dirs): help-%: 1697 @echo 'Architecture-specific targets 1682 @echo 'Architecture-specific targets ($(SRCARCH) $*):' 1698 @$(if $(boards-per-dir), \ 1683 @$(if $(boards-per-dir), \ 1699 $(foreach b, $(boards-per-dir 1684 $(foreach b, $(boards-per-dir), \ 1700 printf " %-24s - Build for % 1685 printf " %-24s - Build for %s\\n" $*/$(b) $(subst _defconfig,,$(b));) \ 1701 echo '') 1686 echo '') 1702 1687 1703 1688 1704 # Documentation targets 1689 # Documentation targets 1705 # ------------------------------------------- 1690 # --------------------------------------------------------------------------- 1706 DOC_TARGETS := xmldocs latexdocs pdfdocs html 1691 DOC_TARGETS := xmldocs latexdocs pdfdocs htmldocs epubdocs cleandocs \ 1707 linkcheckdocs dochelp refcheck 1692 linkcheckdocs dochelp refcheckdocs texinfodocs infodocs 1708 PHONY += $(DOC_TARGETS) 1693 PHONY += $(DOC_TARGETS) 1709 $(DOC_TARGETS): 1694 $(DOC_TARGETS): 1710 $(Q)$(MAKE) $(build)=Documentation $@ 1695 $(Q)$(MAKE) $(build)=Documentation $@ 1711 1696 1712 1697 1713 # Rust targets 1698 # Rust targets 1714 # ------------------------------------------- 1699 # --------------------------------------------------------------------------- 1715 1700 1716 # "Is Rust available?" target 1701 # "Is Rust available?" target 1717 PHONY += rustavailable 1702 PHONY += rustavailable 1718 rustavailable: 1703 rustavailable: 1719 +$(Q)$(CONFIG_SHELL) $(srctree)/scrip !! 1704 $(Q)$(CONFIG_SHELL) $(srctree)/scripts/rust_is_available.sh && echo "Rust is available!" 1720 1705 1721 # Documentation target 1706 # Documentation target 1722 # 1707 # 1723 # Using the singular to avoid running afoul o 1708 # Using the singular to avoid running afoul of `no-dot-config-targets`. 1724 PHONY += rustdoc 1709 PHONY += rustdoc 1725 rustdoc: prepare 1710 rustdoc: prepare 1726 $(Q)$(MAKE) $(build)=rust $@ 1711 $(Q)$(MAKE) $(build)=rust $@ 1727 1712 1728 # Testing target 1713 # Testing target 1729 PHONY += rusttest 1714 PHONY += rusttest 1730 rusttest: prepare 1715 rusttest: prepare 1731 $(Q)$(MAKE) $(build)=rust $@ 1716 $(Q)$(MAKE) $(build)=rust $@ 1732 1717 1733 # Formatting targets 1718 # Formatting targets 1734 PHONY += rustfmt rustfmtcheck 1719 PHONY += rustfmt rustfmtcheck 1735 1720 1736 # We skip `rust/alloc` since we want to minim 1721 # We skip `rust/alloc` since we want to minimize the diff w.r.t. upstream. 1737 # 1722 # 1738 # We match using absolute paths since `find` 1723 # We match using absolute paths since `find` does not resolve them 1739 # when matching, which is a problem when e.g. 1724 # when matching, which is a problem when e.g. `srctree` is `..`. 1740 # We `grep` afterwards in order to remove the 1725 # We `grep` afterwards in order to remove the directory entry itself. 1741 rustfmt: 1726 rustfmt: 1742 $(Q)find $(abs_srctree) -type f -name 1727 $(Q)find $(abs_srctree) -type f -name '*.rs' \ 1743 -o -path $(abs_srctree)/rust/ 1728 -o -path $(abs_srctree)/rust/alloc -prune \ 1744 -o -path $(abs_objtree)/rust/ 1729 -o -path $(abs_objtree)/rust/test -prune \ 1745 | grep -Fv $(abs_srctree)/rus 1730 | grep -Fv $(abs_srctree)/rust/alloc \ 1746 | grep -Fv $(abs_objtree)/rus 1731 | grep -Fv $(abs_objtree)/rust/test \ 1747 | grep -Fv generated \ 1732 | grep -Fv generated \ 1748 | xargs $(RUSTFMT) $(rustfmt_ 1733 | xargs $(RUSTFMT) $(rustfmt_flags) 1749 1734 1750 rustfmtcheck: rustfmt_flags = --check 1735 rustfmtcheck: rustfmt_flags = --check 1751 rustfmtcheck: rustfmt 1736 rustfmtcheck: rustfmt 1752 1737 1753 # Misc 1738 # Misc 1754 # ------------------------------------------- 1739 # --------------------------------------------------------------------------- 1755 1740 1756 PHONY += misc-check 1741 PHONY += misc-check 1757 misc-check: 1742 misc-check: 1758 $(Q)$(srctree)/scripts/misc-check 1743 $(Q)$(srctree)/scripts/misc-check 1759 1744 1760 all: misc-check 1745 all: misc-check 1761 1746 1762 PHONY += scripts_gdb 1747 PHONY += scripts_gdb 1763 scripts_gdb: prepare0 1748 scripts_gdb: prepare0 1764 $(Q)$(MAKE) $(build)=scripts/gdb 1749 $(Q)$(MAKE) $(build)=scripts/gdb 1765 $(Q)ln -fsn $(abspath $(srctree)/scri 1750 $(Q)ln -fsn $(abspath $(srctree)/scripts/gdb/vmlinux-gdb.py) 1766 1751 1767 ifdef CONFIG_GDB_SCRIPTS 1752 ifdef CONFIG_GDB_SCRIPTS 1768 all: scripts_gdb 1753 all: scripts_gdb 1769 endif 1754 endif 1770 1755 1771 else # KBUILD_EXTMOD 1756 else # KBUILD_EXTMOD 1772 1757 1773 filechk_kernel.release = echo $(KERNELRELEASE 1758 filechk_kernel.release = echo $(KERNELRELEASE) 1774 1759 1775 ### 1760 ### 1776 # External module support. 1761 # External module support. 1777 # When building external modules the kernel u 1762 # When building external modules the kernel used as basis is considered 1778 # read-only, and no consistency checks are ma 1763 # read-only, and no consistency checks are made and the make 1779 # system is not used on the basis kernel. If 1764 # system is not used on the basis kernel. If updates are required 1780 # in the basis kernel ordinary make commands 1765 # in the basis kernel ordinary make commands (without M=...) must be used. 1781 1766 1782 # We are always building only modules. 1767 # We are always building only modules. 1783 KBUILD_BUILTIN := 1768 KBUILD_BUILTIN := 1784 KBUILD_MODULES := 1 1769 KBUILD_MODULES := 1 1785 1770 1786 build-dir := $(KBUILD_EXTMOD) 1771 build-dir := $(KBUILD_EXTMOD) 1787 1772 1788 compile_commands.json: $(extmod_prefix)compil 1773 compile_commands.json: $(extmod_prefix)compile_commands.json 1789 PHONY += compile_commands.json 1774 PHONY += compile_commands.json 1790 1775 1791 clean-dirs := $(KBUILD_EXTMOD) 1776 clean-dirs := $(KBUILD_EXTMOD) 1792 clean: private rm-files := $(KBUILD_EXTMOD)/M !! 1777 clean: rm-files := $(KBUILD_EXTMOD)/Module.symvers $(KBUILD_EXTMOD)/modules.nsdeps \ 1793 $(KBUILD_EXTMOD)/compile_commands.jso !! 1778 $(KBUILD_EXTMOD)/compile_commands.json $(KBUILD_EXTMOD)/.thinlto-cache 1794 1779 1795 PHONY += prepare 1780 PHONY += prepare 1796 # now expand this into a simple variable to r 1781 # now expand this into a simple variable to reduce the cost of shell evaluations 1797 prepare: CC_VERSION_TEXT := $(CC_VERSION_TEXT 1782 prepare: CC_VERSION_TEXT := $(CC_VERSION_TEXT) 1798 prepare: 1783 prepare: 1799 @if [ "$(CC_VERSION_TEXT)" != "$(CONF 1784 @if [ "$(CC_VERSION_TEXT)" != "$(CONFIG_CC_VERSION_TEXT)" ]; then \ 1800 echo >&2 "warning: the compil 1785 echo >&2 "warning: the compiler differs from the one used to build the kernel"; \ 1801 echo >&2 " The kernel was bu 1786 echo >&2 " The kernel was built by: $(CONFIG_CC_VERSION_TEXT)"; \ 1802 echo >&2 " You are using: 1787 echo >&2 " You are using: $(CC_VERSION_TEXT)"; \ 1803 fi 1788 fi 1804 1789 1805 PHONY += help 1790 PHONY += help 1806 help: 1791 help: 1807 @echo ' Building external modules.' 1792 @echo ' Building external modules.' 1808 @echo ' Syntax: make -C path/to/ker 1793 @echo ' Syntax: make -C path/to/kernel/src M=$$PWD target' 1809 @echo '' 1794 @echo '' 1810 @echo ' modules - default t 1795 @echo ' modules - default target, build the module(s)' 1811 @echo ' modules_install - install t 1796 @echo ' modules_install - install the module' 1812 @echo ' clean - remove ge 1797 @echo ' clean - remove generated files in module directory only' 1813 @echo ' rust-analyzer - generate 1798 @echo ' rust-analyzer - generate rust-project.json rust-analyzer support file' 1814 @echo '' 1799 @echo '' 1815 1800 1816 ifndef CONFIG_MODULES 1801 ifndef CONFIG_MODULES 1817 modules modules_install: __external_modules_e 1802 modules modules_install: __external_modules_error 1818 __external_modules_error: 1803 __external_modules_error: 1819 @echo >&2 '***' 1804 @echo >&2 '***' 1820 @echo >&2 '*** The present kernel dis 1805 @echo >&2 '*** The present kernel disabled CONFIG_MODULES.' 1821 @echo >&2 '*** You cannot build or in 1806 @echo >&2 '*** You cannot build or install external modules.' 1822 @echo >&2 '***' 1807 @echo >&2 '***' 1823 @false 1808 @false 1824 endif 1809 endif 1825 1810 1826 endif # KBUILD_EXTMOD 1811 endif # KBUILD_EXTMOD 1827 1812 1828 # ------------------------------------------- 1813 # --------------------------------------------------------------------------- 1829 # Modules 1814 # Modules 1830 1815 1831 PHONY += modules modules_install modules_sign 1816 PHONY += modules modules_install modules_sign modules_prepare 1832 1817 1833 modules_install: 1818 modules_install: 1834 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1819 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modinst \ 1835 sign-only=$(if $(filter modules_insta 1820 sign-only=$(if $(filter modules_install,$(MAKECMDGOALS)),,y) 1836 1821 1837 ifeq ($(CONFIG_MODULE_SIG),y) 1822 ifeq ($(CONFIG_MODULE_SIG),y) 1838 # modules_sign is a subset of modules_install 1823 # modules_sign is a subset of modules_install. 1839 # 'make modules_install modules_sign' is equi 1824 # 'make modules_install modules_sign' is equivalent to 'make modules_install'. 1840 modules_sign: modules_install 1825 modules_sign: modules_install 1841 @: 1826 @: 1842 else 1827 else 1843 modules_sign: 1828 modules_sign: 1844 @echo >&2 '***' 1829 @echo >&2 '***' 1845 @echo >&2 '*** CONFIG_MODULE_SIG is d 1830 @echo >&2 '*** CONFIG_MODULE_SIG is disabled. You cannot sign modules.' 1846 @echo >&2 '***' 1831 @echo >&2 '***' 1847 @false 1832 @false 1848 endif 1833 endif 1849 1834 1850 ifdef CONFIG_MODULES 1835 ifdef CONFIG_MODULES 1851 1836 1852 $(MODORDER): $(build-dir) 1837 $(MODORDER): $(build-dir) 1853 @: 1838 @: 1854 1839 1855 # KBUILD_MODPOST_NOFINAL can be set to skip t 1840 # KBUILD_MODPOST_NOFINAL can be set to skip the final link of modules. 1856 # This is solely useful to speed up test comp 1841 # This is solely useful to speed up test compiles. 1857 modules: modpost 1842 modules: modpost 1858 ifneq ($(KBUILD_MODPOST_NOFINAL),1) 1843 ifneq ($(KBUILD_MODPOST_NOFINAL),1) 1859 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1844 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modfinal 1860 endif 1845 endif 1861 1846 1862 PHONY += modules_check 1847 PHONY += modules_check 1863 modules_check: $(MODORDER) 1848 modules_check: $(MODORDER) 1864 $(Q)$(CONFIG_SHELL) $(srctree)/script 1849 $(Q)$(CONFIG_SHELL) $(srctree)/scripts/modules-check.sh $< 1865 1850 1866 else # CONFIG_MODULES 1851 else # CONFIG_MODULES 1867 1852 1868 modules: 1853 modules: 1869 @: 1854 @: 1870 1855 1871 KBUILD_MODULES := 1856 KBUILD_MODULES := 1872 1857 1873 endif # CONFIG_MODULES 1858 endif # CONFIG_MODULES 1874 1859 1875 PHONY += modpost 1860 PHONY += modpost 1876 modpost: $(if $(single-build),, $(if $(KBUILD 1861 modpost: $(if $(single-build),, $(if $(KBUILD_BUILTIN), vmlinux.o)) \ 1877 $(if $(KBUILD_MODULES), modules_chec 1862 $(if $(KBUILD_MODULES), modules_check) 1878 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1863 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost 1879 1864 1880 # Single targets 1865 # Single targets 1881 # ------------------------------------------- 1866 # --------------------------------------------------------------------------- 1882 # To build individual files in subdirectories 1867 # To build individual files in subdirectories, you can do like this: 1883 # 1868 # 1884 # make foo/bar/baz.s 1869 # make foo/bar/baz.s 1885 # 1870 # 1886 # The supported suffixes for single-target ar 1871 # The supported suffixes for single-target are listed in 'single-targets' 1887 # 1872 # 1888 # To build only under specific subdirectories 1873 # To build only under specific subdirectories, you can do like this: 1889 # 1874 # 1890 # make foo/bar/baz/ 1875 # make foo/bar/baz/ 1891 1876 1892 ifdef single-build 1877 ifdef single-build 1893 1878 1894 # .ko is special because modpost is needed 1879 # .ko is special because modpost is needed 1895 single-ko := $(sort $(filter %.ko, $(MAKECMDG 1880 single-ko := $(sort $(filter %.ko, $(MAKECMDGOALS))) 1896 single-no-ko := $(filter-out $(single-ko), $( 1881 single-no-ko := $(filter-out $(single-ko), $(MAKECMDGOALS)) \ 1897 $(foreach x, o mod, $(patsubs 1882 $(foreach x, o mod, $(patsubst %.ko, %.$x, $(single-ko))) 1898 1883 1899 $(single-ko): single_modules 1884 $(single-ko): single_modules 1900 @: 1885 @: 1901 $(single-no-ko): $(build-dir) 1886 $(single-no-ko): $(build-dir) 1902 @: 1887 @: 1903 1888 1904 # Remove MODORDER when done because it is not 1889 # Remove MODORDER when done because it is not the real one. 1905 PHONY += single_modules 1890 PHONY += single_modules 1906 single_modules: $(single-no-ko) modules_prepa 1891 single_modules: $(single-no-ko) modules_prepare 1907 $(Q){ $(foreach m, $(single-ko), echo 1892 $(Q){ $(foreach m, $(single-ko), echo $(extmod_prefix)$(m:%.ko=%.o);) } > $(MODORDER) 1908 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1893 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modpost 1909 ifneq ($(KBUILD_MODPOST_NOFINAL),1) 1894 ifneq ($(KBUILD_MODPOST_NOFINAL),1) 1910 $(Q)$(MAKE) -f $(srctree)/scripts/Mak 1895 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.modfinal 1911 endif 1896 endif 1912 $(Q)rm -f $(MODORDER) 1897 $(Q)rm -f $(MODORDER) 1913 1898 1914 single-goals := $(addprefix $(build-dir)/, $( 1899 single-goals := $(addprefix $(build-dir)/, $(single-no-ko)) 1915 1900 1916 KBUILD_MODULES := 1 1901 KBUILD_MODULES := 1 1917 1902 1918 endif 1903 endif 1919 1904 1920 # Preset locale variables to speed up the bui 1905 # Preset locale variables to speed up the build process. Limit locale 1921 # tweaks to this spot to avoid wrong language 1906 # tweaks to this spot to avoid wrong language settings when running 1922 # make menuconfig etc. 1907 # make menuconfig etc. 1923 # Error messages still appears in the origina 1908 # Error messages still appears in the original language 1924 PHONY += $(build-dir) 1909 PHONY += $(build-dir) 1925 $(build-dir): prepare 1910 $(build-dir): prepare 1926 $(Q)$(MAKE) $(build)=$@ need-builtin= 1911 $(Q)$(MAKE) $(build)=$@ need-builtin=1 need-modorder=1 $(single-goals) 1927 1912 1928 clean-dirs := $(addprefix _clean_, $(clean-di 1913 clean-dirs := $(addprefix _clean_, $(clean-dirs)) 1929 PHONY += $(clean-dirs) clean 1914 PHONY += $(clean-dirs) clean 1930 $(clean-dirs): 1915 $(clean-dirs): 1931 $(Q)$(MAKE) $(clean)=$(patsubst _clea 1916 $(Q)$(MAKE) $(clean)=$(patsubst _clean_%,%,$@) 1932 1917 1933 clean: $(clean-dirs) 1918 clean: $(clean-dirs) 1934 $(call cmd,rmfiles) 1919 $(call cmd,rmfiles) 1935 @find $(or $(KBUILD_EXTMOD), .) $(RCS 1920 @find $(or $(KBUILD_EXTMOD), .) $(RCS_FIND_IGNORE) \ 1936 \( -name '*.[aios]' -o -name 1921 \( -name '*.[aios]' -o -name '*.rsi' -o -name '*.ko' -o -name '.*.cmd' \ 1937 -o -name '*.ko.*' \ 1922 -o -name '*.ko.*' \ 1938 -o -name '*.dtb' -o -name '*. 1923 -o -name '*.dtb' -o -name '*.dtbo' \ 1939 -o -name '*.dtb.S' -o -name ' 1924 -o -name '*.dtb.S' -o -name '*.dtbo.S' \ 1940 -o -name '*.dt.yaml' -o -name !! 1925 -o -name '*.dt.yaml' \ 1941 -o -name '*.dwo' -o -name '*. 1926 -o -name '*.dwo' -o -name '*.lst' \ 1942 -o -name '*.su' -o -name '*.m 1927 -o -name '*.su' -o -name '*.mod' \ 1943 -o -name '.*.d' -o -name '.*. 1928 -o -name '.*.d' -o -name '.*.tmp' -o -name '*.mod.c' \ 1944 -o -name '*.lex.c' -o -name ' 1929 -o -name '*.lex.c' -o -name '*.tab.[ch]' \ 1945 -o -name '*.asn1.[ch]' \ 1930 -o -name '*.asn1.[ch]' \ 1946 -o -name '*.symtypes' -o -nam 1931 -o -name '*.symtypes' -o -name 'modules.order' \ 1947 -o -name '*.c.[012]*.*' \ 1932 -o -name '*.c.[012]*.*' \ 1948 -o -name '*.ll' \ 1933 -o -name '*.ll' \ 1949 -o -name '*.gcno' \ 1934 -o -name '*.gcno' \ 1950 -o -name '*.*.symversions' \) 1935 -o -name '*.*.symversions' \) -type f -print \ 1951 -o -name '.tmp_*' -print \ 1936 -o -name '.tmp_*' -print \ 1952 | xargs rm -rf 1937 | xargs rm -rf 1953 1938 1954 # Generate tags for editors 1939 # Generate tags for editors 1955 # ------------------------------------------- 1940 # --------------------------------------------------------------------------- 1956 quiet_cmd_tags = GEN $@ 1941 quiet_cmd_tags = GEN $@ 1957 cmd_tags = $(BASH) $(srctree)/scripts/t 1942 cmd_tags = $(BASH) $(srctree)/scripts/tags.sh $@ 1958 1943 1959 tags TAGS cscope gtags: FORCE 1944 tags TAGS cscope gtags: FORCE 1960 $(call cmd,tags) 1945 $(call cmd,tags) 1961 1946 1962 # Generate rust-project.json (a file that des !! 1947 # IDE support targets 1963 # Rust projects) for rust-analyzer (an implem << 1964 # Protocol). << 1965 PHONY += rust-analyzer 1948 PHONY += rust-analyzer 1966 rust-analyzer: 1949 rust-analyzer: 1967 +$(Q)$(CONFIG_SHELL) $(srctree)/scrip << 1968 $(Q)$(MAKE) $(build)=rust $@ 1950 $(Q)$(MAKE) $(build)=rust $@ 1969 1951 1970 # Script to generate missing namespace depend 1952 # Script to generate missing namespace dependencies 1971 # ------------------------------------------- 1953 # --------------------------------------------------------------------------- 1972 1954 1973 PHONY += nsdeps 1955 PHONY += nsdeps 1974 nsdeps: export KBUILD_NSDEPS=1 1956 nsdeps: export KBUILD_NSDEPS=1 1975 nsdeps: modules 1957 nsdeps: modules 1976 $(Q)$(CONFIG_SHELL) $(srctree)/script 1958 $(Q)$(CONFIG_SHELL) $(srctree)/scripts/nsdeps 1977 1959 1978 # Clang Tooling 1960 # Clang Tooling 1979 # ------------------------------------------- 1961 # --------------------------------------------------------------------------- 1980 1962 1981 quiet_cmd_gen_compile_commands = GEN $@ 1963 quiet_cmd_gen_compile_commands = GEN $@ 1982 cmd_gen_compile_commands = $(PYTHON3) $ 1964 cmd_gen_compile_commands = $(PYTHON3) $< -a $(AR) -o $@ $(filter-out $<, $(real-prereqs)) 1983 1965 1984 $(extmod_prefix)compile_commands.json: $(srct !! 1966 $(extmod_prefix)compile_commands.json: scripts/clang-tools/gen_compile_commands.py \ 1985 $(if $(KBUILD_EXTMOD),, vmlinux.a $(K 1967 $(if $(KBUILD_EXTMOD),, vmlinux.a $(KBUILD_VMLINUX_LIBS)) \ 1986 $(if $(CONFIG_MODULES), $(MODORDER)) 1968 $(if $(CONFIG_MODULES), $(MODORDER)) FORCE 1987 $(call if_changed,gen_compile_command 1969 $(call if_changed,gen_compile_commands) 1988 1970 1989 targets += $(extmod_prefix)compile_commands.j 1971 targets += $(extmod_prefix)compile_commands.json 1990 1972 1991 PHONY += clang-tidy clang-analyzer 1973 PHONY += clang-tidy clang-analyzer 1992 1974 1993 ifdef CONFIG_CC_IS_CLANG 1975 ifdef CONFIG_CC_IS_CLANG 1994 quiet_cmd_clang_tools = CHECK $< 1976 quiet_cmd_clang_tools = CHECK $< 1995 cmd_clang_tools = $(PYTHON3) $(srctree) 1977 cmd_clang_tools = $(PYTHON3) $(srctree)/scripts/clang-tools/run-clang-tools.py $@ $< 1996 1978 1997 clang-tidy clang-analyzer: $(extmod_prefix)co 1979 clang-tidy clang-analyzer: $(extmod_prefix)compile_commands.json 1998 $(call cmd,clang_tools) 1980 $(call cmd,clang_tools) 1999 else 1981 else 2000 clang-tidy clang-analyzer: 1982 clang-tidy clang-analyzer: 2001 @echo "$@ requires CC=clang" >&2 1983 @echo "$@ requires CC=clang" >&2 2002 @false 1984 @false 2003 endif 1985 endif 2004 1986 2005 # Scripts to check various things for consist 1987 # Scripts to check various things for consistency 2006 # ------------------------------------------- 1988 # --------------------------------------------------------------------------- 2007 1989 2008 PHONY += includecheck versioncheck coccicheck 1990 PHONY += includecheck versioncheck coccicheck export_report 2009 1991 2010 includecheck: 1992 includecheck: 2011 find $(srctree)/* $(RCS_FIND_IGNORE) 1993 find $(srctree)/* $(RCS_FIND_IGNORE) \ 2012 -name '*.[hcS]' -type f -prin 1994 -name '*.[hcS]' -type f -print | sort \ 2013 | xargs $(PERL) -w $(srctree) 1995 | xargs $(PERL) -w $(srctree)/scripts/checkincludes.pl 2014 1996 2015 versioncheck: 1997 versioncheck: 2016 find $(srctree)/* $(RCS_FIND_IGNORE) 1998 find $(srctree)/* $(RCS_FIND_IGNORE) \ 2017 -name '*.[hcS]' -type f -prin 1999 -name '*.[hcS]' -type f -print | sort \ 2018 | xargs $(PERL) -w $(srctree) 2000 | xargs $(PERL) -w $(srctree)/scripts/checkversion.pl 2019 2001 2020 coccicheck: 2002 coccicheck: 2021 $(Q)$(BASH) $(srctree)/scripts/$@ 2003 $(Q)$(BASH) $(srctree)/scripts/$@ 2022 2004 2023 export_report: 2005 export_report: 2024 $(PERL) $(srctree)/scripts/export_rep 2006 $(PERL) $(srctree)/scripts/export_report.pl 2025 2007 2026 PHONY += checkstack kernelrelease kernelversi 2008 PHONY += checkstack kernelrelease kernelversion image_name 2027 2009 2028 # UML needs a little special treatment here. 2010 # UML needs a little special treatment here. It wants to use the host 2029 # toolchain, so needs $(SUBARCH) passed to ch 2011 # toolchain, so needs $(SUBARCH) passed to checkstack.pl. Everyone 2030 # else wants $(ARCH), including people doing 2012 # else wants $(ARCH), including people doing cross-builds, which means 2031 # that $(SUBARCH) doesn't work here. 2013 # that $(SUBARCH) doesn't work here. 2032 ifeq ($(ARCH), um) 2014 ifeq ($(ARCH), um) 2033 CHECKSTACK_ARCH := $(SUBARCH) 2015 CHECKSTACK_ARCH := $(SUBARCH) 2034 else 2016 else 2035 CHECKSTACK_ARCH := $(ARCH) 2017 CHECKSTACK_ARCH := $(ARCH) 2036 endif 2018 endif 2037 MINSTACKSIZE ?= 100 << 2038 checkstack: 2019 checkstack: 2039 $(OBJDUMP) -d vmlinux $$(find . -name 2020 $(OBJDUMP) -d vmlinux $$(find . -name '*.ko') | \ 2040 $(PERL) $(srctree)/scripts/checkstack !! 2021 $(PERL) $(srctree)/scripts/checkstack.pl $(CHECKSTACK_ARCH) 2041 2022 2042 kernelrelease: 2023 kernelrelease: 2043 @$(filechk_kernel.release) 2024 @$(filechk_kernel.release) 2044 2025 2045 kernelversion: 2026 kernelversion: 2046 @echo $(KERNELVERSION) 2027 @echo $(KERNELVERSION) 2047 2028 2048 image_name: 2029 image_name: 2049 @echo $(KBUILD_IMAGE) 2030 @echo $(KBUILD_IMAGE) 2050 2031 2051 PHONY += run-command 2032 PHONY += run-command 2052 run-command: 2033 run-command: 2053 $(Q)$(KBUILD_RUN_COMMAND) 2034 $(Q)$(KBUILD_RUN_COMMAND) 2054 2035 2055 quiet_cmd_rmfiles = $(if $(wildcard $(rm-file 2036 quiet_cmd_rmfiles = $(if $(wildcard $(rm-files)),CLEAN $(wildcard $(rm-files))) 2056 cmd_rmfiles = rm -rf $(rm-files) 2037 cmd_rmfiles = rm -rf $(rm-files) 2057 2038 2058 # read saved command lines for existing targe 2039 # read saved command lines for existing targets 2059 existing-targets := $(wildcard $(sort $(targe 2040 existing-targets := $(wildcard $(sort $(targets))) 2060 2041 2061 -include $(foreach f,$(existing-targets),$(di 2042 -include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd) 2062 2043 2063 endif # config-build 2044 endif # config-build 2064 endif # mixed-build 2045 endif # mixed-build 2065 endif # need-sub-make 2046 endif # need-sub-make 2066 2047 2067 PHONY += FORCE 2048 PHONY += FORCE 2068 FORCE: 2049 FORCE: 2069 2050 2070 # Declare the contents of the PHONY variable 2051 # Declare the contents of the PHONY variable as phony. We keep that 2071 # information in a variable so we can use it 2052 # information in a variable so we can use it in if_changed and friends. 2072 .PHONY: $(PHONY) 2053 .PHONY: $(PHONY)
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.