diff options
| author | David Woodhouse <dwmw2@infradead.org> | 2008-05-29 04:01:51 -0400 |
|---|---|---|
| committer | David Woodhouse <David.Woodhouse@intel.com> | 2008-07-10 09:47:34 -0400 |
| commit | 88ecf814c47f577248751ddbe9626d98aeef5783 (patch) | |
| tree | f289bb81a8ec81dbe82fbc314f39a07f8df1d562 | |
| parent | d172e7f5c67f2d41f453c7aa83d3bdb405ef8ba5 (diff) | |
firmware: Add firmware installation to modules_install, add firmware_install
For 'make modules_install', install any firmware required by
the modules which are being installed.
Also add a 'make firmware_install' target which doesn't depend on the
configuration, but installs _all_ available in-kernel-tree firmware into
$(INSTALL_FW_PATH), which defaults to /lib/firmware. This is intended
for distributors to make arch-independent (and config-independent)
packages containing firmware.
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
| -rw-r--r-- | Makefile | 13 | ||||
| -rw-r--r-- | firmware/Makefile | 24 | ||||
| -rw-r--r-- | scripts/Makefile.fwinst | 45 |
3 files changed, 75 insertions, 7 deletions
| @@ -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 | ||
| 999 | INSTALL_FW_PATH=$(INSTALL_MOD_PATH)/lib/firmware | ||
| 1000 | export INSTALL_FW_PATH | ||
| 1001 | |||
| 1002 | PHONY += firmware_install | ||
| 1003 | firmware_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 |
| 999 | INSTALL_HDR_PATH=$(objtree)/usr | 1009 | INSTALL_HDR_PATH=$(objtree)/usr |
| 1000 | export INSTALL_HDR_PATH | 1010 | export INSTALL_HDR_PATH |
| @@ -1080,6 +1090,7 @@ _modinst_: | |||
| 1080 | # boot script depmod is the master version. | 1090 | # boot script depmod is the master version. |
| 1081 | PHONY += _modinst_post | 1091 | PHONY += _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 | ||
| 1085 | else # CONFIG_MODULES | 1096 | else # 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 cc25f5600d5..3742feeb066 100644 --- a/firmware/Makefile +++ b/firmware/Makefile | |||
| @@ -9,13 +9,22 @@ fwabs := $(addprefix $(srctree)/,$(filter-out /%,$(fwdir)))$(filter /%,$(fwdir)) | |||
| 9 | 9 | ||
| 10 | fw-external-y := $(subst ",,$(CONFIG_EXTRA_FIRMWARE)) | 10 | fw-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: |
| 13 | ifneq ($(CONFIG_FIRMWARE_IN_KERNEL),y) | 13 | # 1. Building kernel with CONFIG_FIRMWARE_IN_KERNEL=y -- $(fw-shipped-y) should |
| 14 | fw-shipped-y := | 14 | # include the firmware files to include, according to .config |
| 15 | endif | 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 | ||
| 17 | firmware-y := $(fw-external-y) $(fw-shipped-y) | 19 | # For the former two cases we want $(fw-shipped-y) and $(fw-shipped-m) to be |
| 18 | firmware-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 | |||
| 24 | fw-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. | ||
| 27 | firmware-dirs := $(sort $(patsubst %,$(objtree)/$(obj)/%/,$(dir $(fw-external-y) $(fw-shipped-all)))) | ||
| 19 | 28 | ||
| 20 | quiet_cmd_mkdir = MKDIR $(patsubst $(objtree)/%,%,$@) | 29 | quiet_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 | ||
| 84 | obj-y := $(patsubst %,%.gen.o, $(firmware-y)) | 93 | obj-y += $(patsubst %,%.gen.o, $(fw-external-y)) |
| 94 | obj-$(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 00000000000..1c030087037 --- /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 | |||
| 8 | INSTALL := 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 | |||
| 14 | include scripts/Kbuild.include | ||
| 15 | include $(srctree)/$(obj)/Makefile | ||
| 16 | |||
| 17 | include scripts/Makefile.host | ||
| 18 | |||
| 19 | mod-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. | ||
| 23 | ifndef CONFIG_FIRMWARE_IN_KERNEL | ||
| 24 | mod-fw += $(addprefix $(INSTALL_FW_PATH)/,$(fw-shipped-y)) | ||
| 25 | endif | ||
| 26 | |||
| 27 | installed-fw := $(addprefix $(INSTALL_FW_PATH)/,$(fw-shipped-all)) | ||
| 28 | installed-fw-dirs := $(sort $(dir $(installed-fw))) $(INSTALL_FW_PATH)/. | ||
| 29 | |||
| 30 | quiet_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 | |||
| 45 | FORCE: | ||
