py/modthread: Initialise nlr_jump_callback_top on threads.

The main thread gets this because the thread state is in bss, but
subsequent threads need this field to be initialised.

Also added a note to mpstate.h to help avoid missing this in the future.

Fixes issue #12695.

This work was funded through GitHub Sponsors.

Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
pull/12711/head
Jim Mussared 2023-10-17 12:27:49 +11:00 zatwierdzone przez Damien George
rodzic e78471416b
commit 3883f29485
2 zmienionych plików z 5 dodań i 2 usunięć

Wyświetl plik

@ -174,6 +174,7 @@ STATIC void *thread_entry(void *args_in) {
// The GC starts off unlocked on this thread.
ts.gc_lock_depth = 0;
ts.nlr_jump_callback_top = NULL;
ts.mp_pending_exception = MP_OBJ_NULL;
// set locals and globals from the calling context

Wyświetl plik

@ -249,8 +249,10 @@ typedef struct _mp_state_vm_t {
#endif
} mp_state_vm_t;
// This structure holds state that is specific to a given thread.
// Everything in this structure is scanned for root pointers.
// This structure holds state that is specific to a given thread. Everything
// in this structure is scanned for root pointers. Anything added to this
// structure must have corresponding initialisation added to thread_entry (in
// py/modthread.c).
typedef struct _mp_state_thread_t {
// Stack top at the start of program
char *stack_top;