This fixes the handling of EXPR_NEW, to make it suitable on x86-64.

Signed-off-by: Eduard - Gabriel Munteanu <eduard.munte...@linux360.ro>
---
 arch/x86/insn-selector.brg |   23 ++++++++++++++++++++++-
 1 files changed, 22 insertions(+), 1 deletions(-)

diff --git a/arch/x86/insn-selector.brg b/arch/x86/insn-selector.brg
index 836b846..ec98e82 100644
--- a/arch/x86/insn-selector.brg
+++ b/arch/x86/insn-selector.brg
@@ -950,6 +950,7 @@ reg:        EXPR_INSTANCE_FIELD(reg) 1
        }
 }
 
+%ifdef CONFIG_X86_32
 reg:   EXPR_NEW
 {
        struct expression *expr;
@@ -957,7 +958,7 @@ reg:        EXPR_NEW
 
        expr = to_expr(tree);
 
-       var = get_fixed_var(s->b_parent, REG_xAX);
+       var = get_fixed_var(s->b_parent, REG_EAX);
        state->reg1 = var;
 
        select_insn(s, tree, imm_insn(INSN_PUSH_IMM,
@@ -967,6 +968,26 @@ reg:       EXPR_NEW
        method_args_cleanup(s, tree, 1);
        select_exception_test(s, tree);
 }
+%else
+reg:   EXPR_NEW
+{
+       struct expression *expr;
+       struct var_info *var, *rdi;
+
+       expr = to_expr(tree);
+
+       var = get_fixed_var(s->b_parent, REG_RAX);
+       state->reg1 = var;
+
+       rdi = get_fixed_var(s->b_parent, REG_RDI);
+
+       select_insn(s, tree, imm_reg_insn(INSN_MOV_IMM_REG,
+               (unsigned long) expr->class, rdi));
+       select_insn(s, tree, rel_insn(INSN_CALL_REL,
+               (unsigned long) vm_object_alloc));
+       select_exception_test(s, tree);
+}
+%endif
 
 %ifdef CONFIG_X86_32
 reg:   EXPR_ARRAY_SIZE_CHECK(reg)
-- 
1.6.0.6


------------------------------------------------------------------------------
_______________________________________________
Jatovm-devel mailing list
Jatovm-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/jatovm-devel

Reply via email to