Makefile 5.0 KB

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