Skip to content

Commit 6e6d47a

Browse files
committed
Directly access ob_type in Py_TYPE
1 parent 4d7b502 commit 6e6d47a

File tree

3 files changed

+72
-23
lines changed

3 files changed

+72
-23
lines changed
Lines changed: 64 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
/*
2+
* Copyright (c) 2024, 2024, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* The Universal Permissive License (UPL), Version 1.0
6+
*
7+
* Subject to the condition set forth below, permission is hereby granted to any
8+
* person obtaining a copy of this software, associated documentation and/or
9+
* data (collectively the "Software"), free of charge and under any and all
10+
* copyright rights in the Software, and any and all patent rights owned or
11+
* freely licensable by each licensor hereunder covering either (i) the
12+
* unmodified Software as contributed to or provided by such licensor, or (ii)
13+
* the Larger Works (as defined below), to deal in both
14+
*
15+
* (a) the Software, and
16+
*
17+
* (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
18+
* one is included with the Software each a "Larger Work" to which the Software
19+
* is contributed by such licensors),
20+
*
21+
* without restriction, including without limitation the rights to copy, create
22+
* derivative works of, display, perform, and distribute the Software and make,
23+
* use, sell, offer for sale, import, export, have made, and have sold the
24+
* Software and the Larger Work(s), and to sublicense the foregoing rights on
25+
* either these or other terms.
26+
*
27+
* This license is subject to the following condition:
28+
*
29+
* The above copyright notice and either this complete permission notice or at a
30+
* minimum a reference to the UPL must be included in all copies or substantial
31+
* portions of the Software.
32+
*
33+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
39+
* SOFTWARE.
40+
*/
41+
42+
#ifndef SRC_HANDLES_H_
43+
#define SRC_HANDLES_H_
44+
45+
#include <object.h>
46+
47+
#define MANAGED_REFCNT 10
48+
#define HANDLE_BASE 0x8000000000000000ULL
49+
#define IMMORTAL_REFCNT (INT64_MAX >> 1)
50+
51+
#ifdef GRAALVM_PYTHON_LLVM_MANAGED
52+
#include <graalvm/llvm/polyglot.h>
53+
#define points_to_py_handle_space(PTR) polyglot_is_value((PTR))
54+
#define stub_to_pointer(STUB_PTR) (STUB_PTR)
55+
#define pointer_to_stub(O) (O)
56+
#else /* GRAALVM_PYTHON_LLVM_MANAGED */
57+
58+
#define points_to_py_handle_space(PTR) ((((uintptr_t) (PTR)) & HANDLE_BASE) != 0)
59+
#define stub_to_pointer(STUB_PTR) (((uintptr_t) (STUB_PTR)) | HANDLE_BASE)
60+
#define pointer_to_stub(PTR) ((PyObject *)(((uintptr_t) (PTR)) & ~HANDLE_BASE))
61+
62+
#endif /* GRAALVM_PYTHON_LLVM_MANAGED */
63+
64+
#endif /* SRC_HANDLES_H_ */

graalpython/com.oracle.graal.python.cext/include/object.h

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
/* Copyright (c) 2018, 2023, Oracle and/or its affiliates.
1+
/* Copyright (c) 2018, 2024, Oracle and/or its affiliates.
22
* Copyright (C) 1996-2020 Python Software Foundation
33
*
44
* Licensed under the PYTHON SOFTWARE FOUNDATION LICENSE VERSION 2
@@ -57,6 +57,8 @@ A standard interface exists for objects that contain an array of items
5757
whose size is determined when the object is allocated.
5858
*/
5959

60+
#include "graalpy/handles.h"
61+
6062
/* Py_DEBUG implies Py_REF_DEBUG. */
6163
#if defined(Py_DEBUG) && !defined(Py_REF_DEBUG)
6264
# define Py_REF_DEBUG
@@ -135,10 +137,14 @@ PyAPI_FUNC(int) Py_Is(PyObject *x, PyObject *y);
135137
PyAPI_FUNC(Py_ssize_t) _Py_REFCNT(const PyObject *ob);
136138
#define Py_REFCNT(ob) _Py_REFCNT(_PyObject_CAST_CONST(ob))
137139

138-
139140
PyAPI_FUNC(PyTypeObject*) _Py_TYPE(const PyObject *ob);
141+
140142
// bpo-39573: The Py_SET_TYPE() function must be used to set an object type.
143+
#if defined(GRAALVM_PYTHON_LLVM_MANAGED) || !defined(NDEBUG)
141144
#define Py_TYPE(ob) _Py_TYPE(_PyObject_CAST_CONST(ob))
145+
#else
146+
#define Py_TYPE(ob) (pointer_to_stub(ob)->ob_type)
147+
#endif
142148

143149
PyAPI_FUNC(Py_ssize_t) _Py_SIZE(const PyVarObject *ob);
144150
// bpo-39573: The Py_SET_SIZE() function must be used to set an object size.

graalpython/com.oracle.graal.python.cext/src/capi.h

Lines changed: 0 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -801,27 +801,6 @@ static inline int get_method_flags_wrapper(int flags) {
801801
return JWRAPPER_UNSUPPORTED;
802802
}
803803

804-
#define MANAGED_REFCNT 10
805-
#define HANDLE_BASE 0x8000000000000000ULL
806-
#define IMMORTAL_REFCNT (INT64_MAX >> 1)
807-
808-
#ifdef GRAALVM_PYTHON_LLVM_MANAGED
809-
#define points_to_py_handle_space(PTR) polyglot_is_value((PTR))
810-
#else /* GRAALVM_PYTHON_LLVM_MANAGED */
811-
812-
#define points_to_py_handle_space(PTR) ((((uintptr_t) (PTR)) & HANDLE_BASE) != 0)
813-
814-
static MUST_INLINE PyObject *stub_to_pointer(PyObject *stub_ptr)
815-
{
816-
return ((uintptr_t) stub_ptr) | HANDLE_BASE;
817-
}
818-
819-
static MUST_INLINE PyObject *pointer_to_stub(PyObject *o)
820-
{
821-
return ((uintptr_t) o) & ~HANDLE_BASE;
822-
}
823-
#endif /* GRAALVM_PYTHON_LLVM_MANAGED */
824-
825804
void register_native_slots(PyTypeObject* managed_class, PyGetSetDef* getsets, PyMemberDef* members);
826805

827806
// export the SizeT arg parse functions, because we use them in contrast to cpython on windows for core modules that we link dynamically

0 commit comments

Comments
 (0)