aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile13
-rw-r--r--firmware/Makefile24
-rw-r--r--scripts/Makefile.fwinst45
3 files changed, 75 insertions, 7 deletions
diff --git a/Makefile b/Makefile
index f398cffa6c07..bd2aa14f1e77 100644
--- a/Makefile
+++ b/Makefile
@@ -995,6 +995,16 @@ depend dep:
995 @echo '*** Warning: make $@ is unnecessary now.' 995 @echo '*** Warning: make $@ is unnecessary now.'
996 996
997# --------------------------------------------------------------------------- 997# ---------------------------------------------------------------------------
998# Firmware install
999INSTALL_FW_PATH=$(INSTALL_MOD_PATH)/lib/firmware
1000export INSTALL_FW_PATH
1001
1002PHONY += firmware_install
1003firmware_install: FORCE
1004 @mkdir -p $(objtree)/firmware
1005 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.fwinst obj=firmware __fw_install
1006
1007# ---------------------------------------------------------------------------
998# Kernel headers 1008# Kernel headers
999INSTALL_HDR_PATH=$(objtree)/usr 1009INSTALL_HDR_PATH=$(objtree)/usr
1000export INSTALL_HDR_PATH 1010export INSTALL_HDR_PATH
@@ -1080,6 +1090,7 @@ _modinst_:
1080# boot script depmod is the master version. 1090# boot script depmod is the master version.
1081PHONY += _modinst_post 1091PHONY += _modinst_post
1082_modinst_post: _modinst_ 1092_modinst_post: _modinst_
1093 $(Q)$(MAKE) -f $(srctree)/scripts/Makefile.fwinst obj=firmware __fw_modinst
1083 $(call cmd,depmod) 1094 $(call cmd,depmod)
1084 1095
1085else # CONFIG_MODULES 1096else # CONFIG_MODULES
@@ -1197,6 +1208,8 @@ help:
1197 @echo '* vmlinux - Build the bare kernel' 1208 @echo '* vmlinux - Build the bare kernel'
1198 @echo '* modules - Build all modules' 1209 @echo '* modules - Build all modules'
1199 @echo ' modules_install - Install all modules to INSTALL_MOD_PATH (default: /)' 1210 @echo ' modules_install - Install all modules to INSTALL_MOD_PATH (default: /)'
1211 @echo ' firmware_install- Install all firmware to INSTALL_FW_PATH'
1212 @echo ' (default: $$(INSTALL_MOD_PATH)/lib/firmware)'
1200 @echo ' dir/ - Build all files in dir and below' 1213 @echo ' dir/ - Build all files in dir and below'
1201 @echo ' dir/file.[ois] - Build specified target only' 1214 @echo ' dir/file.[ois] - Build specified target only'
1202 @echo ' dir/file.ko - Build module including final link' 1215 @echo ' dir/file.ko - Build module including final link'
diff --git a/firmware/Makefile b/firmware/Makefile
index cc25f5600d5d..3742feeb066f 100644
--- a/firmware/Makefile
+++ b/firmware/Makefile
@@ -9,13 +9,22 @@ fwabs := $(addprefix $(srctree)/,$(filter-out /%,$(fwdir)))$(filter /%,$(fwdir))
9 9
10fw-external-y := $(subst ",,$(CONFIG_EXTRA_FIRMWARE)) 10fw-external-y := $(subst ",,$(CONFIG_EXTRA_FIRMWARE))
11 11
12# If CONFIG_FIRMWARE_IN_KERNEL is not set, then don't include any firmware 12# There are three cases to care about:
13ifneq ($(CONFIG_FIRMWARE_IN_KERNEL),y) 13# 1. Building kernel with CONFIG_FIRMWARE_IN_KERNEL=y -- $(fw-shipped-y) should
14fw-shipped-y := 14# include the firmware files to include, according to .config
15endif 15# 2. 'make modules_install', which will install firmware for modules, and
16# _also_ for the in-kernel drivers when CONFIG_FIRMWARE_IN_KERNEL=n
17# 3. 'make firmware_install', which installs all firmware, unconditionally.
16 18
17firmware-y := $(fw-external-y) $(fw-shipped-y) 19# For the former two cases we want $(fw-shipped-y) and $(fw-shipped-m) to be
18firmware-dirs := $(sort $(patsubst %,$(objtree)/$(obj)/%/,$(dir $(firmware-y) $(fw-shipped-)))) 20# accurate. In the latter case it doesn't matter -- it'll use $(fw-shipped-all).
21# But be aware that the config file might not be included at all.
22
23
24fw-shipped-all := $(fw-shipped-y) $(fw-shipped-m) $(fw-shipped-)
25
26# Directories which we _might_ need to create, so we have a rule for them.
27firmware-dirs := $(sort $(patsubst %,$(objtree)/$(obj)/%/,$(dir $(fw-external-y) $(fw-shipped-all))))
19 28
20quiet_cmd_mkdir = MKDIR $(patsubst $(objtree)/%,%,$@) 29quiet_cmd_mkdir = MKDIR $(patsubst $(objtree)/%,%,$@)
21 cmd_mkdir = mkdir -p $@ 30 cmd_mkdir = mkdir -p $@
@@ -81,7 +90,8 @@ $(obj)/%: $(obj)/%.ihex | $(objtree)/$(obj)/$$(dir %)
81$(firmware-dirs): 90$(firmware-dirs):
82 $(call cmd,mkdir) 91 $(call cmd,mkdir)
83 92
84obj-y := $(patsubst %,%.gen.o, $(firmware-y)) 93obj-y += $(patsubst %,%.gen.o, $(fw-external-y))
94obj-$(CONFIG_FIRMWARE_IN_KERNEL) += $(patsubst %,%.gen.o, $(fw-shipped-y))
85 95
86# Remove .S files and binaries created from ihex 96# Remove .S files and binaries created from ihex
87# (during 'make clean' .config isn't included so they're all in $(fw-shipped-)) 97# (during 'make clean' .config isn't included so they're all in $(fw-shipped-))
diff --git a/scripts/Makefile.fwinst b/scripts/Makefile.fwinst
new file mode 100644
index 000000000000..1c030087037f
--- /dev/null
+++ b/scripts/Makefile.fwinst
@@ -0,0 +1,45 @@
1# ==========================================================================
2# Installing firmware
3#
4# We don't include the .config, so all firmware files are in $(fw-shipped-)
5# rather than in $(fw-shipped-y) or $(fw-shipped-n).
6# ==========================================================================
7
8INSTALL := install
9
10# For modules_install installing firmware, we want to see .config
11# But for firmware_install, we don't care, but don't want to require it.
12-include $(objtree)/.config
13
14include scripts/Kbuild.include
15include $(srctree)/$(obj)/Makefile
16
17include scripts/Makefile.host
18
19mod-fw := $(addprefix $(INSTALL_FW_PATH)/,$(fw-shipped-m))
20
21# If CONFIG_FIRMWARE_IN_KERNEL isn't set, then install the
22# firmware for in-kernel drivers too.
23ifndef CONFIG_FIRMWARE_IN_KERNEL
24mod-fw += $(addprefix $(INSTALL_FW_PATH)/,$(fw-shipped-y))
25endif
26
27installed-fw := $(addprefix $(INSTALL_FW_PATH)/,$(fw-shipped-all))
28installed-fw-dirs := $(sort $(dir $(installed-fw))) $(INSTALL_FW_PATH)/.
29
30quiet_cmd_install = INSTALL $(subst $(srctree)/,,$@)
31 cmd_install = $(INSTALL) -m0644 $< $@
32
33$(installed-fw-dirs):
34 $(call cmd,mkdir)
35
36$(installed-fw): $(INSTALL_FW_PATH)/%: $(obj)/% | $(INSTALL_FW_PATH)/$$(dir %)/
37 $(call cmd,install)
38
39.PHONY: __fw_install __fw_modinst FORCE
40
41__fw_install: $(installed-fw)
42__fw_modinst: $(mod-fw)
43
44
45FORCE: