0
0
mirror of https://github.com/netwide-assembler/nasm.git synced 2025-10-10 00:25:06 -04:00
Files
nasm/output/outelf.h
H. Peter Anvin 23ce05f906 treewide: replace verbose copyright headers with SPDX tags
SPDX is an international standard for documenting software license
requirements. Remove the existing headers and replace with a brief
SPDX preamble.

See: https://spdx.dev/use/specifications/

The script used to convert the files is added to "tools", and the
file header templates in headers/ are updated.

Signed-off-by: H. Peter Anvin (Intel) <hpa@zytor.com>
2025-10-01 11:45:31 -07:00

104 lines
3.6 KiB
C

/* SPDX-License-Identifier: BSD-2-Clause */
/* Copyright 1996-2019 The NASM Authors - All Rights Reserved */
/*
* Internal definitions common to outelf32 and outelf64
*/
#ifndef OUTPUT_OUTELF_H
#define OUTPUT_OUTELF_H
#include "elf.h"
#include "rbtree.h"
#include "saa.h"
#define GLOBAL_TEMP_BASE 0x40000000 /* bigger than any sane symbol index */
/* alignment of sections in file */
#define SEC_FILEALIGN 16
/* this stuff is needed for the dwarf/stabs debugging format */
#define TY_DEBUGSYMLIN 0x40 /* internal call to debug_out */
/*
* Debugging ELF sections (section indices starting with sec_debug)
*/
/* stabs */
#define sec_stab (sec_debug + 0)
#define sec_stabstr (sec_debug + 1)
#define sec_rel_stab (sec_debug + 2)
/* stabs symbol table format */
struct stabentry {
uint32_t n_strx;
uint8_t n_type;
uint8_t n_other;
uint16_t n_desc;
uint32_t n_value;
};
/* dwarf */
#define sec_debug_aranges (sec_debug + 0)
#define sec_rela_debug_aranges (sec_debug + 1)
#define sec_debug_pubnames (sec_debug + 2)
#define sec_debug_info (sec_debug + 3)
#define sec_rela_debug_info (sec_debug + 4)
#define sec_debug_abbrev (sec_debug + 5)
#define sec_debug_line (sec_debug + 6)
#define sec_rela_debug_line (sec_debug + 7)
#define sec_debug_frame (sec_debug + 8)
#define sec_debug_loc (sec_debug + 9)
extern uint8_t elf_osabi;
extern uint8_t elf_abiver;
#define WRITE_STAB(p,n_strx,n_type,n_other,n_desc,n_value) \
do { \
WRITELONG(p, n_strx); \
WRITECHAR(p, n_type); \
WRITECHAR(p, n_other); \
WRITESHORT(p, n_desc); \
WRITELONG(p, n_value); \
} while (0)
struct elf_reloc {
struct elf_reloc *next;
int64_t address; /* relative to _start_ of section */
int64_t symbol; /* symbol index */
int64_t offset; /* symbol addend */
int type; /* type of relocation */
};
struct elf_symbol {
struct rbtree symv; /* symbol value and symbol rbtree */
int32_t strpos; /* string table position of name */
int32_t section; /* section ID of the symbol */
int type; /* symbol type */
int other; /* symbol visibility */
int32_t size; /* size of symbol */
int32_t globnum; /* symbol table offset if global */
struct elf_symbol *nextfwd; /* list of unresolved-size symbols */
char *name; /* used temporarily if in above list */
};
struct elf_section {
struct SAA *data;
uint64_t len;
uint64_t size;
uint64_t nrelocs;
int32_t index; /* NASM index or NO_SEG if internal */
int shndx; /* ELF index */
int type; /* SHT_* */
uint64_t align; /* alignment: power of two */
uint64_t flags; /* section flags */
int64_t pass_last_seen;
uint64_t entsize; /* entry size */
char *name;
struct SAA *rel;
struct elf_reloc *head;
struct elf_reloc **tail;
struct rbtree *gsyms; /* global symbols in section */
};
#endif /* OUTPUT_OUTELF_H */