mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-04 04:04:19 +00:00
modpost: generate vmlinux.symvers and reuse it for the second modpost
The full build runs modpost twice, first for vmlinux.o and second for modules. The first pass dumps all the vmlinux symbols into Module.symvers, but the second pass parses vmlinux again instead of reusing the dump file, presumably because it needs to avoid accumulating stale symbols. Loading symbol info from a dump file is faster than parsing an ELF object. Besides, modpost deals with various issues to parse vmlinux in the second pass. A solution is to make the first pass dumps symbols into a separate file, vmlinux.symvers. The second pass reads it, and parses module .o files. The merged symbol information is dumped into Module.symvers in the same way as before. This makes further modpost cleanups possible. Also, it fixes the problem of 'make vmlinux', which previously overwrote Module.symvers, throwing away module symbols. I slightly touched scripts/link-vmlinux.sh so that vmlinux is re-linked when you cross this commit. Otherwise, vmlinux.symvers would not be generated. Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
This commit is contained in:
parent
f1005b30ad
commit
269a535ca9
1
.gitignore
vendored
1
.gitignore
vendored
@ -56,6 +56,7 @@ modules.order
|
|||||||
/linux
|
/linux
|
||||||
/vmlinux
|
/vmlinux
|
||||||
/vmlinux.32
|
/vmlinux.32
|
||||||
|
/vmlinux.symvers
|
||||||
/vmlinux-gdb.py
|
/vmlinux-gdb.py
|
||||||
/vmlinuz
|
/vmlinuz
|
||||||
/System.map
|
/System.map
|
||||||
|
@ -251,6 +251,7 @@ vmlinux-*
|
|||||||
vmlinux.aout
|
vmlinux.aout
|
||||||
vmlinux.bin.all
|
vmlinux.bin.all
|
||||||
vmlinux.lds
|
vmlinux.lds
|
||||||
|
vmlinux.symvers
|
||||||
vmlinuz
|
vmlinuz
|
||||||
voffset.h
|
voffset.h
|
||||||
vsyscall.lds
|
vsyscall.lds
|
||||||
|
2
Makefile
2
Makefile
@ -1416,7 +1416,7 @@ endif # CONFIG_MODULES
|
|||||||
# make distclean Remove editor backup files, patch leftover files and the like
|
# make distclean Remove editor backup files, patch leftover files and the like
|
||||||
|
|
||||||
# Directories & files removed with 'make clean'
|
# Directories & files removed with 'make clean'
|
||||||
CLEAN_FILES += include/ksym \
|
CLEAN_FILES += include/ksym vmlinux.symvers \
|
||||||
modules.builtin modules.builtin.modinfo modules.nsdeps
|
modules.builtin modules.builtin.modinfo modules.nsdeps
|
||||||
|
|
||||||
# Directories & files removed with 'make mrproper'
|
# Directories & files removed with 'make mrproper'
|
||||||
|
@ -55,10 +55,10 @@ ifdef MODPOST_VMLINUX
|
|||||||
quiet_cmd_modpost = MODPOST $@
|
quiet_cmd_modpost = MODPOST $@
|
||||||
cmd_modpost = $(MODPOST) $<
|
cmd_modpost = $(MODPOST) $<
|
||||||
|
|
||||||
Module.symvers: vmlinux.o
|
vmlinux.symvers: vmlinux.o
|
||||||
$(call cmd,modpost)
|
$(call cmd,modpost)
|
||||||
|
|
||||||
__modpost: Module.symvers
|
__modpost: vmlinux.symvers
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
@ -66,7 +66,8 @@ MODPOST += -s \
|
|||||||
$(if $(KBUILD_NSDEPS),-d $(MODULES_NSDEPS))
|
$(if $(KBUILD_NSDEPS),-d $(MODULES_NSDEPS))
|
||||||
|
|
||||||
ifeq ($(KBUILD_EXTMOD),)
|
ifeq ($(KBUILD_EXTMOD),)
|
||||||
MODPOST += $(wildcard vmlinux)
|
|
||||||
|
input-symdump := vmlinux.symvers
|
||||||
output-symdump := Module.symvers
|
output-symdump := Module.symvers
|
||||||
|
|
||||||
else
|
else
|
||||||
|
@ -218,8 +218,6 @@ on_signals()
|
|||||||
}
|
}
|
||||||
trap on_signals HUP INT QUIT TERM
|
trap on_signals HUP INT QUIT TERM
|
||||||
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# Use "make V=1" to debug this script
|
# Use "make V=1" to debug this script
|
||||||
case "${KBUILD_VERBOSE}" in
|
case "${KBUILD_VERBOSE}" in
|
||||||
*1*)
|
*1*)
|
||||||
|
Loading…
Reference in New Issue
Block a user