Commit 55fcb83a authored by Damien George's avatar Damien George

py/compile: Support multiple inline asm emitters.

parent 9c9bc65e
...@@ -115,7 +115,25 @@ STATIC const emit_method_table_t *emit_native_table[] = { ...@@ -115,7 +115,25 @@ STATIC const emit_method_table_t *emit_native_table[] = {
#define NATIVE_EMITTER_TABLE &NATIVE_EMITTER(method_table) #define NATIVE_EMITTER_TABLE &NATIVE_EMITTER(method_table)
#endif #endif
#if MICROPY_EMIT_INLINE_ASM #if MICROPY_EMIT_INLINE_ASM && MICROPY_DYNAMIC_COMPILER
#define ASM_EMITTER(f) emit_asm_table[mp_dynamic_compiler.native_arch]->asm_##f
#define ASM_EMITTER_TABLE emit_asm_table[mp_dynamic_compiler.native_arch]
STATIC const emit_inline_asm_method_table_t *emit_asm_table[] = {
NULL,
NULL,
NULL,
NULL,
&emit_inline_thumb_method_table,
&emit_inline_thumb_method_table,
&emit_inline_thumb_method_table,
&emit_inline_thumb_method_table,
&emit_inline_thumb_method_table,
&emit_inline_xtensa_method_table,
};
#elif MICROPY_EMIT_INLINE_ASM
// define macros for inline assembler // define macros for inline assembler
#if MICROPY_EMIT_INLINE_THUMB #if MICROPY_EMIT_INLINE_THUMB
#define ASM_DECORATOR_QSTR MP_QSTR_asm_thumb #define ASM_DECORATOR_QSTR MP_QSTR_asm_thumb
...@@ -126,6 +144,7 @@ STATIC const emit_method_table_t *emit_native_table[] = { ...@@ -126,6 +144,7 @@ STATIC const emit_method_table_t *emit_native_table[] = {
#else #else
#error "unknown asm emitter" #error "unknown asm emitter"
#endif #endif
#define ASM_EMITTER_TABLE &ASM_EMITTER(method_table)
#endif #endif
#define EMIT_INLINE_ASM(fun) (comp->emit_inline_asm_method_table->fun(comp->emit_inline_asm)) #define EMIT_INLINE_ASM(fun) (comp->emit_inline_asm_method_table->fun(comp->emit_inline_asm))
...@@ -819,9 +838,16 @@ STATIC bool compile_built_in_decorator(compiler_t *comp, int name_len, mp_parse_ ...@@ -819,9 +838,16 @@ STATIC bool compile_built_in_decorator(compiler_t *comp, int name_len, mp_parse_
*emit_options = MP_EMIT_OPT_VIPER; *emit_options = MP_EMIT_OPT_VIPER;
#endif #endif
#if MICROPY_EMIT_INLINE_ASM #if MICROPY_EMIT_INLINE_ASM
#if MICROPY_DYNAMIC_COMPILER
} else if (attr == MP_QSTR_asm_thumb) {
*emit_options = MP_EMIT_OPT_ASM;
} else if (attr == MP_QSTR_asm_xtensa) {
*emit_options = MP_EMIT_OPT_ASM;
#else
} else if (attr == ASM_DECORATOR_QSTR) { } else if (attr == ASM_DECORATOR_QSTR) {
*emit_options = MP_EMIT_OPT_ASM; *emit_options = MP_EMIT_OPT_ASM;
#endif #endif
#endif
} else { } else {
compile_syntax_error(comp, name_nodes[1], "invalid micropython decorator"); compile_syntax_error(comp, name_nodes[1], "invalid micropython decorator");
} }
...@@ -3465,13 +3491,18 @@ mp_raw_code_t *mp_compile_to_raw_code(mp_parse_tree_t *parse_tree, qstr source_f ...@@ -3465,13 +3491,18 @@ mp_raw_code_t *mp_compile_to_raw_code(mp_parse_tree_t *parse_tree, qstr source_f
comp->emit_inline_asm = ASM_EMITTER(new)(max_num_labels); comp->emit_inline_asm = ASM_EMITTER(new)(max_num_labels);
} }
comp->emit = NULL; comp->emit = NULL;
comp->emit_inline_asm_method_table = &ASM_EMITTER(method_table); comp->emit_inline_asm_method_table = ASM_EMITTER_TABLE;
compile_scope_inline_asm(comp, s, MP_PASS_CODE_SIZE); compile_scope_inline_asm(comp, s, MP_PASS_CODE_SIZE);
#if MICROPY_EMIT_INLINE_XTENSA #if MICROPY_EMIT_INLINE_XTENSA
// Xtensa requires an extra pass to compute size of l32r const table // Xtensa requires an extra pass to compute size of l32r const table
// TODO this can be improved by calculating it during SCOPE pass // TODO this can be improved by calculating it during SCOPE pass
// but that requires some other structural changes to the asm emitters // but that requires some other structural changes to the asm emitters
compile_scope_inline_asm(comp, s, MP_PASS_CODE_SIZE); #if MICROPY_DYNAMIC_COMPILER
if (mp_dynamic_compiler.native_arch == MP_NATIVE_ARCH_XTENSA)
#endif
{
compile_scope_inline_asm(comp, s, MP_PASS_CODE_SIZE);
}
#endif #endif
if (comp->compile_error == MP_OBJ_NULL) { if (comp->compile_error == MP_OBJ_NULL) {
compile_scope_inline_asm(comp, s, MP_PASS_EMIT); compile_scope_inline_asm(comp, s, MP_PASS_EMIT);
......
...@@ -255,6 +255,11 @@ void mp_emit_bc_end_except_handler(emit_t *emit); ...@@ -255,6 +255,11 @@ void mp_emit_bc_end_except_handler(emit_t *emit);
typedef struct _emit_inline_asm_t emit_inline_asm_t; typedef struct _emit_inline_asm_t emit_inline_asm_t;
typedef struct _emit_inline_asm_method_table_t { typedef struct _emit_inline_asm_method_table_t {
#if MICROPY_DYNAMIC_COMPILER
emit_inline_asm_t *(*asm_new)(mp_uint_t max_num_labels);
void (*asm_free)(emit_inline_asm_t *emit);
#endif
void (*start_pass)(emit_inline_asm_t *emit, pass_kind_t pass, mp_obj_t *error_slot); void (*start_pass)(emit_inline_asm_t *emit, pass_kind_t pass, mp_obj_t *error_slot);
void (*end_pass)(emit_inline_asm_t *emit, mp_uint_t type_sig); void (*end_pass)(emit_inline_asm_t *emit, mp_uint_t type_sig);
mp_uint_t (*count_params)(emit_inline_asm_t *emit, mp_uint_t n_params, mp_parse_node_t *pn_params); mp_uint_t (*count_params)(emit_inline_asm_t *emit, mp_uint_t n_params, mp_parse_node_t *pn_params);
......
...@@ -812,6 +812,11 @@ branch_not_in_range: ...@@ -812,6 +812,11 @@ branch_not_in_range:
} }
const emit_inline_asm_method_table_t emit_inline_thumb_method_table = { const emit_inline_asm_method_table_t emit_inline_thumb_method_table = {
#if MICROPY_DYNAMIC_COMPILER
emit_inline_thumb_new,
emit_inline_thumb_free,
#endif
emit_inline_thumb_start_pass, emit_inline_thumb_start_pass,
emit_inline_thumb_end_pass, emit_inline_thumb_end_pass,
emit_inline_thumb_count_params, emit_inline_thumb_count_params,
......
...@@ -335,6 +335,11 @@ branch_not_in_range: ...@@ -335,6 +335,11 @@ branch_not_in_range:
} }
const emit_inline_asm_method_table_t emit_inline_xtensa_method_table = { const emit_inline_asm_method_table_t emit_inline_xtensa_method_table = {
#if MICROPY_DYNAMIC_COMPILER
emit_inline_xtensa_new,
emit_inline_xtensa_free,
#endif
emit_inline_xtensa_start_pass, emit_inline_xtensa_start_pass,
emit_inline_xtensa_end_pass, emit_inline_xtensa_end_pass,
emit_inline_xtensa_count_params, emit_inline_xtensa_count_params,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment