-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Build platform ABI tag improvements #5437
base: master
Are you sure you want to change the base?
Conversation
This commit adapts the ABI tag as follows: - It removes ``PYBIND11_INTERNALS_KIND`` that was neither used nor documented. - It adapts the MSVC ABI tag to be less stringent (see PR pybind#4953) - It adapts the GCC ABI tag to be less stringent. - It adds a check for a Clang/libc++ ABI tag that wasn't present before I plan to make a consistent set of changes to nanobind so that both libraries use interchangeable platform ABI tags.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I didn't realize before that this is quite different from #4953.
I think it's best to handle Linux/macOS by itself in a separate PR, so that we can have a focussed discussion. — To add: Definitely, we should cover all platforms before we make a new pybind11 release.
include/pybind11/detail/internals.h
Outdated
# if (_MSC_VER) / 100 == 19 | ||
# define PYBIND11_BUILD_ABI NB_BUILD_LIB "_19" | ||
# else | ||
# define PYBIND11_BUILD_ABI NB_BUILD_LIB "_unknown" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I feel strongly that such a fallback will do more harm than good: people will mostly not know this is happening and will get surprised later, possibly after making releases already.
Generating an #error
here means that we will know immediately that we need to update this code. It'll be under our control then to make this right.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As was discussed in PR #4953, MSVC has been ABI-compatible for ages. There is one huge ABI break looming some years in the future (MSVC "vNext") that will mark a transition towards the next island of stability.
Based on the information that is available, this looks to be a painful and disruptive break that will in any case require recompiling all Python packages for a new Windows base platform (i.e., similar to the different "manylinux" flavors). The check here is intended to catch that transition without making pybind11 completely unusable on the vNext version.
include/pybind11/detail/internals.h
Outdated
# define PYBIND11_BUILD_ABI NB_BUILD_LIB "_unknown" | ||
# endif | ||
#elif defined(_LIBCPP_ABI_VERSION) | ||
# define PYBIND11_BUILD_ABI "_abi" NB_TOSTRING(_LIBCPP_ABI_VERSION) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
PYBIND11_TOSTRING
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right :D. Should I update the PR, or will you adapt the changes in #5439?
I noticed that you changed some of the specific strings so that the generated ABI IDs are now incompatible with nanobind. (e.g. _usecxx11
vs _legacy
used here)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I didn't realize.
Could you maybe work on #5439 directly? (Maybe after git merge master; sorry I forgot to update the PR today.)
My hope was that we can work together on 5439 until everybody is happy with it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I forgot to add:
I believe initially it'll be best to #error
for unknown situations, so that we're sure we're properly covering everything that we're testing with today. As a last step we can add in "unknown" fallbacks.
include/pybind11/detail/internals.h
Outdated
# define PYBIND11_BUILD_LIB "" | ||
# endif | ||
# if (_MSC_VER) / 100 == 19 | ||
# define PYBIND11_BUILD_ABI NB_BUILD_LIB "_19" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How is NB_BUILD_LIB
defined?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It was just a typo, fixed now.
I just merged #5375: the code changed here now lives in include/pybind11/conduit/pybind11_platform_abi_id.h |
I had second but inconclusive thoughts about using We could have provisions for both:
This way we'd be forced to update the code here (pybind/pybind11), but not the rest of the world. This might be convenient in some situations, but I still believe will backfire in others. I'm not sure what'll be best overall. |
FYI I just created #5439. It may take me a few iterations there to get all GitHub Actions to pass. I'll then post an overview of the |
…han MSVC) (#5439) * THIS IS JUST A START: First attempt to combine information from PR #4953 and PR #5437 * Include GXX_ABI and USE_CXX in the identifier Further constrain to GXX_ABI 1002 or greater and less than 2000, hopefully future proof by summarizing that as `1` along with CXX11 on or off. * style: pre-commit fixes * Use `gxx_abi_1xxx` and simplify the Clang string After discussions with Ralf Grosse-Kunstleve we think these would make good identifiers that are concise and clear. * Error if `_GLIBCXX_USE_CXX11_ABI` is not defined Within the `__GXX_ABI_VERSION` block this should always be defined, guard against unexpected defines and make the error obvious. * Change `usecxx11` to `use_cxx11_abi` for correspondence with `_GLIBCXX_USE_CXX11_ABI` (similarly to `gxx_abi` for `__GXX_ABI_VERSION`). * `PYBIND11_COMPILER_TYPE` overhaul, mainly: replace `_icc`, `_clang`, `_gcc` with `_system` * Add NVHPC (__PGI) to the list of compilers compatible with system compiler. See comment by @robertmaynard: #5439 (comment) * Fix oversight: remove __NVCOMPILER elif branch in PYBIND11_BUILD_ABI block. Also add comment pointing to this PR (#5439). * Revert "Fix oversight: remove __NVCOMPILER elif branch in PYBIND11_BUILD_ABI block." This reverts commit d412303. * Revert "Add NVHPC (__PGI) to the list of compilers compatible with system compiler." This reverts commit 9fc9515. * Define NVHPC PYBIND11_BUILD_ABI using __GNUC__, __GNUC_MINOR__, _GLIBCXX_USE_CXX11_ABI * Use _GLIBCXX_USE_CXX11_ABI to detect libstdc++, then assume that NVHPC is always in the 1xxx ABI family. * Enhance NVHPC comment and limited future proofing. * The `PYBIND11_STDLIB` is obsolete but kept around to maintain backward compatibility. * Move `PYBIND11_BUILD_TYPE` down in the file, so that the order of macro definitions is the same as in the list defining `PYBIND11_PLATFORM_ABI_ID` * Introduce `PYBIND11_COMPILER_TYPE_LEADING_UNDERSCORE`: This makes it possible to achieve these two goals: * Avoid the leading underscore in `PYBIND11_PLATFORM_ABI_ID` (see #5439 (comment)) * Maintain backward compatibility for use cases as reported under #5439 (comment) `PYBIND11_INTERNALS_KIND` is removed in this commit to ensure that `PYBIND11_COMPILER_TYPE` is the first element of the `PYBIND11_PLATFORM_ABI_ID`, so that `PYBIND11_COMPILER_TYPE_LEADING_UNDERSCORE` can meaningfully be used as a prefix for `PYBIND11_PLATFORM_ABI_ID` in pybind11/detail/internals.h. * Apply suggestion by @isuruf, with revised comments (code is as suggested). * Make determination of `PYBIND11_COMPILER_TYPE` `"macos"` or `"glibc"` more general. The main motivation is to resolve these "Manylinux on 🐍 3.13t • GIL" and "Pyodide wheel" failures: ``` /__w/pybind11/pybind11/include/pybind11/conduit/pybind11_platform_abi_id.h:35:10: error: #error "Unknown PYBIND11_COMPILER_TYPE: PLEASE REVISE THIS CODE." 35 | # error "Unknown PYBIND11_COMPILER_TYPE: PLEASE REVISE THIS CODE." | ^~~~~ ``` (All other CI jobs succeeded.) Further thought: Essentially, under Linux and macOS the `PYBIND11_COMPILER_TYPE` is only for informational purposes. ABI compatibility is determined by the libstdc++ or libc++ ABI version. * Add `PYBIND11_COMPILER_TYPE` `emscripten` * Add `PYBIND11_COMPILER_TYPE` `graalvm` * Revert "Add `PYBIND11_COMPILER_TYPE` `graalvm`" This reverts commit 75da5fb. * Revert "Add `PYBIND11_COMPILER_TYPE` `emscripten`" This reverts commit e34dc8b. * Revert "Make determination of `PYBIND11_COMPILER_TYPE` `"macos"` or `"glibc"` more general." This reverts commit 41daaa4. * Revert "Apply suggestion by @isuruf, with revised comments (code is as suggested)." This reverts commit ca9e699. * Remove `defined(__INTEL_COMPILER)` as suggested by @hpkfft under #5439 (comment) --------- Co-authored-by: Marcus D. Hanwell <[email protected]> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
With pybind11 and nanobind considering changes to the platform ABI tag, there is a nice opportunity to make them consistent with each other. This would make it potentially possible to later use that ABI tag to safely dispatch function calls between the two libraries.
This commit adapts the ABI tag as follows:
PYBIND11_INTERNALS_KIND
that was neither used nor documented.