diff options
| author | Damien George <damien.p.george@gmail.com> | 2017-02-27 23:56:46 +1100 |
|---|---|---|
| committer | Damien George <damien.p.george@gmail.com> | 2017-03-06 17:01:56 +1100 |
| commit | 05fe66f68a1cf1b7587c55149472ab7bca843631 (patch) | |
| tree | e2e38a0124db195eb8ae011cd05f2a7316c9b06e /py/mpstate.h | |
| parent | fe866d996f54df0c5687c94b98abff5410ef02c9 (diff) | |
py: Move locals/globals dicts to the thread-specific state.
Each threads needs to have its own private references to its current
locals/globals dicts, otherwise functions running within different
contexts (eg imported from different files) can behave very strangely.
Diffstat (limited to 'py/mpstate.h')
| -rw-r--r-- | py/mpstate.h | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/py/mpstate.h b/py/mpstate.h index 54392a994..9e4f54ae5 100644 --- a/py/mpstate.h +++ b/py/mpstate.h @@ -196,11 +196,13 @@ typedef struct _mp_state_vm_t { // This structure holds state that is specific to a given thread. // Everything in this structure is scanned for root pointers. typedef struct _mp_state_thread_t { + mp_obj_dict_t *dict_locals; + mp_obj_dict_t *dict_globals; + // Note: nlr asm code has the offset of this hard-coded nlr_buf_t *nlr_top; // ROOT POINTER // Stack top at the start of program - // Note: this entry is used to locate the end of the root pointer section. char *stack_top; #if MICROPY_STACK_CHECK @@ -208,15 +210,11 @@ typedef struct _mp_state_thread_t { #endif } mp_state_thread_t; -// This structure combines the above 3 structures, and adds the local -// and global dicts. +// This structure combines the above 3 structures. +// The order of the entries are important for root pointer scanning in the GC to work. // Note: if this structure changes then revisit all nlr asm code since they // have the offset of nlr_top hard-coded. typedef struct _mp_state_ctx_t { - // these must come first for root pointer scanning in GC to work - mp_obj_dict_t *dict_locals; - mp_obj_dict_t *dict_globals; - // these must come next in this order for root pointer scanning in GC to work mp_state_thread_t thread; mp_state_vm_t vm; mp_state_mem_t mem; @@ -224,7 +222,7 @@ typedef struct _mp_state_ctx_t { extern mp_state_ctx_t mp_state_ctx; -#define MP_STATE_CTX(x) (mp_state_ctx.x) +#define MP_STATE_CTX(x) MP_STATE_THREAD(x) #define MP_STATE_VM(x) (mp_state_ctx.vm.x) #define MP_STATE_MEM(x) (mp_state_ctx.mem.x) |
