42-archive/nm-otool/srcs/mach_64/mach_64.c

69 lines
2.2 KiB
C

/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* mach_64.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/10/23 16:06:44 by jhalford #+# #+# */
/* Updated: 2017/10/30 16:58:03 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_nm_otool.h"
static void symtab_64_parse(t_machodata *data, struct symtab_command *symtab)
{
int i;
t_symbol_64 symbol;
char *stringtable;
struct nlist_64 *array;
data->symtab = symtab;
stringtable = data->file + endian(symtab->stroff, 32);
array = (struct nlist_64*)(data->file + endian(symtab->symoff, 32));
i = -1;
while (++i < (int)symtab->nsyms)
{
symbol_64_init(&symbol, stringtable, array, i);
symbol_64_set(&symbol, data);
ft_lsteadd(&data->symbols, ft_lstnew(&symbol, sizeof(symbol)));
}
}
static void seg_64_parse(t_machodata *data, struct segment_command_64 *seg)
{
uint32_t nsects;
uint32_t i;
struct section_64 *sect;
nsects = endian(seg->nsects, 32);
sect = (void*)(seg + 1);
i = -1;
while (++i < nsects)
{
ft_lsteadd(&data->sects, ft_lstnew(&sect, sizeof(sect)));
sect = sect + 1;
}
}
void mach_64_parse(t_machodata *data)
{
uint32_t ncmds;
uint32_t i;
struct load_command *lc;
struct mach_header_64 *header;
header = data->file;
ncmds = endian(header->ncmds, 32);
lc = (void*)(header + 1);
i = -1;
while (++i < ncmds)
{
if (endian(lc->cmd, 32) == LC_SYMTAB)
symtab_64_parse(data, (struct symtab_command*)lc);
else if (lc->cmd == LC_SEGMENT_64)
seg_64_parse(data, (struct segment_command_64*)lc);
lc = (void*)lc + endian(lc->cmdsize, 32);
}
}