radare2/libr/bin/p/bin_elf.c
Nibble 94445e1540 * Change the name of some types
- s/u64/ut64/
  - s/u32/ut32/
  - s/u16/ut16/
  - s/u8/ut8/
2009-07-08 13:49:55 +02:00

253 lines
6.4 KiB
C

/* radare - GPL3 - Copyright 2009 nibble<.ds@gmail.com> */
#include <r_types.h>
#include <r_lib.h>
#include <r_bin.h>
#include "elf/elf.h"
static int bopen(struct r_bin_t *bin)
{
if((bin->bin_obj = MALLOC_STRUCT(struct Elf_(r_bin_elf_obj_t))) == NULL)
return R_FALSE;
if ((bin->fd = Elf_(r_bin_elf_open)(bin->bin_obj,bin->file,bin->rw)) == -1) {
free(bin->bin_obj);
return R_FALSE;
}
return bin->fd;
}
static int bclose(struct r_bin_t *bin)
{
return Elf_(r_bin_elf_close)(bin->bin_obj);
}
static ut64 baddr(struct r_bin_t *bin)
{
return Elf_(r_bin_elf_get_baddr)(bin->bin_obj);
}
static struct r_bin_entry_t* entry(struct r_bin_t *bin)
{
struct r_bin_entry_t *ret = NULL;
if((ret = MALLOC_STRUCT(struct r_bin_entry_t)) == NULL)
return NULL;
memset(ret, '\0', sizeof(struct r_bin_entry_t));
ret->offset = ret->rva = Elf_(r_bin_elf_get_entry_offset)(bin->bin_obj);
return ret;
}
static struct r_bin_section_t* sections(struct r_bin_t *bin)
{
struct r_bin_section_t *ret = NULL;
struct r_bin_elf_section_t *section = NULL;
int i, sections_count;
section = Elf_(r_bin_elf_get_sections)(bin->bin_obj);
for (sections_count = 0; section && !section[sections_count].last; sections_count++);
if ((ret = malloc((sections_count + 1) * sizeof(struct r_bin_section_t))) == NULL)
return NULL;
for (i = 0; i < sections_count; i++) {
strncpy(ret[i].name, (char*)section[i].name, R_BIN_SIZEOF_STRINGS);
ret[i].size = section[i].size;
ret[i].vsize = section[i].size;
ret[i].offset = section[i].offset;
ret[i].rva = section[i].offset;
ret[i].characteristics = 0;
if (R_BIN_ELF_SCN_IS_EXECUTABLE(section[i].flags))
ret[i].characteristics |= 0x1;
if (R_BIN_ELF_SCN_IS_WRITABLE(section[i].flags))
ret[i].characteristics |= 0x2;
if (R_BIN_ELF_SCN_IS_READABLE(section[i].flags))
ret[i].characteristics |= 0x4;
ret[i].last = 0;
}
ret[i].last = 1;
free(section);
return ret;
}
static struct r_bin_symbol_t* symbols(struct r_bin_t *bin)
{
int symbols_count, i;
struct r_bin_symbol_t *ret = NULL;
struct r_bin_elf_symbol_t *symbol = NULL;
symbol = Elf_(r_bin_elf_get_symbols)(bin->bin_obj, R_BIN_ELF_SYMBOLS);
for (symbols_count = 0; symbol && !symbol[symbols_count].last; symbols_count++);
if ((ret = malloc((symbols_count + 1) * sizeof(struct r_bin_symbol_t))) == NULL)
return NULL;
for (i = 0; i < symbols_count; i++) {
strncpy(ret[i].name, symbol[i].name, R_BIN_SIZEOF_STRINGS);
strncpy(ret[i].forwarder, "NONE", R_BIN_SIZEOF_STRINGS);
strncpy(ret[i].bind, symbol[i].bind, R_BIN_SIZEOF_STRINGS);
strncpy(ret[i].type, symbol[i].type, R_BIN_SIZEOF_STRINGS);
ret[i].rva = symbol[i].offset;
ret[i].offset = symbol[i].offset;
ret[i].size = symbol[i].size;
ret[i].ordinal = 0;
ret[i].last = 0;
}
ret[i].last = 1;
free(symbol);
return ret;
}
static struct r_bin_import_t* imports(struct r_bin_t *bin)
{
int imports_count, i;
struct r_bin_import_t *ret = NULL;
struct r_bin_elf_symbol_t *import = NULL;
import = Elf_(r_bin_elf_get_symbols)(bin->bin_obj, R_BIN_ELF_IMPORTS);
for (imports_count = 0; import && !import[imports_count].last; imports_count++);
if ((ret = malloc((imports_count + 1) * sizeof(struct r_bin_import_t))) == NULL)
return NULL;
for (i = 0; i < imports_count; i++) {
strncpy(ret[i].name, import[i].name, R_BIN_SIZEOF_STRINGS);
strncpy(ret[i].bind, import[i].bind, R_BIN_SIZEOF_STRINGS);
strncpy(ret[i].type, import[i].type, R_BIN_SIZEOF_STRINGS);
ret[i].rva = import[i].offset;
ret[i].offset = import[i].offset;
ret[i].ordinal = 0;
ret[i].hint = 0;
ret[i].last = 0;
}
ret[i].last = 1;
free(import);
return ret;
}
static struct r_bin_info_t* info(struct r_bin_t *bin)
{
struct r_bin_info_t *ret = NULL;
char *string;
if((ret = malloc(sizeof(struct r_bin_info_t))) == NULL)
return NULL;
memset(ret, '\0', sizeof(struct r_bin_info_t));
if ((string = Elf_(r_bin_elf_get_file_type)(bin->bin_obj)) == NULL)
return NULL;
strncpy(ret->type, string, R_BIN_SIZEOF_STRINGS);
free(string);
if ((string = Elf_(r_bin_elf_get_elf_class)(bin->bin_obj)) == NULL)
return NULL;
strncpy(ret->class, string, R_BIN_SIZEOF_STRINGS);
free(string);
if ((string = Elf_(r_bin_elf_get_osabi_name)(bin->bin_obj)) == NULL)
return NULL;
strncpy(ret->os, string, R_BIN_SIZEOF_STRINGS);
free(string);
if ((string = Elf_(r_bin_elf_get_osabi_name)(bin->bin_obj)) == NULL)
return NULL;
strncpy(ret->subsystem, string, R_BIN_SIZEOF_STRINGS);
free(string);
if ((string = Elf_(r_bin_elf_get_machine_name)(bin->bin_obj)) == NULL)
return NULL;
strncpy(ret->machine, string, R_BIN_SIZEOF_STRINGS);
free(string);
if ((string = Elf_(r_bin_elf_get_arch)(bin->bin_obj)) == NULL)
return NULL;
strncpy(ret->arch, string, R_BIN_SIZEOF_STRINGS);
free(string);
strncpy(ret->rclass, "elf", R_BIN_SIZEOF_STRINGS);
ret->big_endian=Elf_(r_bin_elf_is_big_endian)(bin->bin_obj);
ret->dbg_info = 0;
if (Elf_(r_bin_elf_get_stripped)(bin->bin_obj)) {
ret->dbg_info |= 0x01;
} else {
ret->dbg_info |= 0x04;
ret->dbg_info |= 0x08;
ret->dbg_info |= 0x10;
}
if (Elf_(r_bin_elf_get_static)(bin->bin_obj))
ret->dbg_info |= 0x02;
return ret;
}
static struct r_bin_field_t* fields(struct r_bin_t *bin)
{
struct r_bin_field_t *ret = NULL;
struct r_bin_elf_field_t *field = NULL;
int i, fields_count;
field = Elf_(r_bin_elf_get_fields)(bin->bin_obj);
for (fields_count = 0; field && !field[fields_count].last; fields_count++);
if ((ret = malloc((fields_count + 1) * sizeof(struct r_bin_field_t))) == NULL)
return NULL;
for (i = 0; i < fields_count; i++) {
strncpy(ret[i].name, field[i].name, R_BIN_SIZEOF_STRINGS);
ret[i].rva = field[i].offset;
ret[i].offset = field[i].offset;
ret[i].last = 0;
}
ret[i].last = 1;
free(field);
return ret;
}
#if !R_BIN_ELF64
static int check(struct r_bin_t *bin)
{
int ret = R_FALSE;
ut8 buf[8];
if ((bin->fd = open(bin->file, 0)) != -1) {
lseek(bin->fd, 0, SEEK_SET);
read(bin->fd, buf, 8);
close(bin->fd);
/* buf[EI_CLASS] == ELFCLASS32 */
if (!memcmp(buf, "\x7F\x45\x4c\x46\x01", 5))
ret = R_TRUE;
}
return ret;
}
struct r_bin_handle_t r_bin_plugin_elf = {
.name = "bin_elf",
.desc = "elf bin plugin",
.init = NULL,
.fini = NULL,
.open = &bopen,
.close = &bclose,
.check = &check,
.baddr = &baddr,
.entry = &entry,
.sections = &sections,
.symbols = &symbols,
.imports = &imports,
.strings = NULL,
.info = &info,
.fields = &fields,
};
#ifndef CORELIB
struct r_lib_struct_t radare_plugin = {
.type = R_LIB_TYPE_BIN,
.data = &r_bin_plugin_elf
};
#endif
#endif