This commit is contained in:
Jack Halford 2017-10-26 19:15:27 +02:00
parent b8eadccc85
commit a565b7738d
11 changed files with 108 additions and 108 deletions

View file

@ -6,7 +6,7 @@
# By: wescande <wescande@student.42.fr> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ #
# Created: 2016/08/29 21:32:58 by wescande #+# #+# #
# Updated: 2017/10/07 17:50:04 by jhalford ### ########.fr #
# Updated: 2017/10/26 19:15:02 by jhalford ### ########.fr #
# #
# **************************************************************************** #
@ -37,24 +37,32 @@ SRC_BASE = \
dump_symtab.c\
ft_nm.c\
ft_otool.c\
mach_64.c\
symbol_filter.c\
symbol_format.c\
symbol_free.c\
symbol_init.c\
symbol_sort.c
mach_64/mach_64.c\
mach_64/symbol_64_filter.c\
mach_64/symbol_64_format.c\
mach_64/symbol_64_free.c\
mach_64/symbol_64_init.c\
mach_64/symbol_64_sort.c
SRCS = $(addprefix $(SRC_DIR), $(SRC_BASE))
OBJS = $(addprefix $(OBJ_DIR), $(SRC_BASE:.c=.o))
OBJS = $(addprefix $(OBJ_DIR), $($(notdir SRC_BASE):.c=.o))
OBJS := $(filter-out $(NM_OBJ), $(OBJS))
OBJS := $(filter-out $(OTOOL_OBJ), $(OBJS))
NB = $(words $(SRC_BASE))
INDEX = 0
all :
MACH_64_SRC := $(wildcard $(SRC_DIR)mach_64/*)
MACH_SRC := $(subst _64,_32, $(MACH_64_SRC:.c=.p))
all: $(MACH_SRC)
@make -C $(LIBFT_DIR)
@make -j $(NAME)
# $(SRC_DIR)/mach/%.c: $(SRC_DIR)/mach_64/%.c
$(MACH_SRC):
@mkdir -p $(SRC_DIR)/mach
@echo "$@ ---> $(subst _32,_64, $@)"
ft_nm: $(LIBFT_LIB) $(OBJ_DIR) $(OBJS) $(NM_OBJ)
@$(CC) $(OBJS) -o $@ \
-I $(INC_DIR) \
@ -111,6 +119,6 @@ re: fclean all
relib: fcleanlib $(LIBFT_LIB)
.PHONY : fclean clean re relib cleanlib fcleanlib
.PHONY : fclean clean re relib cleanlib fcleanlib $(MACH_SRC)
-include $(OBJS:.o=.d)

View file

@ -6,7 +6,7 @@
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/02/20 14:36:10 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:49:52 by jhalford ### ########.fr */
/* Updated: 2017/10/26 18:42:47 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
@ -72,7 +72,6 @@ typedef struct s_nmdata t_nmdata;
typedef enum e_symtype t_symtype;
typedef struct s_symbolmap t_symbolmap;
typedef struct s_machodata t_machodata;
typedef struct s_symbol t_symbol;
struct s_nmdata
{
@ -103,44 +102,18 @@ struct s_machodata
struct dysymtab_command *dysymtab;
};
struct s_symbol
{
int pos;
t_symtype type;
char *string;
struct nlist_64 *nlist;
struct section_64 *section;
};
struct s_symbolmap
{
char c;
char *s;
};
extern t_symbolmap g_symbolmap[];
extern t_machodata *g_data;
# include "mach_64.h"
int symbol_init(t_symbol *symbol,
char *stringtable, struct nlist_64 *array, int i);
int symbol_set(t_symbol *symbol, t_machodata *data);
void symbol_free(void *data, size_t size);
int symbol_sort(t_list **syms, t_flag flag);
int symbol_filter(t_list **syms, t_flag flag);
int is_external(t_symbol *s);
int is_not_external(t_symbol *s);
int symbol_format(t_symbol *symbol, t_nmdata *data);
void symbol_format_dfl(t_symbol *symbol);
void symbol_format_m(t_symbol *symbol);
void symbol_format_full(t_symbol *symbol);
void mach_64_dump(struct mach_header_64 *file,
t_nmdata *data);
void mach_64_parse(t_machodata *data);
void dump_dysymtab(t_machodata *data,
struct dysymtab_command *dysymtab);
extern t_symbolmap g_symbolmap[];
extern t_machodata *g_data;
#endif

View file

@ -0,0 +1,39 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* mach_64.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/10/26 18:39:31 by jhalford #+# #+# */
/* Updated: 2017/10/26 18:43:32 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef MACH_64_H
# define MACH_64_H
typedef struct s_symbol_64 t_symbol_64;
struct s_symbol_64
{
int pos;
t_symtype type;
char *string;
struct nlist_64 *nlist;
struct section_64 *section;
};
int symbol_64_init(t_symbol_64 *symbol,
char *stringtable, struct nlist_64 *array, int i);
int symbol_64_set(t_symbol_64 *symbol, t_machodata *data);
void symbol_64_free(void *data, size_t size);
int symbol_64_sort(t_list **syms, t_flag flag);
int symbol_64_filter(t_list **syms, t_flag flag);
int is_external_64(t_symbol_64 *s);
int is_not_external_64(t_symbol_64 *s);
int symbol_64_format(t_symbol_64 *symbol, t_nmdata *data);
void mach_64_dump(struct mach_header_64 *file,
t_nmdata *data);
#endif

View file

@ -6,7 +6,7 @@
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/02/19 03:09:12 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:33:42 by jhalford ### ########.fr */
/* Updated: 2017/10/26 18:46:22 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
@ -40,9 +40,9 @@ int nm_file(void *file, t_nmdata *data)
uint32_t magic;
magic = *(int*)file;
if (IS_MACH_64(magic))
if (IS_MACH_32(magic))
mach_64_dump(file, data);
else if (IS_MACH_32(magic))
else if (IS_MACH_64(magic))
mach_64_dump(file, data);
else if (IS_FAT(magic))
ft_printf("{red}unsupported arch:{eoc} magic=%#x(FAT)\n", magic);

View file

@ -6,16 +6,16 @@
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/10/23 16:06:44 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:42:06 by jhalford ### ########.fr */
/* Updated: 2017/10/26 18:45:25 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_nm_otool.h"
static void symtab_parse(t_machodata *data, struct symtab_command *symtab)
static void symtab_64_parse(t_machodata *data, struct symtab_command *symtab)
{
int i;
t_symbol symbol;
t_symbol_64 symbol;
char *stringtable;
struct nlist_64 *array;
@ -25,8 +25,8 @@ static void symtab_parse(t_machodata *data, struct symtab_command *symtab)
i = -1;
while (++i < (int)symtab->nsyms)
{
symbol_init(&symbol, stringtable, array, i);
symbol_set(&symbol, data);
symbol_64_init(&symbol, stringtable, array, i);
symbol_64_set(&symbol, data);
ft_lsteadd(&data->symbols, ft_lstnew(&symbol, sizeof(symbol)));
}
}
@ -61,7 +61,7 @@ void mach_64_parse(t_machodata *data)
while (++i < ncmds)
{
if (lc->cmd == LC_SYMTAB)
symtab_parse(data, (struct symtab_command*)lc);
symtab_64_parse(data, (struct symtab_command*)lc);
else if (lc->cmd == LC_DYSYMTAB)
data->dysymtab = (struct dysymtab_command*)lc;
else if (lc->cmd == LC_SEGMENT_64)
@ -78,7 +78,7 @@ void mach_64_dump(struct mach_header_64 *file, t_nmdata *data)
mach.symbols = NULL;
mach.file = file;
mach_64_parse(&mach);
symbol_sort(&mach.symbols, data->flag);
symbol_filter(&mach.symbols, data->flag);
ft_lstiter(mach.symbols, symbol_format, data);
symbol_64_sort(&mach.symbols, data->flag);
symbol_64_filter(&mach.symbols, data->flag);
ft_lstiter(mach.symbols, symbol_64_format, data);
}

View file

@ -1,33 +1,33 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* symbol_filter.c :+: :+: :+: */
/* symbol_64_filter.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/28 20:34:36 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:45:54 by jhalford ### ########.fr */
/* Created: 2017/10/26 18:31:27 by jhalford #+# #+# */
/* Updated: 2017/10/26 18:44:51 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_nm_otool.h"
int cmp_symtype(t_symbol *sym, void *type)
int cmp_symtype_64(t_symbol_64 *sym, void *type)
{
return ((1 << sym->type) & *(uint64_t*)type);
}
inline int is_not_external(t_symbol *s)
inline int is_not_external_64(t_symbol_64 *s)
{
return (!(s->nlist->n_type & N_EXT));
}
inline int is_external(t_symbol *s)
inline int is_external_64(t_symbol_64 *s)
{
return (s->nlist->n_type & N_EXT);
}
int symbol_filter(t_list **symbols, t_flag flag)
int symbol_64_filter(t_list **symbols, t_flag flag)
{
uint64_t allowed_syms;
@ -38,8 +38,8 @@ int symbol_filter(t_list **symbols, t_flag flag)
allowed_syms &= ~(1 << SYM_UNDF);
if (flag & NM_ONLY_UNDF)
allowed_syms &= (1 << SYM_UNDF);
ft_lst_filterout(symbols, &allowed_syms, cmp_symtype, symbol_free);
ft_lst_filterout(symbols, &allowed_syms, cmp_symtype_64, symbol_64_free);
if (flag & NM_NO_LOCAL)
ft_lst_filterout(symbols, NULL, is_external, symbol_free);
ft_lst_filterout(symbols, NULL, is_external_64, symbol_64_free);
return (0);
}

View file

@ -1,15 +1,3 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* symbol_format.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/28 20:34:32 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:31:36 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_nm_otool.h"
t_symbolmap g_symbolmap[] =
@ -25,11 +13,11 @@ t_symbolmap g_symbolmap[] =
{'I', "indirect"},
};
void symbol_format_desc(t_symbol *symbol)
void symbol_64_format_desc(t_symbol_64 *symbol)
{
if (symbol->nlist->n_desc & REFERENCED_DYNAMICALLY)
ft_printf(" [referenced dynamically]");
if (is_external(symbol))
if (is_external_64(symbol))
ft_printf(" external");
else
{
@ -39,7 +27,7 @@ void symbol_format_desc(t_symbol *symbol)
}
}
void symbol_format_m(t_symbol *symbol)
void symbol_64_format_m(t_symbol_64 *symbol)
{
t_symbolmap map;
@ -48,10 +36,10 @@ void symbol_format_m(t_symbol *symbol)
symbol->section ? symbol->section->segname : map.s,
symbol->section ? ',' : 0,
symbol->section ? symbol->section->sectname : "");
symbol_format_desc(symbol);
symbol_64_format_desc(symbol);
}
void symbol_format_full(t_symbol *symbol)
void symbol_64_format_full(t_symbol_64 *symbol)
{
ft_printf("\t%i %03b|%b|%x|%b \t%i(%s) \t%04x",
symbol->pos,
@ -63,12 +51,12 @@ void symbol_format_full(t_symbol *symbol)
symbol->nlist->n_desc);
}
void symbol_format_dfl(t_symbol *symbol)
void symbol_64_format_dfl(t_symbol_64 *symbol)
{
t_symbolmap map;
map = g_symbolmap[symbol->type];
if (is_external(symbol))
if (is_external_64(symbol))
ft_printf(" %c", map.c);
else
ft_printf(" %c", map.c + 'a' - 'A');
@ -78,7 +66,7 @@ void symbol_format_dfl(t_symbol *symbol)
symbol->nlist->n_type);
}
int symbol_format(t_symbol *symbol, t_nmdata *data)
int symbol_64_format(t_symbol_64 *symbol, t_nmdata *data)
{
if (data->flag & NM_OFORMAT)
ft_printf("%s: ", data->filename);
@ -89,11 +77,11 @@ int symbol_format(t_symbol *symbol, t_nmdata *data)
else
ft_printf("%016llx", symbol->nlist->n_value);
if (data->flag & NM_MFORMAT)
symbol_format_m(symbol);
symbol_64_format_m(symbol);
else if (data->flag & NM_FULL)
symbol_format_full(symbol);
symbol_64_format_full(symbol);
else
symbol_format_dfl(symbol);
symbol_64_format_dfl(symbol);
}
ft_printf(" %s\n", symbol->string);
return (0);

View file

@ -6,15 +6,15 @@
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/26 17:06:23 by jhalford #+# #+# */
/* Updated: 2017/03/26 17:09:53 by jhalford ### ########.fr */
/* Updated: 2017/10/26 18:38:31 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_nm_otool.h"
void symbol_free(void *data, size_t size)
void symbol_64_free(void *data, size_t size)
{
t_symbol *symbol;
t_symbol_64 *symbol;
symbol = data;
(void)size;

View file

@ -1,12 +1,12 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* symbol_init.c :+: :+: :+: */
/* symbol_64_init.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/25 21:22:06 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:41:15 by jhalford ### ########.fr */
/* Created: 2017/10/26 18:07:28 by jhalford #+# #+# */
/* Updated: 2017/10/26 18:23:24 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
@ -14,7 +14,7 @@
t_machodata *g_data;
int symbol_init(t_symbol *symbol,
int symbol_64_init(t_symbol_64 *symbol,
char *stringtable, struct nlist_64 *array, int i)
{
symbol->type = 0;
@ -24,11 +24,7 @@ int symbol_init(t_symbol *symbol,
return (0);
}
/*
** Calculate the sym->type field
*/
static int symbol_gettype(int type_mask,
static int symbol_64_gettype(int type_mask,
struct nlist_64 *nlist, struct section_64 *section)
{
if (nlist->n_type & N_STAB)
@ -51,11 +47,7 @@ static int symbol_gettype(int type_mask,
return (SYM_OTHER);
}
/*
** Construct symbol data
*/
int symbol_set(t_symbol *sym, t_machodata *data)
int symbol_64_set(t_symbol_64 *sym, t_machodata *data)
{
t_list *lst;
@ -66,7 +58,7 @@ int symbol_set(t_symbol *sym, t_machodata *data)
}
else
sym->section = NULL;
sym->type = symbol_gettype(
sym->type = symbol_64_gettype(
sym->nlist->n_type & N_TYPE,
sym->nlist,
sym->section);

View file

@ -6,25 +6,25 @@
/* By: jhalford <jack@crans.org> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/27 20:33:02 by jhalford #+# #+# */
/* Updated: 2017/10/23 16:38:29 by jhalford ### ########.fr */
/* Updated: 2017/10/26 18:46:04 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_nm_otool.h"
static int sym_asort(t_symbol *sym1, t_symbol *sym2)
static int sym_asort(t_symbol_64 *sym1, t_symbol_64 *sym2)
{
return (ft_strcmp(sym1->string, sym2->string));
}
static int sym_nsort(t_symbol *sym1, t_symbol *sym2)
static int sym_nsort(t_symbol_64 *sym1, t_symbol_64 *sym2)
{
if (sym1->nlist->n_value == sym2->nlist->n_value)
return (sym_asort(sym1, sym2));
return (sym1->nlist->n_value > sym2->nlist->n_value ? 1 : -1);
}
int symbol_sort(t_list **syms, t_flag flag)
int symbol_64_sort(t_list **syms, t_flag flag)
{
if (!(flag & NM_NOSORT))
{