diff options
Diffstat (limited to 'Python/pystate.c')
| -rw-r--r-- | Python/pystate.c | 15 | 
1 files changed, 13 insertions, 2 deletions
| diff --git a/Python/pystate.c b/Python/pystate.c index 2ac2fd5274..926ef07e21 100644 --- a/Python/pystate.c +++ b/Python/pystate.c @@ -22,6 +22,12 @@ to avoid the expense of doing their own locking).  #endif  #endif +#if defined _MSC_VER && _MSC_VER >= 1900 +/* Issue #23524: Temporary fix to disable termination due to invalid parameters */ +PyAPI_DATA(void*) _Py_silent_invalid_parameter_handler; +#include <stdlib.h> +#endif +  #ifdef __cplusplus  extern "C" {  #endif @@ -222,6 +228,11 @@ new_threadstate(PyInterpreterState *interp, int init)              tstate->next->prev = tstate;          interp->tstate_head = tstate;          HEAD_UNLOCK(); + +#if defined _MSC_VER && _MSC_VER >= 1900 +        /* Issue #23524: Temporary fix to disable termination due to invalid parameters */ +        _set_thread_local_invalid_parameter_handler((_invalid_parameter_handler)_Py_silent_invalid_parameter_handler); +#endif      }      return tstate; @@ -403,7 +414,7 @@ tstate_delete_common(PyThreadState *tstate)  void  PyThreadState_Delete(PyThreadState *tstate)  { -    if (tstate == _Py_atomic_load_relaxed(&_PyThreadState_Current)) +    if (tstate == (PyThreadState*)_Py_atomic_load_relaxed(&_PyThreadState_Current))          Py_FatalError("PyThreadState_Delete: tstate is still current");  #ifdef WITH_THREAD      if (autoInterpreterState && PyThread_get_key_value(autoTLSkey) == tstate) @@ -662,7 +673,7 @@ PyThreadState_IsCurrent(PyThreadState *tstate)  {      /* Must be the tstate for this thread */      assert(PyGILState_GetThisThreadState()==tstate); -    return tstate == _Py_atomic_load_relaxed(&_PyThreadState_Current); +    return tstate == (PyThreadState*)_Py_atomic_load_relaxed(&_PyThreadState_Current);  }  /* Internal initialization/finalization functions called by | 
