2014-02-16 02:55:00 +04:00
|
|
|
typedef enum {
|
|
|
|
MP_VM_RETURN_NORMAL,
|
|
|
|
MP_VM_RETURN_YIELD,
|
|
|
|
MP_VM_RETURN_EXCEPTION,
|
|
|
|
} mp_vm_return_kind_t;
|
|
|
|
|
2014-03-22 15:49:31 +04:00
|
|
|
// Exception stack entry
|
|
|
|
typedef struct _mp_exc_stack {
|
|
|
|
const byte *handler;
|
|
|
|
// bit 0 is saved currently_in_except_block value
|
2014-03-23 01:20:07 +04:00
|
|
|
mp_obj_t *val_sp;
|
2014-03-22 15:49:31 +04:00
|
|
|
// We might only have 2 interesting cases here: SETUP_EXCEPT & SETUP_FINALLY,
|
|
|
|
// consider storing it in bit 1 of val_sp. TODO: SETUP_WITH?
|
|
|
|
byte opcode;
|
|
|
|
} mp_exc_stack;
|
|
|
|
|
2014-02-16 02:55:00 +04:00
|
|
|
mp_vm_return_kind_t mp_execute_byte_code(const byte *code, const mp_obj_t *args, uint n_args, const mp_obj_t *args2, uint n_args2, uint n_state, mp_obj_t *ret);
|
2014-03-22 19:50:12 +04:00
|
|
|
mp_vm_return_kind_t mp_execute_byte_code_2(const byte *code_info, const byte **ip_in_out, mp_obj_t *fastn, mp_obj_t **sp_in_out, mp_exc_stack *exc_stack, mp_exc_stack **exc_sp_in_out, volatile mp_obj_t inject_exc);
|
2014-01-19 15:48:48 +04:00
|
|
|
void mp_byte_code_print(const byte *code, int len);
|
2014-03-23 01:20:07 +04:00
|
|
|
|
|
|
|
// Helper macros to access pointer with least significant bit holding a flag
|
|
|
|
#define MP_TAGPTR_PTR(x) ((void*)((machine_uint_t)(x) & ~((machine_uint_t)1)))
|
|
|
|
#define MP_TAGPTR_TAG(x) ((machine_uint_t)(x) & 1)
|
|
|
|
#define MP_TAGPTR_MAKE(ptr, tag) ((void*)((machine_uint_t)(ptr) | tag))
|