fix SSE2 float calls + returns
[libfirm] / ir / be / ia32 / ia32_emitter.h
index bbd1528..a36fdd1 100644 (file)
@@ -1,7 +1,12 @@
+/**
+ * Header file for ia32 emitter, containing some function definitions and types.
+ * @author Christian Wuerdig, Matthias Braun
+ * $Id$
+ */
 #ifndef _IA32_EMITTER_H_
 #define _IA32_EMITTER_H_
 
-#include "irargs_t.h"  // this also inlucdes <libcore/lc_print.h>
+#include "irargs_t.h"
 #include "irnode.h"
 #include "debug.h"
 
@@ -14,22 +19,47 @@ typedef struct _ia32_emit_env_t {
        const arch_env_t      *arch_env;
        const ia32_code_gen_t *cg;
        ia32_isa_t            *isa;
+       struct obstack        *obst;
+       int                    linelength;
        DEBUG_ONLY(firm_dbg_module_t *mod;)
 } ia32_emit_env_t;
 
-const lc_arg_env_t *ia32_get_arg_env(void);
+static INLINE void ia32_emit_char(ia32_emit_env_t *env, char c)
+{
+       obstack_1grow(env->obst, c);
+       env->linelength++;
+}
+
+static INLINE void ia32_emit_string_len(ia32_emit_env_t *env, const char *str, size_t l)
+{
+       obstack_grow(env->obst, str, l);
+       env->linelength += l;
+}
 
-const char *ia32_emit_binop(const ir_node *irn, ia32_emit_env_t *env);
-const char *ia32_emit_unop(const ir_node *irn, ia32_emit_env_t *env);
-const char *ia32_emit_am(const ir_node *irn, ia32_emit_env_t *env);
-const char *ia32_emit_adr(const ir_node *irn, ia32_emit_env_t *env);
+static INLINE void ia32_emit_string(ia32_emit_env_t *env, const char *str)
+{
+       size_t len = strlen(str);
+       ia32_emit_string_len(env, str, len);
+}
 
-const char *ia32_emit_x87_binop(const ir_node *n, ia32_emit_env_t *env);
+#define ia32_emit_cstring(env,x) { ia32_emit_string_len(env, x, sizeof(x)-1); }
 
-int get_ia32_reg_nr(ir_node *irn, int posi, int in_out);
-const char *get_ia32_in_reg_name(ir_node *irn, int pos);
+void ia32_emit_source_register(ia32_emit_env_t *env, const ir_node *node, int pos);
+void ia32_emit_dest_register(ia32_emit_env_t *env, const ir_node *node, int pos);
+void ia32_emit_x87_name(ia32_emit_env_t *env, const ir_node *node, int pos);
+void ia32_emit_immediate(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_mode_suffix(ia32_emit_env_t *env, const ir_mode *mode);
+void ia32_emit_x87_mode_suffix(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_xmm_mode_suffix(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_extend_suffix(ia32_emit_env_t *env, const ir_mode *mode);
+void ia32_emit_binop(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_unop(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_am(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_adr(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_x87_binop(ia32_emit_env_t *env, const ir_node *node);
+void ia32_emit_finish_line(ia32_emit_env_t *env, const ir_node *node);
 
-void ia32_gen_routine(FILE *F, ir_graph *irg, const ia32_code_gen_t *cg);
+void ia32_gen_routine(ia32_code_gen_t *cg, FILE *F, ir_graph *irg);
 
 /**
  * Sections.
@@ -40,7 +70,9 @@ typedef enum section_t {
        SECTION_DATA   = 1,   /**< data section */
        SECTION_RODATA = 2,   /**< rodata section */
        SECTION_COMMON = 3,   /**< common section */
-       SECTION_MAX    = 4
+       SECTION_TLS    = 4,   /**< thread local storage section */
+       SECTION_CTOR   = 5,   /**< ctor section for instrumentation code init */
+       SECTION_MAX    = 6
 } section_t;
 
 /**