diff options
author | norly <ny-git@enpas.org> | 2013-06-02 04:05:30 +0100 |
---|---|---|
committer | norly <ny-git@enpas.org> | 2013-06-03 02:08:46 +0100 |
commit | a08653637257ceaef8e61d965ab0d6c52b0c697d (patch) | |
tree | 8d5a0d2e1d42a582e0f4e98919817ecc7b5e1792 /src/model/fromFile.c | |
parent | c68a087b1de2fc9be1bfc588a7b207f97667f897 (diff) |
Guess where unknown functions are in .rel.plt
Diffstat (limited to 'src/model/fromFile.c')
-rw-r--r-- | src/model/fromFile.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/src/model/fromFile.c b/src/model/fromFile.c index 84ec143..23105e6 100644 --- a/src/model/fromFile.c +++ b/src/model/fromFile.c @@ -52,12 +52,14 @@ static ElfuSymtab* symtabFromScn32(ElfuScn *ms, ElfuScn**origScnArr) case SHN_ABS: case SHN_COMMON: sym->scnptr = NULL; + sym->shndx = cursym->st_shndx; break; default: sym->scnptr = origScnArr[cursym->st_shndx - 1]; break; } + CIRCLEQ_INSERT_TAIL(&st->syms, sym, elem); } @@ -404,6 +406,7 @@ ElfuElf* elfu_mFromElf(Elf *e) switch (ms->shdr.sh_type) { case SHT_SYMTAB: + case SHT_DYNSYM: if (me->elfclass == ELFCLASS32) { ms->symtab = symtabFromScn32(ms, secArray); } else if (me->elfclass == ELFCLASS64) { |