Commit 1e739454 authored by Tim Peters's avatar Tim Peters Committed by GitHub

visit_reachable: replace release-mode test with an assert. (GH-16866)

It should be impossible for an untracked object to have the collecting
flag set.  Back when state was stored in gc_refs, it obviously was
impossible (gc_refs couldn't possibly have a positive & negative value
simultaneously).  While the _implementation_ of "state" has gotten much
more complicated, it's still _logically_ just as impossible.
parent 5bc6a7c0
...@@ -468,13 +468,16 @@ visit_reachable(PyObject *op, PyGC_Head *reachable) ...@@ -468,13 +468,16 @@ visit_reachable(PyObject *op, PyGC_Head *reachable)
PyGC_Head *gc = AS_GC(op); PyGC_Head *gc = AS_GC(op);
const Py_ssize_t gc_refs = gc_get_refs(gc); const Py_ssize_t gc_refs = gc_get_refs(gc);
// Ignore untracked objects and objects in other generation. // Ignore objects in other generation.
// This also skips objects "to the left" of the current position in // This also skips objects "to the left" of the current position in
// move_unreachable's scan of the 'young' list - they've already been // move_unreachable's scan of the 'young' list - they've already been
// traversed, and no longer have the PREV_MASK_COLLECTING flag. // traversed, and no longer have the PREV_MASK_COLLECTING flag.
if (gc->_gc_next == 0 || !gc_is_collecting(gc)) { if (! gc_is_collecting(gc)) {
return 0; return 0;
} }
// It would be a logic error elsewhere if the collecting flag were set on
// an untracked object.
assert(gc->_gc_next != 0);
if (gc->_gc_next & NEXT_MASK_UNREACHABLE) { if (gc->_gc_next & NEXT_MASK_UNREACHABLE) {
/* This had gc_refs = 0 when move_unreachable got /* This had gc_refs = 0 when move_unreachable got
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment