Add assertions on tracemalloc_reentrant_key

Issue #26588.
This commit is contained in:
Victor Stinner 2016-03-22 17:45:09 +01:00
parent 0cfc058d61
commit 4a06647534
1 changed files with 8 additions and 2 deletions

View File

@ -167,7 +167,7 @@ tracemalloc_error(const char *format, ...)
# error "need native thread local storage (TLS)" # error "need native thread local storage (TLS)"
#endif #endif
static int tracemalloc_reentrant_key; static int tracemalloc_reentrant_key = -1;
/* Any non-NULL pointer can be used */ /* Any non-NULL pointer can be used */
#define REENTRANT Py_True #define REENTRANT Py_True
@ -175,7 +175,10 @@ static int tracemalloc_reentrant_key;
static int static int
get_reentrant(void) get_reentrant(void)
{ {
void *ptr = PyThread_get_key_value(tracemalloc_reentrant_key); void *ptr;
assert(tracemalloc_reentrant_key != -1);
ptr = PyThread_get_key_value(tracemalloc_reentrant_key);
if (ptr != NULL) { if (ptr != NULL) {
assert(ptr == REENTRANT); assert(ptr == REENTRANT);
return 1; return 1;
@ -188,6 +191,8 @@ static void
set_reentrant(int reentrant) set_reentrant(int reentrant)
{ {
assert(reentrant == 0 || reentrant == 1); assert(reentrant == 0 || reentrant == 1);
assert(tracemalloc_reentrant_key != -1);
if (reentrant) { if (reentrant) {
assert(!get_reentrant()); assert(!get_reentrant());
PyThread_set_key_value(tracemalloc_reentrant_key, REENTRANT); PyThread_set_key_value(tracemalloc_reentrant_key, REENTRANT);
@ -1018,6 +1023,7 @@ DEBUG("tracemalloc_deinit(): exit (not initialized)");
DEBUG("tracemalloc_deinit(): delete reentrant key"); DEBUG("tracemalloc_deinit(): delete reentrant key");
#ifdef REENTRANT_THREADLOCAL #ifdef REENTRANT_THREADLOCAL
PyThread_delete_key(tracemalloc_reentrant_key); PyThread_delete_key(tracemalloc_reentrant_key);
tracemalloc_reentrant_key = -1;
#endif #endif
Py_XDECREF(unknown_filename); Py_XDECREF(unknown_filename);