Commit c5e4a062 authored by Matthias Maennich's avatar Matthias Maennich Committed by Jessica Yu

module: support reading multiple values per modinfo tag

Similar to modpost's get_next_modinfo(), introduce get_next_modinfo() in
kernel/module.c to acquire any further values associated with the same
modinfo tag name. That is useful for any tags that have multiple
occurrences (such as 'alias'), but is in particular introduced here as
part of the symbol namespaces patch series to read the (potentially)
multiple namespaces a module is importing.
Reviewed-by: default avatarJoel Fernandes (Google) <joel@joelfernandes.org>
Reviewed-by: default avatarMartijn Coenen <maco@android.com>
Reviewed-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarMatthias Maennich <maennich@google.com>
Signed-off-by: default avatarJessica Yu <jeyu@kernel.org>
parent 089cf7f6
...@@ -2481,7 +2481,8 @@ static char *next_string(char *string, unsigned long *secsize) ...@@ -2481,7 +2481,8 @@ static char *next_string(char *string, unsigned long *secsize)
return string; return string;
} }
static char *get_modinfo(struct load_info *info, const char *tag) static char *get_next_modinfo(const struct load_info *info, const char *tag,
char *prev)
{ {
char *p; char *p;
unsigned int taglen = strlen(tag); unsigned int taglen = strlen(tag);
...@@ -2492,13 +2493,25 @@ static char *get_modinfo(struct load_info *info, const char *tag) ...@@ -2492,13 +2493,25 @@ static char *get_modinfo(struct load_info *info, const char *tag)
* get_modinfo() calls made before rewrite_section_headers() * get_modinfo() calls made before rewrite_section_headers()
* must use sh_offset, as sh_addr isn't set! * must use sh_offset, as sh_addr isn't set!
*/ */
for (p = (char *)info->hdr + infosec->sh_offset; p; p = next_string(p, &size)) { char *modinfo = (char *)info->hdr + infosec->sh_offset;
if (prev) {
size -= prev - modinfo;
modinfo = next_string(prev, &size);
}
for (p = modinfo; p; p = next_string(p, &size)) {
if (strncmp(p, tag, taglen) == 0 && p[taglen] == '=') if (strncmp(p, tag, taglen) == 0 && p[taglen] == '=')
return p + taglen + 1; return p + taglen + 1;
} }
return NULL; return NULL;
} }
static char *get_modinfo(const struct load_info *info, const char *tag)
{
return get_next_modinfo(info, tag, NULL);
}
static void setup_modinfo(struct module *mod, struct load_info *info) static void setup_modinfo(struct module *mod, struct load_info *info)
{ {
struct module_attribute *attr; struct module_attribute *attr;
......
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