X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Fbegnuas.h;h=12e2aa7695e8ecd7a9916e2aa63f20ae206248b1;hb=5474a1c188c9d59eea2c915515980cd9cbab58d8;hp=72958eb56c6b51559b73bc71d81ad4c60b3af927;hpb=9246866a19201d235897e8ef842a28542911cd68;p=libfirm diff --git a/ir/be/begnuas.h b/ir/be/begnuas.h index 72958eb56..12e2aa769 100644 --- a/ir/be/begnuas.h +++ b/ir/be/begnuas.h @@ -22,7 +22,6 @@ * @brief Dumps global variables and constants as gas assembler. * @author Christian Wuerdig, Matthias Braun * @date 04.11.2005 - * @version $Id$ */ #ifndef FIRM_BE_BEGNUAS_H #define FIRM_BE_BEGNUAS_H @@ -41,7 +40,11 @@ typedef enum { GAS_SECTION_CSTRING, /**< section for constant strings */ GAS_SECTION_PIC_TRAMPOLINES, /**< trampolines for pic codes */ GAS_SECTION_PIC_SYMBOLS, /**< contains resolved pic symbols */ - GAS_SECTION_LAST = GAS_SECTION_PIC_SYMBOLS, + GAS_SECTION_DEBUG_INFO, /**< dwarf debug info */ + GAS_SECTION_DEBUG_ABBREV, /**< dwarf debug abbrev */ + GAS_SECTION_DEBUG_LINE, /**< dwarf debug line */ + GAS_SECTION_DEBUG_PUBNAMES, /**< dwarf pub names */ + GAS_SECTION_LAST = GAS_SECTION_DEBUG_PUBNAMES, GAS_SECTION_TYPE_MASK = 0xFF, GAS_SECTION_FLAG_TLS = 1 << 8, /**< thread local flag */ @@ -72,12 +75,6 @@ extern elf_variant_t be_gas_elf_variant; */ extern char be_gas_elf_type_char; -/** - * Generate all entities. - * @param main_env the main backend environment - */ -void be_gas_emit_decls(const be_main_env_t *main_env); - /** * Switch the current output section to the given out. * @@ -107,6 +104,20 @@ void be_gas_emit_entity(const ir_entity *entity); */ void be_gas_emit_block_name(const ir_node *block); +/** + * Starts emitting a compilation unit. This emits: + * - global assembler snippets + * - debug info + */ +void be_gas_begin_compilation_unit(const be_main_env_t *env); + +/** + * ends a compilation unit. This emits: + * - global declarations/variables + * - debug info + */ +void be_gas_end_compilation_unit(const be_main_env_t *env); + /** * Return the label prefix for labeled instructions. */ @@ -117,7 +128,8 @@ typedef ir_node* (*get_cfop_target_func)(const ir_node *cfop); /** * Emits a jump table for switch operations */ -void emit_jump_table(const ir_node *node, long default_pn, ir_entity *table, - get_cfop_target_func get_cfop_target); +void be_emit_jump_table(const ir_node *node, const ir_switch_table *table, + ir_entity *entity, + get_cfop_target_func get_cfop_target); #endif