Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

3.14.0a2 rebuild needed for 0x03070000 limited api c extension #127191

Closed
MrBitBucket opened this issue Nov 23, 2024 · 7 comments
Closed

3.14.0a2 rebuild needed for 0x03070000 limited api c extension #127191

MrBitBucket opened this issue Nov 23, 2024 · 7 comments
Labels
3.14 new features, bugs and security fixes interpreter-core (Objects, Python, Grammar, and Parser dirs) type-bug An unexpected behavior, bug, or error

Comments

@MrBitBucket
Copy link

MrBitBucket commented Nov 23, 2024

Bug report

Bug description:

An existing C api extension compiled with Python 3.7-3.11 behaves differently when run in Python 3.14.0a2. Causing a reference count change where none is expected. The python test code looks like this

from sys import getrefcount
from _rl_accel import unicode2T1

utext = 'This is the end of the world'

class Font:
    def __init__(self,name):
        self.fontName = name
        self.substitutionFonts = []
        self.encName = 'utf8'

font = Font('Helvetica')

defns = 'utext font font.encName font.fontName font.substitutionFonts'.split()
rc0 = [getrefcount(eval(x,globals())) for x in defns]
print(rc0)
unicode2T1(utext,[font]+font.substitutionFonts)
rc1 = [getrefcount(eval(x,globals())) for x in defns]
print(rc1)
if rc1!=rc0:
    print('!!!!! reference counts changed !!!!!')

The C function unicode2T1 is not expected to change any of the refcounts checked, but if built with python 3.7-3.11
we see a decrease in the refcount for font.encName when running in python 3.14.0a2.

If built with python 3.14.0a2 the reference count decrease is not seen in the test. It seems that my code is broken in terms of the abi3 guarantee.

To ease checking I built a bash script to checkout and build the test environments; this can be found here.

I run this like

EARLYPYTHON=~/bin/python311 LATEPYTHON=~/bin/python314 tests/runner.sh

Sorry this example is so large, but at least reportlab is not required. We do have a python version of this code rl_accel.py

CPython versions tested on:

3.9, 3.10, 3.11, 3.12, 3.13, 3.14

Operating systems tested on:

Linux

Related

discuss.python.org/t/3-14-0a2-rebuild-needed-for-0x03070000-limited-api-c-extension/72006

@MrBitBucket MrBitBucket added the type-bug An unexpected behavior, bug, or error label Nov 23, 2024
@MrBitBucket
Copy link
Author

I think this is expected now that the immortality of some/all globals is happening in Python >= 3.12. Probably I just need to build new wheels using a late python.

@picnixz
Copy link
Member

picnixz commented Nov 23, 2024

I'm not sure we can do anything on our side since it affects 3rd party extensions and a security-branch only. However I don't know the exact policy concerning that kind of breaking change hence I'm asking @iritkatriel or @vstinner.

@picnixz picnixz added interpreter-core (Objects, Python, Grammar, and Parser dirs) pending The issue will be closed if no feedback is provided labels Nov 23, 2024
@ZeroIntensity
Copy link
Member

As far as I know, the actual reference count of an object is an implementation detail, not part of the stable ABI.

@vstinner
Copy link
Member

Can you try to write a reproducer which doesn't depend on third party code?

@vstinner
Copy link
Member

@picnixz picnixz added 3.14 new features, bugs and security fixes build The build process and cross-build and removed pending The issue will be closed if no feedback is provided build The build process and cross-build labels Dec 15, 2024
@erlend-aasland
Copy link
Contributor

Based on the discussion over at DPO, it sounds to me we can close this as "not planned".

@erlend-aasland erlend-aasland added the pending The issue will be closed if no feedback is provided label Jan 4, 2025
@ZeroIntensity
Copy link
Member

Yeah, reference counts aren't part of the stable ABI. I wonder if we should add a sys._is_immortal for situations like this, similar to how we have sys._is_interned.

@erlend-aasland erlend-aasland closed this as not planned Won't fix, can't repro, duplicate, stale Jan 4, 2025
@erlend-aasland erlend-aasland removed the pending The issue will be closed if no feedback is provided label Jan 4, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
3.14 new features, bugs and security fixes interpreter-core (Objects, Python, Grammar, and Parser dirs) type-bug An unexpected behavior, bug, or error
Projects
None yet
Development

No branches or pull requests

5 participants