diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-05-14 13:55:54 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-05-14 13:55:54 -0400 |
commit | 280664f558c9d973315d48f125eb664cc607d089 (patch) | |
tree | 681375d73394670824c2bff1936fbbd62d8c3d1a /kernel/module.c | |
parent | e0654264c4806dc436b291294a0fbf9be7571ab6 (diff) | |
parent | dadec066d8fa7da227f623f632ea114690fecaf8 (diff) |
Merge tag 'modules-for-v5.2' of git://git.kernel.org/pub/scm/linux/kernel/git/jeyu/linux
Pull modules updates from Jessica Yu:
- Use a separate table to store symbol types instead of hijacking
fields in struct Elf_Sym
- Trivial code cleanups
* tag 'modules-for-v5.2' of git://git.kernel.org/pub/scm/linux/kernel/git/jeyu/linux:
module: add stubs for within_module functions
kallsyms: store type information in its own array
vmlinux.lds.h: drop unused __vermagic
Diffstat (limited to 'kernel/module.c')
-rw-r--r-- | kernel/module.c | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/kernel/module.c b/kernel/module.c index a9e1e7f2c224..6e6712b3aaf5 100644 --- a/kernel/module.c +++ b/kernel/module.c | |||
@@ -2642,6 +2642,8 @@ static void layout_symtab(struct module *mod, struct load_info *info) | |||
2642 | info->symoffs = ALIGN(mod->core_layout.size, symsect->sh_addralign ?: 1); | 2642 | info->symoffs = ALIGN(mod->core_layout.size, symsect->sh_addralign ?: 1); |
2643 | info->stroffs = mod->core_layout.size = info->symoffs + ndst * sizeof(Elf_Sym); | 2643 | info->stroffs = mod->core_layout.size = info->symoffs + ndst * sizeof(Elf_Sym); |
2644 | mod->core_layout.size += strtab_size; | 2644 | mod->core_layout.size += strtab_size; |
2645 | info->core_typeoffs = mod->core_layout.size; | ||
2646 | mod->core_layout.size += ndst * sizeof(char); | ||
2645 | mod->core_layout.size = debug_align(mod->core_layout.size); | 2647 | mod->core_layout.size = debug_align(mod->core_layout.size); |
2646 | 2648 | ||
2647 | /* Put string table section at end of init part of module. */ | 2649 | /* Put string table section at end of init part of module. */ |
@@ -2655,6 +2657,8 @@ static void layout_symtab(struct module *mod, struct load_info *info) | |||
2655 | __alignof__(struct mod_kallsyms)); | 2657 | __alignof__(struct mod_kallsyms)); |
2656 | info->mod_kallsyms_init_off = mod->init_layout.size; | 2658 | info->mod_kallsyms_init_off = mod->init_layout.size; |
2657 | mod->init_layout.size += sizeof(struct mod_kallsyms); | 2659 | mod->init_layout.size += sizeof(struct mod_kallsyms); |
2660 | info->init_typeoffs = mod->init_layout.size; | ||
2661 | mod->init_layout.size += nsrc * sizeof(char); | ||
2658 | mod->init_layout.size = debug_align(mod->init_layout.size); | 2662 | mod->init_layout.size = debug_align(mod->init_layout.size); |
2659 | } | 2663 | } |
2660 | 2664 | ||
@@ -2678,20 +2682,23 @@ static void add_kallsyms(struct module *mod, const struct load_info *info) | |||
2678 | mod->kallsyms->num_symtab = symsec->sh_size / sizeof(Elf_Sym); | 2682 | mod->kallsyms->num_symtab = symsec->sh_size / sizeof(Elf_Sym); |
2679 | /* Make sure we get permanent strtab: don't use info->strtab. */ | 2683 | /* Make sure we get permanent strtab: don't use info->strtab. */ |
2680 | mod->kallsyms->strtab = (void *)info->sechdrs[info->index.str].sh_addr; | 2684 | mod->kallsyms->strtab = (void *)info->sechdrs[info->index.str].sh_addr; |
2685 | mod->kallsyms->typetab = mod->init_layout.base + info->init_typeoffs; | ||
2681 | 2686 | ||
2682 | /* Set types up while we still have access to sections. */ | 2687 | /* |
2683 | for (i = 0; i < mod->kallsyms->num_symtab; i++) | 2688 | * Now populate the cut down core kallsyms for after init |
2684 | mod->kallsyms->symtab[i].st_size | 2689 | * and set types up while we still have access to sections. |
2685 | = elf_type(&mod->kallsyms->symtab[i], info); | 2690 | */ |
2686 | |||
2687 | /* Now populate the cut down core kallsyms for after init. */ | ||
2688 | mod->core_kallsyms.symtab = dst = mod->core_layout.base + info->symoffs; | 2691 | mod->core_kallsyms.symtab = dst = mod->core_layout.base + info->symoffs; |
2689 | mod->core_kallsyms.strtab = s = mod->core_layout.base + info->stroffs; | 2692 | mod->core_kallsyms.strtab = s = mod->core_layout.base + info->stroffs; |
2693 | mod->core_kallsyms.typetab = mod->core_layout.base + info->core_typeoffs; | ||
2690 | src = mod->kallsyms->symtab; | 2694 | src = mod->kallsyms->symtab; |
2691 | for (ndst = i = 0; i < mod->kallsyms->num_symtab; i++) { | 2695 | for (ndst = i = 0; i < mod->kallsyms->num_symtab; i++) { |
2696 | mod->kallsyms->typetab[i] = elf_type(src + i, info); | ||
2692 | if (i == 0 || is_livepatch_module(mod) || | 2697 | if (i == 0 || is_livepatch_module(mod) || |
2693 | is_core_symbol(src+i, info->sechdrs, info->hdr->e_shnum, | 2698 | is_core_symbol(src+i, info->sechdrs, info->hdr->e_shnum, |
2694 | info->index.pcpu)) { | 2699 | info->index.pcpu)) { |
2700 | mod->core_kallsyms.typetab[ndst] = | ||
2701 | mod->kallsyms->typetab[i]; | ||
2695 | dst[ndst] = src[i]; | 2702 | dst[ndst] = src[i]; |
2696 | dst[ndst++].st_name = s - mod->core_kallsyms.strtab; | 2703 | dst[ndst++].st_name = s - mod->core_kallsyms.strtab; |
2697 | s += strlcpy(s, &mod->kallsyms->strtab[src[i].st_name], | 2704 | s += strlcpy(s, &mod->kallsyms->strtab[src[i].st_name], |
@@ -4091,7 +4098,7 @@ int module_get_kallsym(unsigned int symnum, unsigned long *value, char *type, | |||
4091 | const Elf_Sym *sym = &kallsyms->symtab[symnum]; | 4098 | const Elf_Sym *sym = &kallsyms->symtab[symnum]; |
4092 | 4099 | ||
4093 | *value = kallsyms_symbol_value(sym); | 4100 | *value = kallsyms_symbol_value(sym); |
4094 | *type = sym->st_size; | 4101 | *type = kallsyms->typetab[symnum]; |
4095 | strlcpy(name, kallsyms_symbol_name(kallsyms, symnum), KSYM_NAME_LEN); | 4102 | strlcpy(name, kallsyms_symbol_name(kallsyms, symnum), KSYM_NAME_LEN); |
4096 | strlcpy(module_name, mod->name, MODULE_NAME_LEN); | 4103 | strlcpy(module_name, mod->name, MODULE_NAME_LEN); |
4097 | *exported = is_exported(name, *value, mod); | 4104 | *exported = is_exported(name, *value, mod); |