-
Notifications
You must be signed in to change notification settings - Fork 44
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
Support for new cp313t
GIL-free ABI variant
#40
Comments
It's very much more involved than that. CFFI is full of static global caches (guaranteeing the uniqueness of many CTypeObject, for example). There is also careful logic around when to acquire and release the GIL around calls, and particularly callbacks. I believe that if you just try out the tests, then yes, it will mostly work because they are mostly single-threaded. In a real multithreaded environment you're going to see very obscure failures sometimes (e.g. "object of ctype 'int **' is expected, but got instead 'int **'"). Supporting multithreading requires a through review of the whole source code of CFFI, I'm afraid. Otherwise we get some "meh, doesn't usually crashes, that's good enough". I certainly hope that it's not what CPython is going for in the GIL-free ABI variant. I would object to distribute such a version of CFFI. |
@arigo 100% agreed on all points- I just wanted to see what kind of gaps might need to be filled to even get it to build and run single-threaded under the new I re-tried some of the concurrency testing I'd previously done on Sam's 3.9 I'm also very much against actually shipping a known-broken |
Hi! We've been working on porting extension modules to the free-threading interpreter and tracking the work over at https://github.com/Quansight-Labs/free-threaded-compatibility. I did most of the work on the NumPy port, which also has a lot of static global caches I had to make thread local, add a single-initialization API and initialize the cache using that, or add locking. I don't know whether I can directly work on cffi, but I'm happy to answer questions or share experiences. |
Blocked-by: python-cffi/cffi#40
Blocked-by: python-cffi/cffi#40
Maybe this issue should be left open until the static global caches alluded to above are made thread-safe? Does cffi have existing multithreaded test coverage? If not then I'd be suspicious about having found all the data races that may exist in C code. |
@ngoldbaum There's a new issue for tracking known blockers to supporting free-threading: #126 |
🙃 makes sense! sorry for the noise... |
@ngoldbaum No worries- thanks for all you're doing (all over the place 😆 ) to keep stuff moving forward on this! It's fun to see things starting to actually light up and work, but yeah, creating heavily threaded stress tests to exercise all the init, type creation, refcounting, buffer marshaling, etc is going to be a big job. IIRC nearly none of the existing test suite exercises Python threads- most of the concurrent tests are focused on the embedding use case (with natively-created pthreads calling in to Python). Even those tests are mainly focused on stressing the interpreter startup locking- the actual Python operations are near-no-op idempotent functions with stack-only scalars, so very little concurrent exercise of all the little internal atomic-ish things that the GIL is protecting today. |
I did some smoke testing with the new GIL-free
t
CPython ABI on 3.13.0a2. I had to patch upwheel
with a pre-release version ofpackaging
to get it to build and install without barfing on the new ABI tag, but once I got past that, most of the CFFI test suite is passing. Looks like the majority of the failures are related to new symbol exports (possibly unique to the nogil build?) that need to be accounted for, eg:I've already added some 3.13 pre-release smoke-testing- once the various packaging tools we need have released versions that support the new
t
ABI tagging, we can include that as well.The text was updated successfully, but these errors were encountered: