Commit bcda8f1d authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-35081: Add Include/internal/pycore_object.h (GH-10640)

Move _PyObject_GC_TRACK() and _PyObject_GC_UNTRACK() from
Include/objimpl.h to Include/internal/pycore_object.h.
parent aac1f81e
#ifndef Py_INTERNAL_OBJECT_H
#define Py_INTERNAL_OBJECT_H
#ifdef __cplusplus
extern "C" {
#endif
#if !defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_BUILTIN)
# error "this header requires Py_BUILD_CORE or Py_BUILD_CORE_BUILTIN defined"
#endif
/* Tell the GC to track this object.
*
* NB: While the object is tracked by the collector, it must be safe to call the
* ob_traverse method.
*
* Internal note: _PyRuntime.gc.generation0->_gc_prev doesn't have any bit flags
* because it's not object header. So we don't use _PyGCHead_PREV() and
* _PyGCHead_SET_PREV() for it to avoid unnecessary bitwise operations.
*
* The PyObject_GC_Track() function is the public version of this macro.
*/
#define _PyObject_GC_TRACK(o) do { \
PyGC_Head *g = _Py_AS_GC(o); \
if (g->_gc_next != 0) { \
Py_FatalError("GC object already tracked"); \
} \
assert((g->_gc_prev & _PyGC_PREV_MASK_COLLECTING) == 0); \
PyGC_Head *last = (PyGC_Head*)(_PyRuntime.gc.generation0->_gc_prev); \
_PyGCHead_SET_NEXT(last, g); \
_PyGCHead_SET_PREV(g, last); \
_PyGCHead_SET_NEXT(g, _PyRuntime.gc.generation0); \
_PyRuntime.gc.generation0->_gc_prev = (uintptr_t)g; \
} while (0);
/* Tell the GC to stop tracking this object.
*
* Internal note: This may be called while GC. So _PyGC_PREV_MASK_COLLECTING must
* be cleared. But _PyGC_PREV_MASK_FINALIZED bit is kept.
*
* The PyObject_GC_UnTrack() function is the public version of this macro.
*/
#define _PyObject_GC_UNTRACK(o) do { \
PyGC_Head *g = _Py_AS_GC(o); \
PyGC_Head *prev = _PyGCHead_PREV(g); \
PyGC_Head *next = _PyGCHead_NEXT(g); \
assert(next != NULL); \
_PyGCHead_SET_NEXT(prev, next); \
_PyGCHead_SET_PREV(next, prev); \
g->_gc_next = 0; \
g->_gc_prev &= _PyGC_PREV_MASK_FINALIZED; \
} while (0);
#ifdef __cplusplus
}
#endif
#endif /* !Py_INTERNAL_OBJECT_H */
...@@ -323,51 +323,6 @@ typedef struct { ...@@ -323,51 +323,6 @@ typedef struct {
_PyGCHead_SET_FINALIZED(_Py_AS_GC(o)) _PyGCHead_SET_FINALIZED(_Py_AS_GC(o))
#endif /* !defined(Py_LIMITED_API) */ #endif /* !defined(Py_LIMITED_API) */
#if defined(Py_BUILD_CORE) || defined(Py_BUILD_CORE_BUILTIN)
/* Tell the GC to track this object.
*
* NB: While the object is tracked by the collector, it must be safe to call the
* ob_traverse method.
*
* Internal note: _PyRuntime.gc.generation0->_gc_prev doesn't have any bit flags
* because it's not object header. So we don't use _PyGCHead_PREV() and
* _PyGCHead_SET_PREV() for it to avoid unnecessary bitwise operations.
*
* The PyObject_GC_Track() function is the public version of this macro.
*/
#define _PyObject_GC_TRACK(o) do { \
PyGC_Head *g = _Py_AS_GC(o); \
if (g->_gc_next != 0) { \
Py_FatalError("GC object already tracked"); \
} \
assert((g->_gc_prev & _PyGC_PREV_MASK_COLLECTING) == 0); \
PyGC_Head *last = (PyGC_Head*)(_PyRuntime.gc.generation0->_gc_prev); \
_PyGCHead_SET_NEXT(last, g); \
_PyGCHead_SET_PREV(g, last); \
_PyGCHead_SET_NEXT(g, _PyRuntime.gc.generation0); \
_PyRuntime.gc.generation0->_gc_prev = (uintptr_t)g; \
} while (0);
/* Tell the GC to stop tracking this object.
*
* Internal note: This may be called while GC. So _PyGC_PREV_MASK_COLLECTING must
* be cleared. But _PyGC_PREV_MASK_FINALIZED bit is kept.
*
* The PyObject_GC_UnTrack() function is the public version of this macro.
*/
#define _PyObject_GC_UNTRACK(o) do { \
PyGC_Head *g = _Py_AS_GC(o); \
PyGC_Head *prev = _PyGCHead_PREV(g); \
PyGC_Head *next = _PyGCHead_NEXT(g); \
assert(next != NULL); \
_PyGCHead_SET_NEXT(prev, next); \
_PyGCHead_SET_PREV(next, prev); \
g->_gc_next = 0; \
g->_gc_prev &= _PyGC_PREV_MASK_FINALIZED; \
} while (0);
#endif /* defined(Py_BUILD_CORE) || defined(Py_BUILD_CORE_BUILTIN) */
#ifndef Py_LIMITED_API #ifndef Py_LIMITED_API
PyAPI_FUNC(PyObject *) _PyObject_GC_Malloc(size_t size); PyAPI_FUNC(PyObject *) _PyObject_GC_Malloc(size_t size);
PyAPI_FUNC(PyObject *) _PyObject_GC_Calloc(size_t size); PyAPI_FUNC(PyObject *) _PyObject_GC_Calloc(size_t size);
......
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
#include "pythread.h" #include "pythread.h"
......
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "structmember.h" /* for offsetof() */ #include "structmember.h" /* for offsetof() */
#include "_iomodule.h" #include "_iomodule.h"
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "structmember.h" #include "structmember.h"
#ifdef HAVE_SYS_TYPES_H #ifdef HAVE_SYS_TYPES_H
#include <sys/types.h> #include <sys/types.h>
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "structmember.h" #include "structmember.h"
#include "_iomodule.h" #include "_iomodule.h"
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include "Python.h" #include "Python.h"
#include "structmember.h" #include "structmember.h"
#include "pycore_accu.h" #include "pycore_accu.h"
#include "pycore_object.h"
#include "_iomodule.h" #include "_iomodule.h"
/* Implementation note: the buffer is always at least one character longer /* Implementation note: the buffer is always at least one character longer
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "structmember.h" #include "structmember.h"
#include "_iomodule.h" #include "_iomodule.h"
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#ifdef MS_WINDOWS #ifdef MS_WINDOWS
...@@ -556,7 +557,7 @@ read_console_w(HANDLE handle, DWORD maxlen, DWORD *readlen) { ...@@ -556,7 +557,7 @@ read_console_w(HANDLE handle, DWORD maxlen, DWORD *readlen) {
Py_BEGIN_ALLOW_THREADS Py_BEGIN_ALLOW_THREADS
DWORD off = 0; DWORD off = 0;
while (off < maxlen) { while (off < maxlen) {
DWORD n = (DWORD)-1; DWORD n = (DWORD)-1;
DWORD len = min(maxlen - off, BUFSIZ); DWORD len = min(maxlen - off, BUFSIZ);
SetLastError(0); SetLastError(0);
BOOL res = ReadConsoleW(handle, &buf[off], len, &n, NULL); BOOL res = ReadConsoleW(handle, &buf[off], len, &n, NULL);
......
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "Python.h" #include "Python.h"
#include "pycore_context.h" #include "pycore_context.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "frameobject.h" /* for PyFrame_ClearFreeList */ #include "frameobject.h" /* for PyFrame_ClearFreeList */
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
......
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "frameobject.h" #include "frameobject.h"
......
/* Cell object implementation */ /* Cell object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
......
/* Class object implementation (dead now except for methods) */ /* Class object implementation (dead now except for methods) */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
......
/* Descriptors -- a new, flexible way to describe attributes */ /* Descriptors -- a new, flexible way to describe attributes */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" /* Why is this not included in Python.h? */ #include "structmember.h" /* Why is this not included in Python.h? */
......
...@@ -111,6 +111,7 @@ converting the dict to the combined table. ...@@ -111,6 +111,7 @@ converting the dict to the combined table.
#define PyDict_MINSIZE 8 #define PyDict_MINSIZE 8
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "dict-common.h" #include "dict-common.h"
#include "stringlib/eq.h" /* to get unicode_eq() */ #include "stringlib/eq.h" /* to get unicode_eq() */
......
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include <Python.h> #include <Python.h>
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
......
/* Frame object implementation */ /* Frame object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "code.h" #include "code.h"
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
/* Function object implementation */ /* Function object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "code.h" #include "code.h"
......
/* Generator object implementation */ /* Generator object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "frameobject.h" #include "frameobject.h"
#include "structmember.h" #include "structmember.h"
......
/* Iterator objects */ /* Iterator objects */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
......
/* List object implementation */ /* List object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "pycore_accu.h" #include "pycore_accu.h"
......
/* Memoryview object implementation */ /* Memoryview object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "pystrhex.h" #include "pystrhex.h"
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
/* Method object implementation */ /* Method object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
......
...@@ -465,6 +465,7 @@ later: ...@@ -465,6 +465,7 @@ later:
*/ */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
#include "dict-common.h" #include "dict-common.h"
......
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
*/ */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
......
...@@ -14,6 +14,7 @@ this type and there is exactly one in existence. ...@@ -14,6 +14,7 @@ this type and there is exactly one in existence.
*/ */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pymem.h" #include "pycore_pymem.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "structmember.h" #include "structmember.h"
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
/* Tuple object implementation */ /* Tuple object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "pycore_accu.h" #include "pycore_accu.h"
......
/* Type object implementation */ /* Type object implementation */
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "frameobject.h" #include "frameobject.h"
#include "structmember.h" #include "structmember.h"
......
...@@ -41,6 +41,7 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ...@@ -41,6 +41,7 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#define PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN
#include "Python.h" #include "Python.h"
#include "pycore_fileutils.h" #include "pycore_fileutils.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "ucnhash.h" #include "ucnhash.h"
#include "bytes_methods.h" #include "bytes_methods.h"
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#define PY_LOCAL_AGGRESSIVE #define PY_LOCAL_AGGRESSIVE
#include "Python.h" #include "Python.h"
#include "pycore_object.h"
#include "pycore_pystate.h" #include "pycore_pystate.h"
#include "code.h" #include "code.h"
......
#include "Python.h" #include "Python.h"
#include "structmember.h"
#include "pycore_pystate.h"
#include "pycore_context.h" #include "pycore_context.h"
#include "pycore_hamt.h" #include "pycore_hamt.h"
#include "pycore_object.h"
#include "pycore_pystate.h"
#include "structmember.h"
#define CONTEXT_FREELIST_MAXLEN 255 #define CONTEXT_FREELIST_MAXLEN 255
......
#include "Python.h" #include "Python.h"
#include "structmember.h"
#include "pycore_pystate.h"
#include "pycore_hamt.h" #include "pycore_hamt.h"
#include "pycore_object.h"
#include "pycore_pystate.h"
#include "structmember.h"
/* /*
This file provides an implemention of an immutable mapping using the This file provides an implemention of an immutable mapping using the
......
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