blob: 62151a3d396f47579504f84ebb944e268a27713a [file] [log] [blame]
Damien Georgec8f78bc2014-02-15 22:55:00 +00001typedef enum {
2 MP_VM_RETURN_NORMAL,
3 MP_VM_RETURN_YIELD,
4 MP_VM_RETURN_EXCEPTION,
5} mp_vm_return_kind_t;
6
Paul Sokolovskyc0abc282014-03-22 13:49:31 +02007// Exception stack entry
8typedef struct _mp_exc_stack {
9 const byte *handler;
10 // bit 0 is saved currently_in_except_block value
Paul Sokolovsky16734202014-03-22 23:20:07 +020011 mp_obj_t *val_sp;
Paul Sokolovsky0c904df2014-03-30 00:48:21 +020012 // Saved exception, valid if currently_in_except_block bit is 1
13 mp_obj_t prev_exc;
Paul Sokolovskyc0abc282014-03-22 13:49:31 +020014 // We might only have 2 interesting cases here: SETUP_EXCEPT & SETUP_FINALLY,
15 // consider storing it in bit 1 of val_sp. TODO: SETUP_WITH?
16 byte opcode;
Damien George89f94b52014-03-30 00:57:09 +000017} mp_exc_stack_t;
Paul Sokolovskyc0abc282014-03-22 13:49:31 +020018
Damien Georgebee17b02014-03-27 11:07:04 +000019mp_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, mp_obj_t *ret);
Damien George89f94b52014-03-30 00:57:09 +000020mp_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_t *exc_stack, mp_exc_stack_t **exc_sp_in_out, volatile mp_obj_t inject_exc);
Damien Georgecbd2f742014-01-19 11:48:48 +000021void mp_byte_code_print(const byte *code, int len);
Paul Sokolovsky16734202014-03-22 23:20:07 +020022
23// Helper macros to access pointer with least significant bit holding a flag
24#define MP_TAGPTR_PTR(x) ((void*)((machine_uint_t)(x) & ~((machine_uint_t)1)))
25#define MP_TAGPTR_TAG(x) ((machine_uint_t)(x) & 1)
26#define MP_TAGPTR_MAKE(ptr, tag) ((void*)((machine_uint_t)(ptr) | tag))