Makefile 5.3 KB

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