⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 elf-x86-amd64.c

📁 支持AMD64的汇编编译器源码
💻 C
字号:
/* * ELF object format helpers - x86:amd64 * *  Copyright (C) 2004  Michael Urman * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND OTHER CONTRIBUTORS ``AS IS'' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR OTHER CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */#include <util.h>/*@unused@*/ RCSID("$Id: elf-x86-amd64.c 1168 2004-10-31 01:07:52Z peter $");#define YASM_LIB_INTERNAL#define YASM_EXPR_INTERNAL#include <libyasm.h>#define YASM_OBJFMT_ELF_INTERNAL#include "elf.h"#include "elf-machine.h"enum ssym_index {    SSYM_GOTPCREL = 0,    SSYM_GOT,    SSYM_PLT};static intelf_x86_amd64_accepts_reloc(size_t val, yasm_symrec *wrt, yasm_symrec **ssyms){    if (wrt) {	if ((wrt == ssyms[SSYM_GOTPCREL] && val == 32)	    || (wrt == ssyms[SSYM_GOT] && val == 32)	    || (wrt == ssyms[SSYM_PLT] && val == 32))	    return 1;	else	    return 0;    }    return (val&(val-1)) ? 0 : ((val & (8|16|32|64)) != 0);}static voidelf_x86_amd64_write_symtab_entry(unsigned char *bufp,                                 elf_symtab_entry *entry,                                 yasm_intnum *value_intn,                                 yasm_intnum *size_intn){    YASM_WRITE_32_L(bufp, entry->name ? entry->name->index : 0);    YASM_WRITE_8(bufp, ELF64_ST_INFO(entry->bind, entry->type));    YASM_WRITE_8(bufp, 0);    if (entry->sect) {        if (yasm_section_is_absolute(entry->sect)) {            YASM_WRITE_16_L(bufp, SHN_ABS);        } else {            elf_secthead *shead = yasm_section_get_data(entry->sect,                &elf_section_data);            if (!shead)                yasm_internal_error(                    N_("symbol references section without data"));            YASM_WRITE_16_L(bufp, shead->index);        }    } else {        YASM_WRITE_16_L(bufp, entry->index);    }    YASM_WRITE_64I_L(bufp, value_intn);    YASM_WRITE_64I_L(bufp, size_intn);}static voidelf_x86_amd64_write_secthead(unsigned char *bufp, elf_secthead *shead){    YASM_WRITE_32_L(bufp, shead->name ? shead->name->index : 0);    YASM_WRITE_32_L(bufp, shead->type);    YASM_WRITE_64Z_L(bufp, shead->flags);    YASM_WRITE_64Z_L(bufp, 0);		/* vmem address */    YASM_WRITE_64Z_L(bufp, shead->offset);    YASM_WRITE_64I_L(bufp, shead->size);    YASM_WRITE_32_L(bufp, shead->link);    YASM_WRITE_32_L(bufp, shead->info);    if (shead->align)        YASM_WRITE_64I_L(bufp, shead->align);    else        YASM_WRITE_64Z_L(bufp, 0);    YASM_WRITE_64Z_L(bufp, shead->entsize);    }static voidelf_x86_amd64_write_secthead_rel(unsigned char *bufp,                                 elf_secthead *shead,                                 elf_section_index symtab_idx,                                 elf_section_index sindex){    yasm_intnum *nreloc;    yasm_intnum *relocsize;    YASM_WRITE_32_L(bufp, shead->rel_name ? shead->rel_name->index : 0);    YASM_WRITE_32_L(bufp, SHT_RELA);    YASM_WRITE_64Z_L(bufp, 0);    YASM_WRITE_64Z_L(bufp, 0);    YASM_WRITE_64Z_L(bufp, shead->rel_offset);    nreloc = yasm_intnum_create_uint(shead->nreloc);    relocsize = yasm_intnum_create_uint(RELOC64A_SIZE);    yasm_intnum_calc(relocsize, YASM_EXPR_MUL, nreloc, 0);    YASM_WRITE_64I_L(bufp, relocsize);		/* size */    yasm_intnum_destroy(nreloc);    yasm_intnum_destroy(relocsize);    YASM_WRITE_32_L(bufp, symtab_idx);		/* link: symtab index */    YASM_WRITE_32_L(bufp, shead->index);	/* info: relocated's index */    YASM_WRITE_64Z_L(bufp, RELOC64_ALIGN);	/* align */    YASM_WRITE_64Z_L(bufp, RELOC64A_SIZE);	/* entity size */}static voidelf_x86_amd64_handle_reloc_addend(yasm_intnum *intn, elf_reloc_entry *reloc){    /* .rela: copy value out as addend, replace original with 0 */    reloc->addend = yasm_intnum_copy(intn);    yasm_intnum_zero(intn);}static unsigned intelf_x86_amd64_map_reloc_info_to_type(elf_reloc_entry *reloc,				     yasm_symrec **ssyms){    if (reloc->wrt) {	if (reloc->wrt == ssyms[SSYM_GOTPCREL] && reloc->valsize == 32)	    return (unsigned char) R_X86_64_GOTPCREL;	else if (reloc->wrt == ssyms[SSYM_GOT] && reloc->valsize == 32)	    return (unsigned char) R_X86_64_GOT32;	else if (reloc->wrt == ssyms[SSYM_PLT] && reloc->valsize == 32)	    return (unsigned char) R_X86_64_PLT32;	else	    yasm_internal_error(N_("Unsupported WRT"));    } else if (reloc->rtype_rel) {        switch (reloc->valsize) {            case 8: return (unsigned char) R_X86_64_PC8;            case 16: return (unsigned char) R_X86_64_PC16;            case 32: return (unsigned char) R_X86_64_PC32;            default: yasm_internal_error(N_("Unsupported relocation size"));        }    } else {        switch (reloc->valsize) {            case 8: return (unsigned char) R_X86_64_8;            case 16: return (unsigned char) R_X86_64_16;            case 32: return (unsigned char) R_X86_64_32;            case 64: return (unsigned char) R_X86_64_64;            default: yasm_internal_error(N_("Unsupported relocation size"));        }    }    return 0;}static voidelf_x86_amd64_write_reloc(unsigned char *bufp, elf_reloc_entry *reloc,                          unsigned int r_type, unsigned int r_sym){    YASM_WRITE_64I_L(bufp, reloc->reloc.addr);    /*YASM_WRITE_64_L(bufp, ELF64_R_INFO(r_sym, r_type));*/    YASM_WRITE_64C_L(bufp, r_sym, r_type);    YASM_WRITE_64I_L(bufp, reloc->addend);}static voidelf_x86_amd64_write_proghead(unsigned char **bufpp,                             elf_offset secthead_addr,                             unsigned long secthead_count,                             elf_section_index shstrtab_index){    unsigned char *bufp = *bufpp;    unsigned char *buf = bufp-4;    YASM_WRITE_8(bufp, ELFCLASS64);	    /* elf class */    YASM_WRITE_8(bufp, ELFDATA2LSB);	    /* data encoding :: MSB? */    YASM_WRITE_8(bufp, EV_CURRENT);	    /* elf version */    YASM_WRITE_8(bufp, ELFOSABI_SYSV);	    /* os/abi */    YASM_WRITE_8(bufp, 0);		    /* SYSV v3 ABI=0 */    while (bufp-buf < EI_NIDENT)	    /* e_ident padding */        YASM_WRITE_8(bufp, 0);    YASM_WRITE_16_L(bufp, ET_REL);	    /* e_type - object file */    YASM_WRITE_16_L(bufp, EM_X86_64);	    /* e_machine - or others */    YASM_WRITE_32_L(bufp, EV_CURRENT);	    /* elf version */    YASM_WRITE_64Z_L(bufp, 0);		    /* e_entry */    YASM_WRITE_64Z_L(bufp, 0);		    /* e_phoff */    YASM_WRITE_64Z_L(bufp, secthead_addr);  /* e_shoff secthead off */    YASM_WRITE_32_L(bufp, 0);		    /* e_flags */    YASM_WRITE_16_L(bufp, EHDR64_SIZE);	    /* e_ehsize */    YASM_WRITE_16_L(bufp, 0);		    /* e_phentsize */    YASM_WRITE_16_L(bufp, 0);		    /* e_phnum */    YASM_WRITE_16_L(bufp, SHDR64_SIZE);	    /* e_shentsize */    YASM_WRITE_16_L(bufp, secthead_count);  /* e_shnum */    YASM_WRITE_16_L(bufp, shstrtab_index);  /* e_shstrndx */    *bufpp = bufp;}static elf_machine_ssym elf_x86_amd64_ssyms[] = {    {"..gotpcrel", 1},    {"..got", 1},    {"..plt", 0}};const elf_machine_handlerelf_machine_handler_x86_amd64 = {    "x86", "amd64", ".rela",    SYMTAB64_SIZE, SYMTAB64_ALIGN, RELOC64A_SIZE, SHDR64_SIZE, EHDR64_SIZE,    elf_x86_amd64_accepts_reloc,    elf_x86_amd64_write_symtab_entry,    elf_x86_amd64_write_secthead,    elf_x86_amd64_write_secthead_rel,    elf_x86_amd64_handle_reloc_addend,    elf_x86_amd64_map_reloc_info_to_type,    elf_x86_amd64_write_reloc,    elf_x86_amd64_write_proghead,    elf_x86_amd64_ssyms,    sizeof(elf_x86_amd64_ssyms)/sizeof(elf_x86_amd64_ssyms[0])};

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -