2 // ELFManager.cpp: ELF format manager
6 // JPM = Jean-Paul Mari <djipi.mari@gmail.com>
9 // --- ---------- ------------------------------------------------------------
10 // JPM 12/01/2016 Created this file
11 // JPM 12/01/2016 ELF format support
12 // JPM 13/07/2017 ELF DWARF format support
17 #include "libelf/libelf.h"
18 #include "libelf/gelf.h"
21 #include "ELFManager.h"
22 #include "DwarfManager.h"
26 const char *SectionName
;
41 ELFSectionType ELFTabSectionType
[] = {
42 { "", ELF_NULL_TYPE
},
43 { ".text", ELF_text_TYPE
},
44 { ".rodata", ELF_rodata_TYPE
},
45 { ".data", ELF_data_TYPE
},
46 { ".bss", ELF_bss_TYPE
},
47 { ".heap", ELF_heap_TYPE
},
48 { ".debug_aranges", ELF_debug_aranges_TYPE
},
49 { ".debug_info", ELF_debug_info_TYPE
},
50 { ".debug_abbrev", ELF_debug_abbrev_TYPE
},
51 { ".debug_line", ELF_debug_line_TYPE
},
52 { ".debug_frame", ELF_debug_frame_TYPE
},
53 { ".debug_str", ELF_debug_str_TYPE
},
54 { ".debug_loc", ELF_debug_loc_TYPE
},
55 { ".debug_ranges", ELF_debug_ranges_TYPE
},
56 { ".comment", ELF_comment_TYPE
},
57 { ".shstrtab", ELF_shstrtab_TYPE
},
58 { ".symtab", ELF_symtab_TYPE
},
59 { ".strtab", ELF_strtab_TYPE
}
65 void *PtrExec
; // ELF executable
67 // ELF Dwarf management
71 size_t NbELFtabStruct
;
75 char *ELFManager_GetSymbolnameFromSymbolindex(size_t Index
);
78 // ELF section type detection
79 size_t ELFManager_GetSectionType(char *SectionName
)
83 for (i
= 0; i
< ELF_END_TYPE
; i
++)
85 if (!strcmp(ELFTabSectionType
[i
].SectionName
, SectionName
))
87 return (ELFTabSectionType
[i
].SectionType
);
91 return (size_t)ELF_NO_TYPE
;
95 // ELF manager executable copy
96 void *ELFManager_ExeCopy(void *src
, size_t size
)
98 if ((PtrExec
= malloc(size
)) != NULL
)
100 memcpy(PtrExec
, src
, size
);
107 Elf
*ELFManager_MemOpen(char *PtrELFExe
, size_t Size
)
109 return(ElfMem
= elf_memory(PtrELFExe
, Size
));
113 int ELFManager_MemEnd(void)
119 err
= elf_end(ElfMem
);
127 // ELF manager Initialisation
128 void ELFManager_Init(void)
138 // ELF manager Dwarf Initialisation
139 bool ELFManager_DwarfInit(Elf
*PtrElfMem
)
141 return (ElfDwarf
= (DWARFManager_ElfInit(PtrElfMem
) == DW_DLV_OK
) ? true : false);
146 void ELFManager_Reset(void)
150 DWARFManager_Reset();
162 while (NbELFtabStruct
)
164 free(ELFtab
[--NbELFtabStruct
]);
175 // ELF manager Closing
176 void ELFManager_Close(void)
182 // Save the ELF tab in memory
183 bool ELFManager_AddTab(void *Ptr
, size_t type
)
187 if ((ELFtab
= (ELFTab
**)calloc(1, sizeof(ELFTab
*))) == NULL
)
194 if ((ELFtab
= (ELFTab
**)realloc(ELFtab
, sizeof(ELFTab
*)*(NbELFtabStruct
+1))) == NULL
)
200 if ((ELFtab
[NbELFtabStruct
] = (ELFTab
*)calloc(1, sizeof(ELFTab
))) == NULL
)
206 ELFtab
[NbELFtabStruct
]->Type
= type
;
207 ELFtab
[NbELFtabStruct
]->PtrTab
= Ptr
;
214 // Get Address from his Symbol Name
215 // Return 0 if Symbol name is not found
216 size_t ELFManager_GetAdrFromSymbolName(char *SymbolName
)
223 for (size_t i
= 0; i
< NbELFtabStruct
; i
++)
225 if ((ELFtab
[i
]->Type
== ELF_symtab_TYPE
) && ((ELFtab
[i
]->PtrDataTab
) != NULL
))
229 while ((PtrST
= gelf_getsym(ELFtab
[i
]->PtrDataTab
, j
++, &ST
)) != NULL
)
231 if (!strcmp(ELFManager_GetSymbolnameFromSymbolindex(PtrST
->st_name
), SymbolName
))
233 Adr
= PtrST
->st_value
;
244 // Get Symbol name from his address
245 // Return NULL if Symbol name is not found
246 char *ELFManager_GetSymbolnameFromAdr(size_t Adr
)
248 char *SymbolName
= NULL
;
253 for (size_t i
= 0; i
< NbELFtabStruct
; i
++)
255 if ((ELFtab
[i
]->Type
== ELF_symtab_TYPE
) && ((ELFtab
[i
]->PtrDataTab
) != NULL
))
259 while ((PtrST
= gelf_getsym(ELFtab
[i
]->PtrDataTab
, j
++, &ST
)) != NULL
)
261 if (PtrST
->st_value
== Adr
)
263 WriteLog("ELF: .symtab: DATA: st_info=%0x, st_name=%0x, st_other=%0x, st_shndx=%0x, st_size=%0x, st_value=%0x\n", PtrST
->st_info
, PtrST
->st_name
, PtrST
->st_other
, PtrST
->st_shndx
, PtrST
->st_size
, PtrST
->st_value
);
264 SymbolName
= ELFManager_GetSymbolnameFromSymbolindex(PtrST
->st_name
);
275 // Get Symbol name from his Symbol index
276 char *ELFManager_GetSymbolnameFromSymbolindex(size_t Index
)
280 for (size_t i
= 0; i
< NbELFtabStruct
; i
++)
282 if ((ELFtab
[i
]->Type
== ELF_strtab_TYPE
) && ((ELFtab
[i
]->PtrDataTab
) != NULL
))
284 return ((char *)(ELFtab
[i
]->PtrDataTab
->d_buf
) + Index
);