如何在struct“Elf64_Rela”中获取符号名称

时间:2017-07-26 07:05:11

标签: c elf ldd nm readelf

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/mman.h>
#include <errno.h>
#include <fcntl.h>
#include <elf.h>


Elf64_Rela *retab;
Elf64_Rela *retab_end;
Elf64_Ehdr *ehdr;
Elf64_Shdr *shdr;
char *strtab;

void elf_open(char *filename)
{

    int fd = open(filename, O_RDONLY);
    struct stat sbuf;
    fstat(fd, &sbuf);
    void *maddr = mmap(NULL, sbuf.st_size, PROT_READ, MAP_SHARED, fd, 0);
    close(fd);


    ehdr = maddr;
    shdr = (Elf64_Shdr *)(maddr + ehdr->e_shoff);
    for (int i = 0; i < ehdr->e_shnum; i++) 
    {
        if (shdr[i].sh_type == SHT_RELA) 
        {   
            retab = (Elf64_Rela *)(maddr + shdr[i].sh_offset);
            retab_end = (Elf64_Rela *)((char *)retab + shdr[i].sh_size);
            strtab = (char *)(maddr + shdr[shdr[i].sh_link].sh_offset);
            break;
        }
    }
}

int main()
{
    elf_open("lib1.so");
    Elf64_Rela *p = retab;

    while(p<retab_end)  
    {
        printf("%x %d\n",p->r_offset,p->r_info);

        p++;
    }
}

这是获取.rela.dyn部分的代码。但我不知道得到这个符号的名字。我知道Elf64_Rela结构没有name字段。在'SYMTAB'部分中,我可以使用&strtab[p->st_name]获取符号名称。我该怎么办?

typedef struct {
    Elf64_Addr r_offset;
    Elf64_Xword r_info;
    Elf64_Sxword r_addend;
} Elf64_Rela;

1 个答案:

答案 0 :(得分:1)

并非所有重定位都引用符号,因此您需要先检查ELF64_R_TYPE (p->r_info)。具有符号的重定位集是特定于体系结构的。

对于那些带符号的重定位,ELF64_R_SYM (p->r_info)应该是.dynsym部分中相关符号的索引。