Ejemplo n.º 1
0
int
elfx_update_shstrndx(Elf *elf, size_t value) {
    size_t extvalue = 0;
    Elf_Scn *scn;

    if (!elf) {
	return LIBELF_FAILURE;
    }
    elf_assert(elf->e_magic == ELF_MAGIC);
    if (value >= SHN_LORESERVE) {
	extvalue = value;
	value = SHN_XINDEX;
    }
    if (elf->e_kind != ELF_K_ELF) {
	seterr(ERROR_NOTELF);
	return LIBELF_FAILURE;
    }
    if (!elf->e_ehdr && !_elf_cook(elf)) {
	return LIBELF_FAILURE;
    }
    if (!(scn = _elf_first_scn(elf))) {
	return LIBELF_FAILURE;
    }
    elf_assert(scn->s_magic == SCN_MAGIC);
    if (elf->e_class == ELFCLASS32) {
	((Elf32_Ehdr*)elf->e_ehdr)->e_shstrndx = value;
	scn->s_shdr32.sh_link = extvalue;
    }
#if __LIBELF64
    else if (elf->e_class == ELFCLASS64) {
	((Elf64_Ehdr*)elf->e_ehdr)->e_shstrndx = value;
	scn->s_shdr64.sh_link = extvalue;
    }
#endif /* __LIBELF64 */
    else {
	if (valid_class(elf->e_class)) {
	    seterr(ERROR_UNIMPLEMENTED);
	}
	else {
	    seterr(ERROR_UNKNOWN_CLASS);
	}
	return LIBELF_FAILURE;
    }
    elf->e_ehdr_flags |= ELF_F_DIRTY;
    scn->s_shdr_flags |= ELF_F_DIRTY;
    return LIBELF_SUCCESS;
}
Ejemplo n.º 2
0
static Elf_Scn*
_buildscn(Elf *elf) {
    Elf_Scn *scn;

    if (!_elf_first_scn(elf)) {
	return NULL;
    }
    scn = elf->e_scn_n;
    elf_assert(scn);
    if (!(scn = _makescn(elf, scn->s_index + 1))) {
	return NULL;
    }
    if (_elf_update_shnum(elf, scn->s_index + 1)) {
	free(scn);
	return NULL;
    }
    elf->e_scn_n = elf->e_scn_n->s_link = scn;
    return scn;
}
Ejemplo n.º 3
0
static char*
_elf_newphdr(Elf *elf, size_t count, unsigned cls) {
    size_t extcount = 0;
    Elf_Scn *scn = NULL;
    char *phdr = NULL;
    size_t size;

    if (!elf) {
	return NULL;
    }
    elf_assert(elf->e_magic == ELF_MAGIC);
    if (!elf->e_ehdr && !elf->e_readable) {
	seterr(ERROR_NOEHDR);
    }
    else if (elf->e_kind != ELF_K_ELF) {
	seterr(ERROR_NOTELF);
    }
    else if (elf->e_class != cls) {
	seterr(ERROR_CLASSMISMATCH);
    }
    else if (elf->e_ehdr || _elf_cook(elf)) {
	size = _msize(cls, _elf_version, ELF_T_PHDR);
	elf_assert(size);
	if (!(scn = _elf_first_scn(elf))) {
	    return NULL;
	}
	if (count) {
	    if (!(phdr = (char*)malloc(count * size))) {
		seterr(ERROR_MEM_PHDR);
		return NULL;
	    }
	    memset(phdr, 0, count * size);
	}
	elf_assert(elf->e_ehdr);
	elf->e_phnum = count;
	if (count >= PN_XNUM) {
	    /*
	     * get NULL section (create it if necessary)
	     */
	    extcount = count;
	    count = PN_XNUM;
	}
	if (cls == ELFCLASS32) {
	    ((Elf32_Ehdr*)elf->e_ehdr)->e_phnum = count;
	    scn->s_shdr32.sh_info = extcount;
	}
#if __LIBELF64
	else if (cls == ELFCLASS64) {
	    ((Elf64_Ehdr*)elf->e_ehdr)->e_phnum = count;
	    scn->s_shdr64.sh_info = extcount;
	}
#endif /* __LIBELF64 */
	else {
	    seterr(ERROR_UNIMPLEMENTED);
	    if (phdr) {
		free(phdr);
	    }
	    return NULL;
	}
	if (elf->e_phdr) {
	    free(elf->e_phdr);
	}
	elf->e_phdr = phdr;
	elf->e_phdr_flags |= ELF_F_DIRTY;
	elf->e_ehdr_flags |= ELF_F_DIRTY;
	scn->s_scn_flags |= ELF_F_DIRTY;
	return phdr;
    }
    return NULL;
}