|
@@ -1697,6 +1697,15 @@ static void unset_module_core_ro_nx(struct module *mod) { }
|
|
|
static void unset_module_init_ro_nx(struct module *mod) { }
|
|
|
#endif
|
|
|
|
|
|
+void __weak module_free(struct module *mod, void *module_region)
|
|
|
+{
|
|
|
+ vfree(module_region);
|
|
|
+}
|
|
|
+
|
|
|
+void __weak module_arch_cleanup(struct module *mod)
|
|
|
+{
|
|
|
+}
|
|
|
+
|
|
|
/* Free a module, remove from lists, etc. */
|
|
|
static void free_module(struct module *mod)
|
|
|
{
|
|
@@ -1851,6 +1860,26 @@ static int simplify_symbols(struct module *mod, const struct load_info *info)
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
+int __weak apply_relocate(Elf_Shdr *sechdrs,
|
|
|
+ const char *strtab,
|
|
|
+ unsigned int symindex,
|
|
|
+ unsigned int relsec,
|
|
|
+ struct module *me)
|
|
|
+{
|
|
|
+ pr_err("module %s: REL relocation unsupported\n", me->name);
|
|
|
+ return -ENOEXEC;
|
|
|
+}
|
|
|
+
|
|
|
+int __weak apply_relocate_add(Elf_Shdr *sechdrs,
|
|
|
+ const char *strtab,
|
|
|
+ unsigned int symindex,
|
|
|
+ unsigned int relsec,
|
|
|
+ struct module *me)
|
|
|
+{
|
|
|
+ pr_err("module %s: RELA relocation unsupported\n", me->name);
|
|
|
+ return -ENOEXEC;
|
|
|
+}
|
|
|
+
|
|
|
static int apply_relocations(struct module *mod, const struct load_info *info)
|
|
|
{
|
|
|
unsigned int i;
|
|
@@ -2235,6 +2264,11 @@ static void dynamic_debug_remove(struct _ddebug *debug)
|
|
|
ddebug_remove_module(debug->modname);
|
|
|
}
|
|
|
|
|
|
+void * __weak module_alloc(unsigned long size)
|
|
|
+{
|
|
|
+ return size == 0 ? NULL : vmalloc_exec(size);
|
|
|
+}
|
|
|
+
|
|
|
static void *module_alloc_update_bounds(unsigned long size)
|
|
|
{
|
|
|
void *ret = module_alloc(size);
|
|
@@ -2645,6 +2679,14 @@ static void flush_module_icache(const struct module *mod)
|
|
|
set_fs(old_fs);
|
|
|
}
|
|
|
|
|
|
+int __weak module_frob_arch_sections(Elf_Ehdr *hdr,
|
|
|
+ Elf_Shdr *sechdrs,
|
|
|
+ char *secstrings,
|
|
|
+ struct module *mod)
|
|
|
+{
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
static struct module *layout_and_allocate(struct load_info *info)
|
|
|
{
|
|
|
/* Module within temporary copy. */
|
|
@@ -2716,6 +2758,13 @@ static void module_deallocate(struct module *mod, struct load_info *info)
|
|
|
module_free(mod, mod->module_core);
|
|
|
}
|
|
|
|
|
|
+int __weak module_finalize(const Elf_Ehdr *hdr,
|
|
|
+ const Elf_Shdr *sechdrs,
|
|
|
+ struct module *me)
|
|
|
+{
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
static int post_relocation(struct module *mod, const struct load_info *info)
|
|
|
{
|
|
|
/* Sort exception table now relocations are done. */
|