https://github.com/python/cpython/commit/9221ef2d8cb7f4cf37592eb650d4c8f972033000
commit: 9221ef2d8cb7f4cf37592eb650d4c8f972033000
branch: main
author: Brett Simmers <[email protected]>
committer: colesbury <[email protected]>
date: 2024-03-20T11:18:26-04:00
summary:
gh-116908: Only write to `_pending_calls.calls_to_do` with atomic operations
(#117044)
These writes to `pending->calls_to_do` need to be atomic, because other threads
can read (atomically) from `calls_to_do` without holding `pending->mutex`.
files:
M Python/ceval_gil.c
diff --git a/Python/ceval_gil.c b/Python/ceval_gil.c
index d2cd35dfa86833..78c13d619e6ee0 100644
--- a/Python/ceval_gil.c
+++ b/Python/ceval_gil.c
@@ -671,7 +671,7 @@ _push_pending_call(struct _pending_calls *pending,
pending->calls[i].flags = flags;
pending->last = j;
assert(pending->calls_to_do < NPENDINGCALLS);
- pending->calls_to_do++;
+ _Py_atomic_add_int32(&pending->calls_to_do, 1);
return 0;
}
@@ -701,7 +701,7 @@ _pop_pending_call(struct _pending_calls *pending,
pending->calls[i] = (struct _pending_call){0};
pending->first = (i + 1) % NPENDINGCALLS;
assert(pending->calls_to_do > 0);
- pending->calls_to_do--;
+ _Py_atomic_add_int32(&pending->calls_to_do, -1);
}
}
_______________________________________________
Python-checkins mailing list -- [email protected]
To unsubscribe send an email to [email protected]
https://mail.python.org/mailman3/lists/python-checkins.python.org/
Member address: [email protected]