Message ID | 1345345030-22211-60-git-send-email-andi@firstfloor.org (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
>>> Andi Kleen <andi@firstfloor.org> 08/19/12 4:59 AM >>> >@@ -1904,6 +1904,10 @@ static int simplify_symbols(struct module *mod, const struct load_info *info) > > switch (sym[i].st_shndx) { > case SHN_COMMON: >+ /* Ignore common symbols */ >+ if (!strncmp(name, "__gnu_lto", 9)) >+ break; >+ > /* We compiled with -fno-common. These are not > supposed to happen. */ > pr_debug("Common symbol: %s\n", name); I think it is dangerous to just match the start of the symbol name here - this may in the future well lead to ignoring symbols we shouldn't be ignoring. Also I would think the added comment ought to say "Ignore LTO symbols." Otherwise its sort of contradicting the purpose of the case being handled here. Jan -- To unsubscribe from this list: send the line "unsubscribe linux-kbuild" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Sun, Aug 19, 2012 at 09:53:02AM +0100, Jan Beulich wrote: > >>> Andi Kleen <andi@firstfloor.org> 08/19/12 4:59 AM >>> > >@@ -1904,6 +1904,10 @@ static int simplify_symbols(struct module *mod, const struct load_info *info) > > > > switch (sym[i].st_shndx) { > > case SHN_COMMON: > >+ /* Ignore common symbols */ > >+ if (!strncmp(name, "__gnu_lto", 9)) > >+ break; > >+ > > /* We compiled with -fno-common. These are not > > supposed to happen. */ > > pr_debug("Common symbol: %s\n", name); > > I think it is dangerous to just match the start of the symbol name here - > this may in the future well lead to ignoring symbols we shouldn't be > ignoring. > > Also I would think the added comment ought to say "Ignore LTO symbols." > Otherwise its sort of contradicting the purpose of the case being handled > here. Ok maybe should error out. This case only happens with fat LTO when the LTO step is not actually run. It used to happen because old versions of this patchkit didn't correctly LTO modules I'll change it to error out. The reason for the prefix was that there is a __gnu_lto_vXXX and the version number could change. Thanks for the reviewws. -Andi
diff --git a/kernel/module.c b/kernel/module.c index c00565a..2cbbae3 100644 --- a/kernel/module.c +++ b/kernel/module.c @@ -1904,6 +1904,10 @@ static int simplify_symbols(struct module *mod, const struct load_info *info) switch (sym[i].st_shndx) { case SHN_COMMON: + /* Ignore common symbols */ + if (!strncmp(name, "__gnu_lto", 9)) + break; + /* We compiled with -fno-common. These are not supposed to happen. */ pr_debug("Common symbol: %s\n", name);