Modules updates for v5.2
Summary of modules changes for the 5.2 merge window: - Use a separate table to store symbol types instead of hijacking fields in struct Elf_Sym - Trivial code cleanups Signed-off-by: Jessica Yu <jeyu@kernel.org> -----BEGIN PGP SIGNATURE----- iQIcBAABCgAGBQJc2W9gAAoJEMBFfjjOO8FyAqkP+wbCB42LJ8kD2H+pbxpsf7vU T1+5fZ3rfyLqHDc9Pzt1K6SBR04aLq8OXW3nOIQ5kmirSstiznokAExQBjeMegVJ 14Q5IxOSQ44rBPg5ggCA6s9qNyw2fqgwKWQKXLW+VmYAHiBfIBV0mO576KWIEgE1 vOCQPqW0ccfmjEssumEYMSePg01LATjso3PMcdJm6yI74xSGd8n872y36BleAP8M 232L8B4fuZEuHJ1QaBnXdapKibyMX3k3WbfK9U2RzSWaGjmuBXwihCB+ZA6HCiRX MVwXQwh63UGCZLYkXnGMwPNgX5TTZRiPT4oIhB0tGIXkEFX/DlA+NGfuinEAYuKS M0zhjgjSOKYEhNy1GtirbHjNCC4ULF0OZvD/dB8InQON0/t5Duq3sOHSp9+rWMg7 yuHy3NJGHHd65nGd7u7vXmdZXct/NVDdahKhqRA8i+HOxUBdF9vvMMnSASXufWFt j5GSFA5/IZKpYofho/jvJK2rmQQVkVpD9zWCZcv8BNT124W4cZ5swOOSVYOnSAJb Wvy1oknjF/HrKIft3UIFR0FU8uIueP0mtnna2B9SBVfZm7rM+/3+a1D/UOHaLtuO ++b1sIOpyApevRZcXpTnH63ZaO2tRC7KnDzaBT8FTZimEyV5KdD6Ec2MKJdi8Nkb Pr099LJ2i/i8rQbkjM1i =NO31 -----END PGP SIGNATURE----- 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
This commit is contained in:
commit
280664f558
|
@ -332,7 +332,6 @@
|
||||||
__start_rodata = .; \
|
__start_rodata = .; \
|
||||||
*(.rodata) *(.rodata.*) \
|
*(.rodata) *(.rodata.*) \
|
||||||
RO_AFTER_INIT_DATA /* Read only after init */ \
|
RO_AFTER_INIT_DATA /* Read only after init */ \
|
||||||
KEEP(*(__vermagic)) /* Kernel version magic */ \
|
|
||||||
. = ALIGN(8); \
|
. = ALIGN(8); \
|
||||||
__start___tracepoints_ptrs = .; \
|
__start___tracepoints_ptrs = .; \
|
||||||
KEEP(*(__tracepoints_ptrs)) /* Tracepoints: pointer array */ \
|
KEEP(*(__tracepoints_ptrs)) /* Tracepoints: pointer array */ \
|
||||||
|
|
|
@ -332,6 +332,7 @@ struct mod_kallsyms {
|
||||||
Elf_Sym *symtab;
|
Elf_Sym *symtab;
|
||||||
unsigned int num_symtab;
|
unsigned int num_symtab;
|
||||||
char *strtab;
|
char *strtab;
|
||||||
|
char *typetab;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_LIVEPATCH
|
#ifdef CONFIG_LIVEPATCH
|
||||||
|
@ -717,6 +718,17 @@ static inline bool within_module_core(unsigned long addr,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline bool within_module_init(unsigned long addr,
|
||||||
|
const struct module *mod)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline bool within_module(unsigned long addr, const struct module *mod)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/* Get/put a kernel symbol (calls should be symmetric) */
|
/* Get/put a kernel symbol (calls should be symmetric) */
|
||||||
#define symbol_get(x) ({ extern typeof(x) x __attribute__((weak)); &(x); })
|
#define symbol_get(x) ({ extern typeof(x) x __attribute__((weak)); &(x); })
|
||||||
#define symbol_put(x) do { } while (0)
|
#define symbol_put(x) do { } while (0)
|
||||||
|
|
|
@ -20,7 +20,7 @@ struct load_info {
|
||||||
unsigned long len;
|
unsigned long len;
|
||||||
Elf_Shdr *sechdrs;
|
Elf_Shdr *sechdrs;
|
||||||
char *secstrings, *strtab;
|
char *secstrings, *strtab;
|
||||||
unsigned long symoffs, stroffs;
|
unsigned long symoffs, stroffs, init_typeoffs, core_typeoffs;
|
||||||
struct _ddebug *debug;
|
struct _ddebug *debug;
|
||||||
unsigned int num_debug;
|
unsigned int num_debug;
|
||||||
bool sig_ok;
|
bool sig_ok;
|
||||||
|
|
|
@ -2642,6 +2642,8 @@ static void layout_symtab(struct module *mod, struct load_info *info)
|
||||||
info->symoffs = ALIGN(mod->core_layout.size, symsect->sh_addralign ?: 1);
|
info->symoffs = ALIGN(mod->core_layout.size, symsect->sh_addralign ?: 1);
|
||||||
info->stroffs = mod->core_layout.size = info->symoffs + ndst * sizeof(Elf_Sym);
|
info->stroffs = mod->core_layout.size = info->symoffs + ndst * sizeof(Elf_Sym);
|
||||||
mod->core_layout.size += strtab_size;
|
mod->core_layout.size += strtab_size;
|
||||||
|
info->core_typeoffs = mod->core_layout.size;
|
||||||
|
mod->core_layout.size += ndst * sizeof(char);
|
||||||
mod->core_layout.size = debug_align(mod->core_layout.size);
|
mod->core_layout.size = debug_align(mod->core_layout.size);
|
||||||
|
|
||||||
/* Put string table section at end of init part of module. */
|
/* 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)
|
||||||
__alignof__(struct mod_kallsyms));
|
__alignof__(struct mod_kallsyms));
|
||||||
info->mod_kallsyms_init_off = mod->init_layout.size;
|
info->mod_kallsyms_init_off = mod->init_layout.size;
|
||||||
mod->init_layout.size += sizeof(struct mod_kallsyms);
|
mod->init_layout.size += sizeof(struct mod_kallsyms);
|
||||||
|
info->init_typeoffs = mod->init_layout.size;
|
||||||
|
mod->init_layout.size += nsrc * sizeof(char);
|
||||||
mod->init_layout.size = debug_align(mod->init_layout.size);
|
mod->init_layout.size = debug_align(mod->init_layout.size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2678,20 +2682,23 @@ static void add_kallsyms(struct module *mod, const struct load_info *info)
|
||||||
mod->kallsyms->num_symtab = symsec->sh_size / sizeof(Elf_Sym);
|
mod->kallsyms->num_symtab = symsec->sh_size / sizeof(Elf_Sym);
|
||||||
/* Make sure we get permanent strtab: don't use info->strtab. */
|
/* Make sure we get permanent strtab: don't use info->strtab. */
|
||||||
mod->kallsyms->strtab = (void *)info->sechdrs[info->index.str].sh_addr;
|
mod->kallsyms->strtab = (void *)info->sechdrs[info->index.str].sh_addr;
|
||||||
|
mod->kallsyms->typetab = mod->init_layout.base + info->init_typeoffs;
|
||||||
|
|
||||||
/* Set types up while we still have access to sections. */
|
/*
|
||||||
for (i = 0; i < mod->kallsyms->num_symtab; i++)
|
* Now populate the cut down core kallsyms for after init
|
||||||
mod->kallsyms->symtab[i].st_size
|
* and set types up while we still have access to sections.
|
||||||
= elf_type(&mod->kallsyms->symtab[i], info);
|
*/
|
||||||
|
|
||||||
/* Now populate the cut down core kallsyms for after init. */
|
|
||||||
mod->core_kallsyms.symtab = dst = mod->core_layout.base + info->symoffs;
|
mod->core_kallsyms.symtab = dst = mod->core_layout.base + info->symoffs;
|
||||||
mod->core_kallsyms.strtab = s = mod->core_layout.base + info->stroffs;
|
mod->core_kallsyms.strtab = s = mod->core_layout.base + info->stroffs;
|
||||||
|
mod->core_kallsyms.typetab = mod->core_layout.base + info->core_typeoffs;
|
||||||
src = mod->kallsyms->symtab;
|
src = mod->kallsyms->symtab;
|
||||||
for (ndst = i = 0; i < mod->kallsyms->num_symtab; i++) {
|
for (ndst = i = 0; i < mod->kallsyms->num_symtab; i++) {
|
||||||
|
mod->kallsyms->typetab[i] = elf_type(src + i, info);
|
||||||
if (i == 0 || is_livepatch_module(mod) ||
|
if (i == 0 || is_livepatch_module(mod) ||
|
||||||
is_core_symbol(src+i, info->sechdrs, info->hdr->e_shnum,
|
is_core_symbol(src+i, info->sechdrs, info->hdr->e_shnum,
|
||||||
info->index.pcpu)) {
|
info->index.pcpu)) {
|
||||||
|
mod->core_kallsyms.typetab[ndst] =
|
||||||
|
mod->kallsyms->typetab[i];
|
||||||
dst[ndst] = src[i];
|
dst[ndst] = src[i];
|
||||||
dst[ndst++].st_name = s - mod->core_kallsyms.strtab;
|
dst[ndst++].st_name = s - mod->core_kallsyms.strtab;
|
||||||
s += strlcpy(s, &mod->kallsyms->strtab[src[i].st_name],
|
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,
|
||||||
const Elf_Sym *sym = &kallsyms->symtab[symnum];
|
const Elf_Sym *sym = &kallsyms->symtab[symnum];
|
||||||
|
|
||||||
*value = kallsyms_symbol_value(sym);
|
*value = kallsyms_symbol_value(sym);
|
||||||
*type = sym->st_size;
|
*type = kallsyms->typetab[symnum];
|
||||||
strlcpy(name, kallsyms_symbol_name(kallsyms, symnum), KSYM_NAME_LEN);
|
strlcpy(name, kallsyms_symbol_name(kallsyms, symnum), KSYM_NAME_LEN);
|
||||||
strlcpy(module_name, mod->name, MODULE_NAME_LEN);
|
strlcpy(module_name, mod->name, MODULE_NAME_LEN);
|
||||||
*exported = is_exported(name, *value, mod);
|
*exported = is_exported(name, *value, mod);
|
||||||
|
|
Loading…
Reference in New Issue