modpost: abort if module name is too long
Module name has a limited length, but currently the build system allows the build finishing even if the module name is too long. CC /root/kprobe_example/abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz.mod.o /root/kprobe_example/abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz.mod.c:9:2: warning: initializer-string for array of chars is too long [enabled by default] .name = KBUILD_MODNAME, ^ but it's merely a warning. This patch adds the check of the module name length in modpost and stops the build properly. Signed-off-by: Wanlong Gao <wanlong.gao@gmail.com> Signed-off-by: Jessica Yu <jeyu@kernel.org>
This commit is contained in:
parent
520eccdfe1
commit
4fd3e4ef1f
@ -47,6 +47,12 @@ enum export {
|
|||||||
export_unused_gpl, export_gpl_future, export_unknown
|
export_unused_gpl, export_gpl_future, export_unknown
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* In kernel, this size is defined in linux/module.h;
|
||||||
|
* here we use Elf_Addr instead of long for covering cross-compile
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define MODULE_NAME_LEN (64 - sizeof(Elf_Addr))
|
||||||
|
|
||||||
#define PRINTF __attribute__ ((format (printf, 1, 2)))
|
#define PRINTF __attribute__ ((format (printf, 1, 2)))
|
||||||
|
|
||||||
PRINTF void fatal(const char *fmt, ...)
|
PRINTF void fatal(const char *fmt, ...)
|
||||||
@ -2116,6 +2122,23 @@ static void check_exports(struct module *mod)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int check_modname_len(struct module *mod)
|
||||||
|
{
|
||||||
|
const char *mod_name;
|
||||||
|
|
||||||
|
mod_name = strrchr(mod->name, '/');
|
||||||
|
if (mod_name == NULL)
|
||||||
|
mod_name = mod->name;
|
||||||
|
else
|
||||||
|
mod_name++;
|
||||||
|
if (strlen(mod_name) >= MODULE_NAME_LEN) {
|
||||||
|
merror("module name is too long [%s.ko]\n", mod->name);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Header for the generated file
|
* Header for the generated file
|
||||||
**/
|
**/
|
||||||
@ -2155,11 +2178,6 @@ static void add_staging_flag(struct buffer *b, const char *name)
|
|||||||
buf_printf(b, "\nMODULE_INFO(staging, \"Y\");\n");
|
buf_printf(b, "\nMODULE_INFO(staging, \"Y\");\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* In kernel, this size is defined in linux/module.h;
|
|
||||||
* here we use Elf_Addr instead of long for covering cross-compile
|
|
||||||
*/
|
|
||||||
#define MODULE_NAME_LEN (64 - sizeof(Elf_Addr))
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Record CRCs for unresolved symbols
|
* Record CRCs for unresolved symbols
|
||||||
**/
|
**/
|
||||||
@ -2490,6 +2508,7 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
buf.pos = 0;
|
buf.pos = 0;
|
||||||
|
|
||||||
|
err |= check_modname_len(mod);
|
||||||
add_header(&buf, mod);
|
add_header(&buf, mod);
|
||||||
add_intree_flag(&buf, !external_module);
|
add_intree_flag(&buf, !external_module);
|
||||||
add_staging_flag(&buf, mod->name);
|
add_staging_flag(&buf, mod->name);
|
||||||
|
Loading…
Reference in New Issue
Block a user