1# SPDX-License-Identifier: GPL-2.0-only 2 3PHONY := __default 4__default: vmlinux 5 6include include/config/auto.conf 7include $(srctree)/scripts/Kbuild.include 8include $(srctree)/scripts/Makefile.lib 9 10targets := 11 12%.o: %.c FORCE 13 $(call if_changed_rule,cc_o_c) 14 15%.o: %.S FORCE 16 $(call if_changed_rule,as_o_S) 17 18# Built-in dtb 19# --------------------------------------------------------------------------- 20 21quiet_cmd_wrap_dtbs = WRAP $@ 22 cmd_wrap_dtbs = { \ 23 echo '\#include <asm-generic/vmlinux.lds.h>'; \ 24 echo '.section .dtb.init.rodata,"a"'; \ 25 while read dtb; do \ 26 symbase=__dtb_$$(basename -s .dtb "$${dtb}" | tr - _); \ 27 echo '.balign STRUCT_ALIGNMENT'; \ 28 echo ".global $${symbase}_begin"; \ 29 echo "$${symbase}_begin:"; \ 30 echo '.incbin "'$$dtb'" '; \ 31 echo ".global $${symbase}_end"; \ 32 echo "$${symbase}_end:"; \ 33 done < $<; \ 34 } > $@ 35 36.builtin-dtbs.S: .builtin-dtbs-list FORCE 37 $(call if_changed,wrap_dtbs) 38 39quiet_cmd_gen_dtbs_list = GEN $@ 40 cmd_gen_dtbs_list = \ 41 $(if $(CONFIG_BUILTIN_DTB_NAME), echo "arch/$(SRCARCH)/boot/dts/$(CONFIG_BUILTIN_DTB_NAME).dtb",:) > $@ 42 43.builtin-dtbs-list: arch/$(SRCARCH)/boot/dts/dtbs-list FORCE 44 $(call if_changed,$(if $(CONFIG_BUILTIN_DTB_ALL),copy,gen_dtbs_list)) 45 46targets += .builtin-dtbs-list 47 48ifdef CONFIG_GENERIC_BUILTIN_DTB 49targets += .builtin-dtbs.S .builtin-dtbs.o 50vmlinux.unstripped: .builtin-dtbs.o 51endif 52 53# vmlinux.unstripped 54# --------------------------------------------------------------------------- 55 56ifdef CONFIG_ARCH_WANTS_PRE_LINK_VMLINUX 57vmlinux.unstripped: arch/$(SRCARCH)/tools/vmlinux.arch.o 58 59arch/$(SRCARCH)/tools/vmlinux.arch.o: vmlinux.o FORCE 60 $(Q)$(MAKE) $(build)=arch/$(SRCARCH)/tools $@ 61endif 62 63ARCH_POSTLINK := $(wildcard $(srctree)/arch/$(SRCARCH)/Makefile.postlink) 64 65# Final link of vmlinux with optional arch pass after final link 66cmd_link_vmlinux = \ 67 $< "$(LD)" "$(KBUILD_LDFLAGS)" "$(LDFLAGS_vmlinux)" "$@"; \ 68 $(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) $@, true) 69 70targets += vmlinux.unstripped .vmlinux.export.o 71vmlinux.unstripped: scripts/link-vmlinux.sh vmlinux.o .vmlinux.export.o $(KBUILD_LDS) FORCE 72 +$(call if_changed_dep,link_vmlinux) 73ifdef CONFIG_DEBUG_INFO_BTF 74vmlinux.unstripped: $(RESOLVE_BTFIDS) 75endif 76 77ifdef CONFIG_BUILDTIME_TABLE_SORT 78vmlinux.unstripped: scripts/sorttable 79endif 80 81# vmlinux 82# --------------------------------------------------------------------------- 83 84remove-section-y := .modinfo 85remove-section-$(CONFIG_ARCH_VMLINUX_NEEDS_RELOCS) += '.rel*' '!.rel*.dyn' 86# for compatibility with binutils < 2.32 87# https://sourceware.org/git/?p=binutils-gdb.git;a=commit;h=c12d9fa2afe7abcbe407a00e15719e1a1350c2a7 88remove-section-$(CONFIG_ARCH_VMLINUX_NEEDS_RELOCS) += '.rel.*' 89 90remove-symbols := -w --strip-unneeded-symbol='__mod_device_table__*' 91 92# To avoid warnings: "empty loadable segment detected at ..." from GNU objcopy, 93# it is necessary to remove the PT_LOAD flag from the segment. 94quiet_cmd_strip_relocs = OBJCOPY $@ 95 cmd_strip_relocs = $(OBJCOPY) $(patsubst %,--set-section-flags %=noload,$(remove-section-y)) $< $@; \ 96 $(OBJCOPY) $(addprefix --remove-section=,$(remove-section-y)) $(remove-symbols) $@ 97 98targets += vmlinux 99vmlinux: vmlinux.unstripped FORCE 100 $(call if_changed,strip_relocs) 101 102# modules.builtin.modinfo 103# --------------------------------------------------------------------------- 104 105OBJCOPYFLAGS_modules.builtin.modinfo := -j .modinfo -O binary 106 107targets += modules.builtin.modinfo 108modules.builtin.modinfo: vmlinux.unstripped FORCE 109 $(call if_changed,objcopy) 110 111# modules.builtin 112# --------------------------------------------------------------------------- 113 114__default: modules.builtin 115 116# The second line aids cases where multiple modules share the same object. 117 118quiet_cmd_modules_builtin = GEN $@ 119 cmd_modules_builtin = \ 120 tr '\0' '\n' < $< | \ 121 sed -n 's/^[[:alnum:]:_]*\.file=//p' | \ 122 tr ' ' '\n' | uniq | sed -e 's:^:kernel/:' -e 's/$$/.ko/' > $@ 123 124targets += modules.builtin 125modules.builtin: modules.builtin.modinfo FORCE 126 $(call if_changed,modules_builtin) 127 128# modules.builtin.ranges 129# --------------------------------------------------------------------------- 130ifdef CONFIG_BUILTIN_MODULE_RANGES 131__default: modules.builtin.ranges 132 133quiet_cmd_modules_builtin_ranges = GEN $@ 134 cmd_modules_builtin_ranges = gawk -f $(real-prereqs) > $@ 135 136targets += modules.builtin.ranges 137modules.builtin.ranges: $(srctree)/scripts/generate_builtin_ranges.awk \ 138 modules.builtin vmlinux.map vmlinux.o.map FORCE 139 $(call if_changed,modules_builtin_ranges) 140 141vmlinux.map: vmlinux.unstripped 142 @: 143 144endif 145 146# Add FORCE to the prerequisites of a target to force it to be always rebuilt. 147# --------------------------------------------------------------------------- 148 149PHONY += FORCE 150FORCE: 151 152# Read all saved command lines and dependencies for the $(targets) we 153# may be building above, using $(if_changed{,_dep}). As an 154# optimization, we don't need to read them if the target does not 155# exist, we will rebuild anyway in that case. 156 157existing-targets := $(wildcard $(sort $(targets))) 158 159-include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd) 160 161.PHONY: $(PHONY) 162