X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Fbe%2Farm%2Farm_emitter.h;h=5da5aa9360b849c1dc451777d51ef0102c627974;hb=505d3662efed6efbca2c43eea2fe23b87816b285;hp=7109c0769c4d1a57197e97fa5a12aee2c88aac89;hpb=205396c4f4f5abe7abd6dc2350c8c398a7623afc;p=libfirm diff --git a/ir/be/arm/arm_emitter.h b/ir/be/arm/arm_emitter.h index 7109c0769..5da5aa936 100644 --- a/ir/be/arm/arm_emitter.h +++ b/ir/be/arm/arm_emitter.h @@ -1,7 +1,33 @@ -#ifndef _ARM_EMITTER_H_ -#define _ARM_EMITTER_H_ +/* + * Copyright (C) 1995-2008 University of Karlsruhe. All right reserved. + * + * This file is part of libFirm. + * + * This file may be distributed and/or modified under the terms of the + * GNU General Public License version 2 as published by the Free Software + * Foundation and appearing in the file LICENSE.GPL included in the + * packaging of this file. + * + * Licensees holding valid libFirm Professional Edition licenses may use + * this file in accordance with the libFirm Commercial License. + * Agreement provided with the Software. + * + * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE + * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE. + */ + +/** + * @file + * @brief declarations for arm emitter + * @author Oliver Richter, Tobias Gneis + * @version $Id$ + */ +#ifndef FIRM_BE_ARM_ARM_EMITTER_H +#define FIRM_BE_ARM_ARM_EMITTER_H #include "firm_types.h" +#include "set.h" #include "irargs_t.h" #include "debug.h" @@ -9,50 +35,15 @@ #include "bearch_arm_t.h" -/** - * A SymConst entry. - */ -typedef struct _SymConstEntry { - unsigned label; /**< a label number for this label */ - ir_node *symconst; /**< the node holding this label */ - struct _SymConstEntry *next; /**< links all entries */ -} SymConstEntry; - -/** - * The ARM emitter environment. - */ -typedef struct _arm_emit_env_t { - FILE *out; /**< the output stream */ - const arch_env_t *arch_env; /**< the architecture environment */ - const arm_code_gen_t *cg; /**< the code generator object */ - struct obstack obst; /**< an temporary store for SymConstEntries */ - SymConstEntry *symbols; /**< list containing all SymConstEntries */ - DEBUG_ONLY(firm_dbg_module_t *mod;) -} arm_emit_env_t; +void arm_emit_mode(const ir_node *node); +void arm_emit_source_register(const ir_node *node, int pos); +void arm_emit_dest_register(const ir_node *node, int pos); +void arm_emit_offset(const ir_node *node); +void arm_emit_immediate(const ir_node *node); +void arm_emit_shift(const ir_node *node); -const lc_arg_env_t *arm_get_arg_env(void); +void arm_gen_routine(const arm_code_gen_t *cg, ir_graph *irg); -void equalize_dest_src(FILE *F, ir_node *n); - -int get_arm_reg_nr(ir_node *irn, int posi, int in_out); -const char *get_arm_in_reg_name(ir_node *irn, int pos); - -void arm_gen_routine(FILE *F, ir_graph *irg, const arm_code_gen_t *cg); - -/** - * Sections. - */ -typedef enum sections { - NO_SECTION, /**< no section selected yet. */ - SECTION_TEXT, /**< text section */ - SECTION_DATA, /**< data section */ - SECTION_RODATA, /**< rodata section */ - SECTION_COMMON, /**< common section */ -} sections; - -/** - * Switch to a new section - */ -void arm_switch_section(FILE *f, sections sec); +void arm_init_emitter(void); -#endif /* _ARM_EMITTER_H_ */ +#endif