summaryrefslogtreecommitdiffstatshomepage
path: root/py/emitnative.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-05-10 13:40:46 +0100
committerDamien George <damien.p.george@gmail.com>2014-05-10 13:40:46 +0100
commitccc85ea0da8433d782bdec79cf09ccd242017198 (patch)
tree418fdefc28e9b89f81160029c8057dc5d4003fda /py/emitnative.c
parent04b7cc4df0a4fe7a6d5ec1e756baac2424b26922 (diff)
downloadmicropython-ccc85ea0da8433d782bdec79cf09ccd242017198.tar.gz
micropython-ccc85ea0da8433d782bdec79cf09ccd242017198.zip
py: Combine native emitters to 1 glue function; distinguish viper.
This patch simplifies the glue between native emitter and runtime, and handles viper code like inline assember: return values are converted to Python objects. Fixes issue #531.
Diffstat (limited to 'py/emitnative.c')
-rw-r--r--py/emitnative.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/py/emitnative.c b/py/emitnative.c
index 4ce21e9c0e..261b1a2a51 100644
--- a/py/emitnative.c
+++ b/py/emitnative.c
@@ -309,10 +309,10 @@ STATIC void emit_native_end_pass(emit_t *emit) {
if (emit->pass == MP_PASS_EMIT) {
#if N_X64
void *f = asm_x64_get_code(emit->as);
- mp_emit_glue_assign_native_code(emit->scope->raw_code, f, asm_x64_get_code_size(emit->as), emit->scope->num_pos_args);
+ mp_emit_glue_assign_native(emit->scope->raw_code, emit->do_viper_types ? MP_CODE_NATIVE_VIPER : MP_CODE_NATIVE_PY, f, asm_x64_get_code_size(emit->as), emit->scope->num_pos_args);
#elif N_THUMB
void *f = asm_thumb_get_code(emit->as);
- mp_emit_glue_assign_native_code(emit->scope->raw_code, f, asm_thumb_get_code_size(emit->as), emit->scope->num_pos_args);
+ mp_emit_glue_assign_native(emit->scope->raw_code, emit->do_viper_types ? MP_CODE_NATIVE_VIPER : MP_CODE_NATIVE_PY, f, asm_thumb_get_code_size(emit->as), emit->scope->num_pos_args);
#endif
}
}
@@ -438,6 +438,11 @@ STATIC void emit_access_stack(emit_t *emit, int pos, vtype_kind_t *vtype, int re
}
}
+STATIC void emit_pre_pop_discard(emit_t *emit, vtype_kind_t *vtype) {
+ emit->last_emit_was_return_value = false;
+ adjust_stack(emit, -1);
+}
+
STATIC void emit_pre_pop_reg(emit_t *emit, vtype_kind_t *vtype, int reg_dest) {
emit->last_emit_was_return_value = false;
emit_access_stack(emit, 1, vtype, reg_dest);
@@ -938,7 +943,7 @@ STATIC void emit_native_dup_top_two(emit_t *emit) {
STATIC void emit_native_pop_top(emit_t *emit) {
vtype_kind_t vtype;
- emit_pre_pop_reg(emit, &vtype, REG_TEMP0);
+ emit_pre_pop_discard(emit, &vtype);
emit_post(emit);
}