diff options
author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2011-04-16 18:30:57 +0000 |
---|---|---|
committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2011-04-16 18:30:57 +0000 |
commit | 5ed970594e5968204fd460981508316edc4c0298 (patch) | |
tree | e6fb6200183e257b8f8cf45857f359b053bd2a0d /target/linux/generic/patches-2.6.38/310-arm_module_unresolved_weak_sym.patch | |
parent | 837777d736d83a89c1473730332e9b8890dd09e7 (diff) |
kernel: reorganize 2.6.38 patches, clean up block2mtd patches
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@26690 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/generic/patches-2.6.38/310-arm_module_unresolved_weak_sym.patch')
-rw-r--r-- | target/linux/generic/patches-2.6.38/310-arm_module_unresolved_weak_sym.patch | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/target/linux/generic/patches-2.6.38/310-arm_module_unresolved_weak_sym.patch b/target/linux/generic/patches-2.6.38/310-arm_module_unresolved_weak_sym.patch new file mode 100644 index 0000000000..fe7027c070 --- /dev/null +++ b/target/linux/generic/patches-2.6.38/310-arm_module_unresolved_weak_sym.patch @@ -0,0 +1,13 @@ +--- a/arch/arm/kernel/module.c ++++ b/arch/arm/kernel/module.c +@@ -98,6 +98,10 @@ apply_relocate(Elf32_Shdr *sechdrs, cons + return -ENOEXEC; + } + ++ if ((IS_ERR_VALUE(sym->st_value) || !sym->st_value) && ++ ELF_ST_BIND(sym->st_info) == STB_WEAK) ++ continue; ++ + loc = dstsec->sh_addr + rel->r_offset; + + switch (ELF32_R_TYPE(rel->r_info)) { |