Commit a82f794c authored by Masahiro Yamada's avatar Masahiro Yamada

modpost: strip .o from modname before calling new_module()

new_module() conditionally strips the .o because the modname has .o
suffix when it is called from read_symbols(), but no .o when it is
called from read_dump().

It is clearer to strip .o in read_symbols().

I also used flexible-array for mod->name.
Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
parent 858b937d
...@@ -175,18 +175,12 @@ static struct module *find_module(const char *modname) ...@@ -175,18 +175,12 @@ static struct module *find_module(const char *modname)
static struct module *new_module(const char *modname) static struct module *new_module(const char *modname)
{ {
struct module *mod; struct module *mod;
char *p;
mod = NOFAIL(malloc(sizeof(*mod))); mod = NOFAIL(malloc(sizeof(*mod) + strlen(modname) + 1));
memset(mod, 0, sizeof(*mod)); memset(mod, 0, sizeof(*mod));
p = NOFAIL(strdup(modname));
/* strip trailing .o */
if (strends(p, ".o"))
p[strlen(p) - 2] = '\0';
/* add to list */ /* add to list */
mod->name = p; strcpy(mod->name, modname);
mod->is_vmlinux = is_vmlinux(modname); mod->is_vmlinux = is_vmlinux(modname);
mod->gpl_compatible = -1; mod->gpl_compatible = -1;
mod->next = modules; mod->next = modules;
...@@ -2013,7 +2007,15 @@ static void read_symbols(const char *modname) ...@@ -2013,7 +2007,15 @@ static void read_symbols(const char *modname)
if (!parse_elf(&info, modname)) if (!parse_elf(&info, modname))
return; return;
mod = new_module(modname); {
char *tmp;
/* strip trailing .o */
tmp = NOFAIL(strdup(modname));
tmp[strlen(tmp) - 2] = '\0';
mod = new_module(tmp);
free(tmp);
}
if (!mod->is_vmlinux) { if (!mod->is_vmlinux) {
license = get_modinfo(&info, "license"); license = get_modinfo(&info, "license");
......
...@@ -116,7 +116,6 @@ struct namespace_list { ...@@ -116,7 +116,6 @@ struct namespace_list {
struct module { struct module {
struct module *next; struct module *next;
const char *name;
int gpl_compatible; int gpl_compatible;
struct symbol *unres; struct symbol *unres;
int from_dump; /* 1 if module was loaded from *.symvers */ int from_dump; /* 1 if module was loaded from *.symvers */
...@@ -130,6 +129,7 @@ struct module { ...@@ -130,6 +129,7 @@ struct module {
struct namespace_list *missing_namespaces; struct namespace_list *missing_namespaces;
// Actual imported namespaces // Actual imported namespaces
struct namespace_list *imported_namespaces; struct namespace_list *imported_namespaces;
char name[];
}; };
struct elf_info { struct elf_info {
......
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