some code I wrote today. somebody please finish this.
[libfirm] / ir / be / bearch.c
index 23f023f..fb7ffa8 100644 (file)
@@ -41,7 +41,7 @@ arch_env_t *arch_env_init(arch_env_t *env, const arch_isa_if_t *isa_if, FILE *fi
 arch_env_t *arch_env_push_irn_handler(arch_env_t *env,
     const arch_irn_handler_t *handler)
 {
-  assert(env->handlers_tos <= ARCH_MAX_HANDLERS);
+  assert(env->handlers_tos < ARCH_MAX_HANDLERS);
   env->handlers[env->handlers_tos++] = handler;
   return env;
 }
@@ -87,6 +87,10 @@ get_irn_ops(const arch_env_t *env, const ir_node *irn)
   return fallback_irn_ops;
 }
 
+const arch_irn_ops_t *arch_get_irn_ops(const arch_env_t *env, const ir_node *irn) {
+       return get_irn_ops(env, irn);
+}
+
 const arch_register_req_t *arch_get_register_req(const arch_env_t *env,
     arch_register_req_t *req, const ir_node *irn, int pos)
 {
@@ -107,6 +111,18 @@ entity *arch_get_frame_entity(const arch_env_t *env, ir_node *irn)
   return ops->impl->get_frame_entity(ops, irn);
 }
 
+void arch_set_frame_entity(const arch_env_t *env, ir_node *irn, entity *ent)
+{
+       const arch_irn_ops_t *ops = get_irn_ops(env, irn);
+       ops->impl->set_frame_entity(ops, irn, ent);
+}
+
+int arch_get_sp_bias(const arch_env_t *env, ir_node *irn)
+{
+       const arch_irn_ops_t *ops = get_irn_ops(env, irn);
+       return ops->impl->get_sp_bias(ops, irn);
+}
+
 arch_inverse_t *arch_get_inverse(const arch_env_t *env, const ir_node *irn, int i, arch_inverse_t *inverse, struct obstack *obstack)
 {
   const arch_irn_ops_t *ops = get_irn_ops(env, irn);
@@ -126,10 +142,10 @@ int arch_possible_memory_operand(const arch_env_t *env, const ir_node *irn, unsi
        }
 }
 
-extern void arch_perform_memory_operand(const arch_env_t *env, ir_node *irn, ir_node *reload, unsigned int i) {
+extern void arch_perform_memory_operand(const arch_env_t *env, ir_node *irn, ir_node *spill, unsigned int i) {
        const arch_irn_ops_t *ops = get_irn_ops(env, irn);
        if(ops->impl->perform_memory_operand) {
-               ops->impl->perform_memory_operand(ops, irn, reload, i);
+               ops->impl->perform_memory_operand(ops, irn, spill, i);
        } else {
                return;
        }