summaryrefslogtreecommitdiffstatshomepage
path: root/py
diff options
context:
space:
mode:
Diffstat (limited to 'py')
-rw-r--r--py/emit.h2
-rw-r--r--py/emitnative.c14
-rw-r--r--py/nativeglue.c14
-rw-r--r--py/runtime.h1
4 files changed, 15 insertions, 16 deletions
diff --git a/py/emit.h b/py/emit.h
index 34c6cfd845..2a5da8e8e3 100644
--- a/py/emit.h
+++ b/py/emit.h
@@ -156,8 +156,6 @@ typedef struct _emit_method_table_t {
void (*end_except_handler)(emit_t *emit);
} emit_method_table_t;
-int mp_native_type_from_qstr(qstr qst);
-
static inline void mp_emit_common_get_id_for_load(scope_t *scope, qstr qst) {
scope_find_or_add_id(scope, qst, ID_INFO_KIND_GLOBAL_IMPLICIT);
}
diff --git a/py/emitnative.c b/py/emitnative.c
index ffdebd6432..aa5ec4935d 100644
--- a/py/emitnative.c
+++ b/py/emitnative.c
@@ -136,20 +136,6 @@ typedef enum {
VTYPE_BUILTIN_CAST = 0x70 | MP_NATIVE_TYPE_OBJ,
} vtype_kind_t;
-int mp_native_type_from_qstr(qstr qst) {
- switch (qst) {
- case MP_QSTR_object: return MP_NATIVE_TYPE_OBJ;
- case MP_QSTR_bool: return MP_NATIVE_TYPE_BOOL;
- case MP_QSTR_int: return MP_NATIVE_TYPE_INT;
- case MP_QSTR_uint: return MP_NATIVE_TYPE_UINT;
- case MP_QSTR_ptr: return MP_NATIVE_TYPE_PTR;
- case MP_QSTR_ptr8: return MP_NATIVE_TYPE_PTR8;
- case MP_QSTR_ptr16: return MP_NATIVE_TYPE_PTR16;
- case MP_QSTR_ptr32: return MP_NATIVE_TYPE_PTR32;
- default: return -1;
- }
-}
-
STATIC qstr vtype_to_qstr(vtype_kind_t vtype) {
switch (vtype) {
case VTYPE_PYOBJ: return MP_QSTR_object;
diff --git a/py/nativeglue.c b/py/nativeglue.c
index b7031a5d27..6e5bd6ce2e 100644
--- a/py/nativeglue.c
+++ b/py/nativeglue.c
@@ -41,6 +41,20 @@
#if MICROPY_EMIT_NATIVE
+int mp_native_type_from_qstr(qstr qst) {
+ switch (qst) {
+ case MP_QSTR_object: return MP_NATIVE_TYPE_OBJ;
+ case MP_QSTR_bool: return MP_NATIVE_TYPE_BOOL;
+ case MP_QSTR_int: return MP_NATIVE_TYPE_INT;
+ case MP_QSTR_uint: return MP_NATIVE_TYPE_UINT;
+ case MP_QSTR_ptr: return MP_NATIVE_TYPE_PTR;
+ case MP_QSTR_ptr8: return MP_NATIVE_TYPE_PTR8;
+ case MP_QSTR_ptr16: return MP_NATIVE_TYPE_PTR16;
+ case MP_QSTR_ptr32: return MP_NATIVE_TYPE_PTR32;
+ default: return -1;
+ }
+}
+
// convert a MicroPython object to a valid native value based on type
mp_uint_t mp_convert_obj_to_native(mp_obj_t obj, mp_uint_t type) {
DEBUG_printf("mp_convert_obj_to_native(%p, " UINT_FMT ")\n", obj, type);
diff --git a/py/runtime.h b/py/runtime.h
index 9811c1b5ae..3e447ee4fe 100644
--- a/py/runtime.h
+++ b/py/runtime.h
@@ -169,6 +169,7 @@ NORETURN void mp_raise_recursion_depth(void);
#endif
// helper functions for native/viper code
+int mp_native_type_from_qstr(qstr qst);
mp_uint_t mp_convert_obj_to_native(mp_obj_t obj, mp_uint_t type);
mp_obj_t mp_convert_native_to_obj(mp_uint_t val, mp_uint_t type);
mp_obj_dict_t *mp_native_swap_globals(mp_obj_dict_t *new_globals);