Makefile 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. #
  2. # kbuild file for firmware/
  3. #
  4. # Create $(fwabs) from $(CONFIG_EXTRA_FIRMWARE_DIR) -- if it doesn't have a
  5. # leading /, it's relative to $(srctree).
  6. fwdir := $(subst ",,$(CONFIG_EXTRA_FIRMWARE_DIR))
  7. fwabs := $(addprefix $(srctree)/,$(filter-out /%,$(fwdir)))$(filter /%,$(fwdir))
  8. fw-external-y := $(subst ",,$(CONFIG_EXTRA_FIRMWARE))
  9. # There are three cases to care about:
  10. # 1. Building kernel with CONFIG_FIRMWARE_IN_KERNEL=y -- $(fw-shipped-y) should
  11. # include the firmware files to include, according to .config
  12. # 2. 'make modules_install', which will install firmware for modules, and
  13. # _also_ for the in-kernel drivers when CONFIG_FIRMWARE_IN_KERNEL=n
  14. # 3. 'make firmware_install', which installs all firmware, unconditionally.
  15. # For the former two cases we want $(fw-shipped-y) and $(fw-shipped-m) to be
  16. # accurate. In the latter case it doesn't matter -- it'll use $(fw-shipped-all).
  17. # But be aware that the config file might not be included at all.
  18. fw-shipped-$(CONFIG_SND_KORG1212) += korg/k1212.dsp
  19. fw-shipped-$(CONFIG_SND_MAESTRO3) += ess/maestro3_assp_kernel.fw \
  20. ess/maestro3_assp_minisrc.fw
  21. fw-shipped-all := $(fw-shipped-y) $(fw-shipped-m) $(fw-shipped-)
  22. # Directories which we _might_ need to create, so we have a rule for them.
  23. firmware-dirs := $(sort $(patsubst %,$(objtree)/$(obj)/%/,$(dir $(fw-external-y) $(fw-shipped-all))))
  24. quiet_cmd_mkdir = MKDIR $(patsubst $(objtree)/%,%,$@)
  25. cmd_mkdir = mkdir -p $@
  26. quiet_cmd_ihex = IHEX $@
  27. cmd_ihex = $(OBJCOPY) -Iihex -Obinary $< $@
  28. quiet_cmd_ihex2fw = IHEX2FW $@
  29. cmd_ihex2fw = $(objtree)/$(obj)/ihex2fw $< $@
  30. quiet_cmd_h16tofw = H16TOFW $@
  31. cmd_h16tofw = $(objtree)/$(obj)/ihex2fw -w $< $@
  32. quiet_cmd_fwbin = MK_FW $@
  33. cmd_fwbin = FWNAME="$(patsubst firmware/%.gen.S,%,$@)"; \
  34. FWSTR="$(subst /,_,$(subst .,_,$(subst -,_,$(patsubst \
  35. firmware/%.gen.S,%,$@))))"; \
  36. ASM_WORD=$(if $(CONFIG_64BIT),.quad,.long); \
  37. ASM_ALIGN=$(if $(CONFIG_64BIT),3,2); \
  38. PROGBITS=$(if $(CONFIG_ARM),%,@)progbits; \
  39. echo "/* Generated by firmware/Makefile */" > $@;\
  40. echo " .section .rodata" >>$@;\
  41. echo " .p2align $${ASM_ALIGN}" >>$@;\
  42. echo "_fw_$${FWSTR}_bin:" >>$@;\
  43. echo " .incbin \"$(2)\"" >>$@;\
  44. echo "_fw_end:" >>$@;\
  45. echo " .section .rodata.str,\"aMS\",$${PROGBITS},1" >>$@;\
  46. echo " .p2align $${ASM_ALIGN}" >>$@;\
  47. echo "_fw_$${FWSTR}_name:" >>$@;\
  48. echo " .string \"$$FWNAME\"" >>$@;\
  49. echo " .section .builtin_fw,\"a\",$${PROGBITS}" >>$@;\
  50. echo " .p2align $${ASM_ALIGN}" >>$@;\
  51. echo " $${ASM_WORD} _fw_$${FWSTR}_name" >>$@;\
  52. echo " $${ASM_WORD} _fw_$${FWSTR}_bin" >>$@;\
  53. echo " $${ASM_WORD} _fw_end - _fw_$${FWSTR}_bin" >>$@;
  54. # One of these files will change, or come into existence, whenever
  55. # the configuration changes between 32-bit and 64-bit. The .S files
  56. # need to change when that happens.
  57. wordsize_deps := $(wildcard include/config/64bit.h include/config/32bit.h \
  58. include/config/ppc32.h include/config/ppc64.h \
  59. include/config/superh32.h include/config/superh64.h \
  60. include/config/x86_32.h include/config/x86_64.h)
  61. # Workaround for make < 3.81, where .SECONDEXPANSION doesn't work.
  62. # It'll end up depending on these targets, so make them a PHONY rule which
  63. # depends on _all_ the directories in $(firmware-dirs), and it'll work out OK.
  64. PHONY += $(objtree)/$$(%) $(objtree)/$(obj)/$$(%)
  65. $(objtree)/$$(%) $(objtree)/$(obj)/$$(%): $(firmware-dirs)
  66. @true
  67. # For the $$(dir %) trick, where we need % to be expanded first.
  68. .SECONDEXPANSION:
  69. $(patsubst %,$(obj)/%.gen.S, $(fw-shipped-y)): %: $(wordsize_deps) \
  70. | $(objtree)/$$(dir %)
  71. $(call cmd,fwbin,$(patsubst %.gen.S,%,$@))
  72. $(patsubst %,$(obj)/%.gen.S, $(fw-external-y)): %: $(wordsize_deps) \
  73. include/config/builtin/firmware/dir.h | $(objtree)/$$(dir %)
  74. $(call cmd,fwbin,$(fwabs)/$(patsubst $(obj)/%.gen.S,%,$@))
  75. # The .o files depend on the binaries directly; the .S files don't.
  76. $(patsubst %,$(obj)/%.gen.o, $(fw-shipped-y)): %.gen.o: %
  77. $(patsubst %,$(obj)/%.gen.o, $(fw-external-y)): $(obj)/%.gen.o: $(fwdir)/%
  78. # .ihex is used just as a simple way to hold binary files in a source tree
  79. # where binaries are frowned upon. They are directly converted with objcopy.
  80. $(obj)/%: $(obj)/%.ihex | $(objtree)/$(obj)/$$(dir %)
  81. $(call cmd,ihex)
  82. # .HEX is also Intel HEX, but where the offset and length in each record
  83. # is actually meaningful, because the firmware has to be loaded in a certain
  84. # order rather than as a single binary blob. Thus, we convert them into our
  85. # more compact binary representation of ihex records (<linux/ihex.h>)
  86. $(obj)/%.fw: $(obj)/%.HEX $(obj)/ihex2fw | $(objtree)/$(obj)/$$(dir %)
  87. $(call cmd,ihex2fw)
  88. # .H16 is our own modified form of Intel HEX, with 16-bit length for records.
  89. $(obj)/%.fw: $(obj)/%.H16 $(obj)/ihex2fw | $(objtree)/$(obj)/$$(dir %)
  90. $(call cmd,h16tofw)
  91. $(firmware-dirs):
  92. $(call cmd,mkdir)
  93. obj-y += $(patsubst %,%.gen.o, $(fw-external-y))
  94. obj-$(CONFIG_FIRMWARE_IN_KERNEL) += $(patsubst %,%.gen.o, $(fw-shipped-y))
  95. # Remove .S files and binaries created from ihex
  96. # (during 'make clean' .config isn't included so they're all in $(fw-shipped-))
  97. targets := $(fw-shipped-) $(patsubst $(obj)/%,%, \
  98. $(shell find $(obj) -name \*.gen.S 2>/dev/null))
  99. # Without this, built-in.o won't be created when it's empty, and the
  100. # final vmlinux link will fail.
  101. obj-n := dummy
  102. hostprogs-y := ihex2fw