+ const void *(*get_irn_ops)(const arch_irn_handler_t *handler,
+ const ir_node *irn);
+
+};
+
+/**
+ * The code generator.
+ */
+struct _arch_code_generator_if_t {
+
+
+ /**
+ * Initialize the code generator.
+ * @param file The file to dump to.
+ * @param irg The function to generate code for.
+ * @param env The architecture environment.
+ * @return A newly created code generator.
+ */
+ void *(*init)(FILE *file, ir_graph *irg, const arch_env_t *env);
+
+ /**
+ * Called, when the graph is being normalized.
+ */
+ void (*prepare_graph)(void *self);
+
+ /**
+ * Called before scheduling.
+ */
+ void (*before_sched)(void *self);
+
+ /**
+ * Called before register allocation.
+ */
+ void (*before_ra)(void *self);
+
+ /**
+ * Called after register allocation to lower Spills to Stores
+ * @param self The code generator
+ * @param spill The spill node to lower
+ * @return The new backend node which substitutes the spill
+ */
+ ir_node *(*lower_spill)(void *self, ir_node *spill);
+
+ /**
+ * Called after register allocation to lower Reloads to Loads
+ * @param self The code generator
+ * @param reload The reload node to lower
+ * @return The new backend node which substitutes the reload
+ */
+ ir_node *(*lower_reload)(void *self, ir_node *reload);
+
+ /**
+ * Called in lowering (e.g. alloca lowering) to set the
+ * correct stack register.
+ * @param self The code generator
+ * @return The stack register for the current irg
+ */
+ const arch_register_t *(*get_stack_register)(void *self);
+
+ /**
+ * Called after everything happened.
+ * The code generator must also be de-allocated here.
+ */
+ void (*done)(void *self);
+
+};
+
+#define _arch_cg_call(cg, func) \
+do { \
+ if((cg)->impl->func) \
+ (cg)->impl->func(cg); \
+} while(0)