提交 25601209 编写于 作者: R Russell King 提交者: Sam Ravnborg

kbuild: make modpost section warnings clearer

Change modpost section mismatch warnings to be less confusing;
model them on the binutils linker warnings which we all know how
to interpret.

Also, fix the wrong ordering of arguments for the final case -
fromsec and refsymname were reversed.
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
Acked-by: NAcked-by: David S. Miller <davem@davemloft.net>
Signed-off-by: NSam Ravnborg <sam@ravnborg.org>
上级 03c9587d
...@@ -885,29 +885,28 @@ static void warn_sec_mismatch(const char *modname, const char *fromsec, ...@@ -885,29 +885,28 @@ static void warn_sec_mismatch(const char *modname, const char *fromsec,
return; return;
if (before && after) { if (before && after) {
warn("%s - Section mismatch: reference to %s:%s from %s " warn("%s(%s+0x%llx): Section mismatch: reference to %s:%s "
"between '%s' (at offset 0x%llx) and '%s'\n", "(between '%s' and '%s')\n",
modname, secname, refsymname, fromsec, modname, fromsec, (unsigned long long)r.r_offset,
secname, refsymname,
elf->strtab + before->st_name, elf->strtab + before->st_name,
(long long)r.r_offset,
elf->strtab + after->st_name); elf->strtab + after->st_name);
} else if (before) { } else if (before) {
warn("%s - Section mismatch: reference to %s:%s from %s " warn("%s(%s+0x%llx): Section mismatch: reference to %s:%s "
"after '%s' (at offset 0x%llx)\n", "(after '%s')\n",
modname, secname, refsymname, fromsec, modname, fromsec, (unsigned long long)r.r_offset,
elf->strtab + before->st_name, secname, refsymname,
(long long)r.r_offset); elf->strtab + before->st_name);
} else if (after) { } else if (after) {
warn("%s - Section mismatch: reference to %s:%s from %s " warn("%s(%s+0x%llx): Section mismatch: reference to %s:%s "
"before '%s' (at offset -0x%llx)\n", "before '%s' (at offset -0x%llx)\n",
modname, secname, refsymname, fromsec, modname, fromsec, (unsigned long long)r.r_offset,
elf->strtab + after->st_name, secname, refsymname,
(long long)r.r_offset); elf->strtab + after->st_name);
} else { } else {
warn("%s - Section mismatch: reference to %s:%s from %s " warn("%s(%s+0x%llx): Section mismatch: reference to %s:%s\n",
"(offset 0x%llx)\n", modname, fromsec, (unsigned long long)r.r_offset,
modname, secname, fromsec, refsymname, secname, refsymname);
(long long)r.r_offset);
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册