ir_mode: simplify interface, improve float-mode handling
[libfirm] / ir / be / ia32 / ia32_emitter.h
index ac4b18f..289a4cd 100644 (file)
 
 #include "irnode.h"
 
-#include "../bearch.h"
+#include "bearch.h"
 
 #include "bearch_ia32_t.h"
 
 void ia32_emit_source_register(const ir_node *node, int pos);
 void ia32_emit_dest_register(const ir_node *node, int pos);
+void ia32_emit_dest_register_size(const ir_node *node, int pos);
 void ia32_emit_8bit_dest_register(const ir_node *node, int pos);
 void ia32_emit_x87_register(const ir_node *node, int pos);
 void ia32_emit_source_register_or_immediate(const ir_node *node, int pos);
 void ia32_emit_8bit_source_register_or_immediate(const ir_node *node, int pos);
+void ia32_emit_8bit_high_source_register(const ir_node *node, int pos);
+void ia32_emit_16bit_source_register_or_immediate(const ir_node *node, int pos);
 void ia32_emit_mode_suffix(const ir_node *node);
 void ia32_emit_x87_mode_suffix(const ir_node *node);
 void ia32_emit_xmm_mode_suffix(const ir_node *node);
 void ia32_emit_xmm_mode_suffix_s(const ir_node *node);
-void ia32_emit_extend_suffix(const ir_mode *mode);
+void ia32_emit_extend_suffix(const ir_node *node);
 void ia32_emit_cmp_suffix_node(const ir_node *node, int flags_pos);
 void ia32_emit_binop(const ir_node *node);
 void ia32_emit_unop(const ir_node *node, int pos);
 void ia32_emit_am(const ir_node *node);
 void ia32_emit_x87_binop(const ir_node *node);
 
-void ia32_gen_routine(ia32_code_gen_t *cg, ir_graph *irg);
-void ia32_emit_exc_label(const ir_node *node);
+void ia32_gen_routine(ir_graph *irg);
+void ia32_gen_binary_routine(ir_graph *irg);
 
+/** Initializes the Emitter. */
+void ia32_init_emitter(void);
 #endif