mirror of
https://github.com/torvalds/linux.git
synced 2024-11-12 23:23:03 +00:00
kbuild: add read-file macro
Since GNU Make 4.2, $(file ...) supports the read operater '<', which is useful to read a file without forking a new process. No warning is shown even if the input file is missing. For older Make versions, it falls back to the cat command. Signed-off-by: Masahiro Yamada <masahiroy@kernel.org> Reviewed-by: Nicolas Schier <nicolas@fjasle.eu> Reviewed-by: Alexander Lobakin <alexandr.lobakin@intel.com> Tested-by: Alexander Lobakin <alexandr.lobakin@intel.com>
This commit is contained in:
parent
a5db80c65d
commit
6768fa4bcb
2
Makefile
2
Makefile
@ -376,7 +376,7 @@ else # !mixed-build
|
|||||||
include $(srctree)/scripts/Kbuild.include
|
include $(srctree)/scripts/Kbuild.include
|
||||||
|
|
||||||
# Read KERNELRELEASE from include/config/kernel.release (if it exists)
|
# Read KERNELRELEASE from include/config/kernel.release (if it exists)
|
||||||
KERNELRELEASE = $(shell cat include/config/kernel.release 2> /dev/null)
|
KERNELRELEASE = $(call read-file, include/config/kernel.release)
|
||||||
KERNELVERSION = $(VERSION)$(if $(PATCHLEVEL),.$(PATCHLEVEL)$(if $(SUBLEVEL),.$(SUBLEVEL)))$(EXTRAVERSION)
|
KERNELVERSION = $(VERSION)$(if $(PATCHLEVEL),.$(PATCHLEVEL)$(if $(SUBLEVEL),.$(SUBLEVEL)))$(EXTRAVERSION)
|
||||||
export VERSION PATCHLEVEL SUBLEVEL KERNELRELEASE KERNELVERSION
|
export VERSION PATCHLEVEL SUBLEVEL KERNELRELEASE KERNELVERSION
|
||||||
|
|
||||||
|
@ -10,6 +10,10 @@ empty :=
|
|||||||
space := $(empty) $(empty)
|
space := $(empty) $(empty)
|
||||||
space_escape := _-_SPACE_-_
|
space_escape := _-_SPACE_-_
|
||||||
pound := \#
|
pound := \#
|
||||||
|
define newline
|
||||||
|
|
||||||
|
|
||||||
|
endef
|
||||||
|
|
||||||
###
|
###
|
||||||
# Comparison macros.
|
# Comparison macros.
|
||||||
@ -61,6 +65,16 @@ stringify = $(squote)$(quote)$1$(quote)$(squote)
|
|||||||
kbuild-dir = $(if $(filter /%,$(src)),$(src),$(srctree)/$(src))
|
kbuild-dir = $(if $(filter /%,$(src)),$(src),$(srctree)/$(src))
|
||||||
kbuild-file = $(or $(wildcard $(kbuild-dir)/Kbuild),$(kbuild-dir)/Makefile)
|
kbuild-file = $(or $(wildcard $(kbuild-dir)/Kbuild),$(kbuild-dir)/Makefile)
|
||||||
|
|
||||||
|
###
|
||||||
|
# Read a file, replacing newlines with spaces
|
||||||
|
#
|
||||||
|
# Make 4.2 or later can read a file by using its builtin function.
|
||||||
|
ifneq ($(filter-out 3.% 4.0 4.1, $(MAKE_VERSION)),)
|
||||||
|
read-file = $(subst $(newline),$(space),$(file < $1))
|
||||||
|
else
|
||||||
|
read-file = $(shell cat $1 2>/dev/null)
|
||||||
|
endif
|
||||||
|
|
||||||
###
|
###
|
||||||
# Easy method for doing a status message
|
# Easy method for doing a status message
|
||||||
kecho := :
|
kecho := :
|
||||||
|
@ -13,7 +13,7 @@ include $(srctree)/scripts/Kbuild.include
|
|||||||
include $(srctree)/scripts/Makefile.lib
|
include $(srctree)/scripts/Makefile.lib
|
||||||
|
|
||||||
# find all modules listed in modules.order
|
# find all modules listed in modules.order
|
||||||
modules := $(shell cat $(MODORDER))
|
modules := $(call read-file, $(MODORDER))
|
||||||
|
|
||||||
__modfinal: $(modules)
|
__modfinal: $(modules)
|
||||||
@:
|
@:
|
||||||
|
@ -9,7 +9,7 @@ __modinst:
|
|||||||
include include/config/auto.conf
|
include include/config/auto.conf
|
||||||
include $(srctree)/scripts/Kbuild.include
|
include $(srctree)/scripts/Kbuild.include
|
||||||
|
|
||||||
modules := $(shell cat $(MODORDER))
|
modules := $(call read-file, $(MODORDER))
|
||||||
|
|
||||||
ifeq ($(KBUILD_EXTMOD),)
|
ifeq ($(KBUILD_EXTMOD),)
|
||||||
dst := $(MODLIB)/kernel
|
dst := $(MODLIB)/kernel
|
||||||
|
Loading…
Reference in New Issue
Block a user