#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;
答案 0 :(得分:1)
并非所有重定位都引用符号,因此您需要先检查ELF64_R_TYPE (p->r_info)
。具有符号的重定位集是特定于体系结构的。
对于那些带符号的重定位,ELF64_R_SYM (p->r_info)
应该是.dynsym
部分中相关符号的索引。