Commit 7e8a3235 authored by Masahiro Yamada's avatar Masahiro Yamada

modpost: show warning if vmlinux is not found when processing modules

check_exports() does not print warnings about unresolved symbols if
vmlinux is missing because there would be too many.

This situation happens when you do 'make modules' from the clean
tree, or compile external modules against a kernel tree that has
not been completely built.

It is dangerous to not check unresolved symbols because you might be
building useless modules. At least it should be warned.
Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
parent 436b2ac6
...@@ -2001,8 +2001,6 @@ static void read_symbols(const char *modname) ...@@ -2001,8 +2001,6 @@ static void read_symbols(const char *modname)
mod = new_module(modname); mod = new_module(modname);
/* When there's no vmlinux, don't print warnings about
* unresolved symbols (since there'll be too many ;) */
if (is_vmlinux(modname)) { if (is_vmlinux(modname)) {
have_vmlinux = 1; have_vmlinux = 1;
mod->skip = 1; mod->skip = 1;
...@@ -2623,6 +2621,13 @@ int main(int argc, char **argv) ...@@ -2623,6 +2621,13 @@ int main(int argc, char **argv)
if (files_source) if (files_source)
read_symbols_from_files(files_source); read_symbols_from_files(files_source);
/*
* When there's no vmlinux, don't print warnings about
* unresolved symbols (since there'll be too many ;)
*/
if (!have_vmlinux)
warn("Symbol info of vmlinux is missing. Unresolved symbol check will be entirely skipped.\n");
err = 0; err = 0;
for (mod = modules; mod; mod = mod->next) { for (mod = modules; mod; mod = mod->next) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment