@@ -38,6 +38,8 @@ __modpost:
38
38
include include/config/auto.conf
39
39
include $(srctree)/scripts/Kbuild.include
40
40
41
+ MODPOST = scripts/mod/modpost
42
+
41
43
modpost-args = \
42
44
$(if $(CONFIG_MODVERSIONS),-m) \
43
45
$(if $(CONFIG_MODULE_SRCVERSION_ALL),-a) \
@@ -46,6 +48,8 @@ modpost-args = \
46
48
$(if $(CONFIG_MODULE_ALLOW_MISSING_NAMESPACE_IMPORTS)$(KBUILD_NSDEPS),-N) \
47
49
-o $@
48
50
51
+ modpost-deps := $(MODPOST)
52
+
49
53
# 'make -i -k' ignores compile errors, and builds as many modules as possible.
50
54
ifneq ($(findstring i,$(filter-out --%,$(MAKEFLAGS))),)
51
55
modpost-args += -n
@@ -78,12 +82,13 @@ targets += .vmlinux.objs
78
82
.vmlinux.objs: vmlinux.a $(KBUILD_VMLINUX_LIBS) FORCE
79
83
$(call if_changed,vmlinux_objs)
80
84
81
- vmlinux.o-if-present := $(wildcard vmlinux.o)
82
- output-symdump := vmlinux.symvers
83
-
84
- ifdef KBUILD_MODULES
85
- output-symdump := $(if $(vmlinux.o-if-present), Module.symvers, modules-only.symvers)
86
- missing-input := $(filter-out $(vmlinux.o-if-present),vmlinux.o)
85
+ ifeq ($(wildcard vmlinux.o),)
86
+ missing-input := vmlinux.o
87
+ output-symdump := modules-only.symvers
88
+ else
89
+ modpost-args += vmlinux.o
90
+ modpost-deps += vmlinux.o
91
+ output-symdump := $(if $(KBUILD_MODULES), Module.symvers, vmlinux.symvers)
87
92
endif
88
93
89
94
else
@@ -95,11 +100,16 @@ src := $(obj)
95
100
# Include the module's Makefile to find KBUILD_EXTRA_SYMBOLS
96
101
include $(kbuild-file)
97
102
98
- module.symvers-if-present := $(wildcard Module.symvers)
99
103
output-symdump := $(KBUILD_EXTMOD)/Module.symvers
100
- missing-input := $(filter-out $(module.symvers-if-present), Module.symvers)
101
104
102
- modpost-args += -e $(addprefix -i ,$(module.symvers-if-present) $(KBUILD_EXTRA_SYMBOLS))
105
+ ifeq ($(wildcard Module.symvers),)
106
+ missing-input := Module.symvers
107
+ else
108
+ modpost-args += -i Module.symvers
109
+ modpost-deps += Module.symvers
110
+ endif
111
+
112
+ modpost-args += -e $(addprefix -i , $(KBUILD_EXTRA_SYMBOLS))
103
113
104
114
endif # ($(KBUILD_EXTMOD),)
105
115
@@ -108,12 +118,10 @@ modpost-args += -w
108
118
endif
109
119
110
120
ifdef KBUILD_MODULES
111
- modorder-if-needed := $(MODORDER)
112
121
modpost-args += -T $(MODORDER)
122
+ modpost-deps += $(MODORDER)
113
123
endif
114
124
115
- MODPOST = scripts/mod/modpost
116
-
117
125
# Read out modules.order to pass in modpost.
118
126
# Otherwise, allmodconfig would fail with "Argument list too long".
119
127
quiet_cmd_modpost = MODPOST $@
@@ -122,10 +130,10 @@ quiet_cmd_modpost = MODPOST $@
122
130
echo >&2 "WARNING: $(missing-input) is missing."; \
123
131
echo >&2 " Modules may not have dependencies or modversions."; \
124
132
echo >&2 " You may get many unresolved symbol warnings.";) \
125
- $(MODPOST) $(modpost-args) $(vmlinux.o-if-present)
133
+ $(MODPOST) $(modpost-args)
126
134
127
135
targets += $(output-symdump)
128
- $(output-symdump): $(modorder-if-needed) $(vmlinux.o-if-present) $(module.symvers-if-present) $(MODPOST ) FORCE
136
+ $(output-symdump): $(modpost-deps ) FORCE
129
137
$(call if_changed,modpost)
130
138
131
139
__modpost: $(output-symdump)
0 commit comments