-
Notifications
You must be signed in to change notification settings - Fork 2.2k
fix: allow the ABI string to be forced #2602
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
Conversation
|
||
/// On MSVC, debug and release builds are not ABI-compatible! | ||
#if defined(_MSC_VER) && defined(_DEBUG) | ||
# define PYBIND11_BUILD_TYPE "_debug" |
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.
Very minor & optional: I'd undo the whitespace change here, to reduce the potential for confusion.
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.
There was a mix of 2-space and 3-space indentation in these, I normalized to two space. You can use -w
when calling git blame to ignore whitespace, and there's a temporary ignore whitespace setting for the git diffs.
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.
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 can still undo if you think it should be undone - obviously I didn't search out and fix all uneven whitespace ;) )
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'm with the PR fine as-is. Thanks!
(Already merged, but for the record this look all good to me.) |
What's the immediate motivation behind this, actually? Is there any way 2.3 can work with 2.6? This does feel like it could cause weird segfaults that we'll have to debug for users? :-( EDIT: Sorry, I have found the thread on commit c9f5a46, now: c9f5a46#commitcomment-35812965 |
The immediate need is for PyTorch. They have been stuck trying to upgrade to 2.4 since the beginning of the year in order to fix bugs, but haven't been able to. The problem is that they compile a bunch of modules, then at run time they also have a JIT that compiles and needs to use the existing module. If the JIT compiler ID doesn't exactly match, 2.4 and later fail due to this addition. They have been happily using it without this for now, and this would allow the upgrade to move forward separately of this change. We could not even debug the issue without the ability to force this. Also other users who were using pybind11 to mix clang and gcc could continue to do so now without being stuck on an old version.
So if a user is intentionally forcing the ABI string with these defs, then coming to us and complaining that the ABI is not actually compatible? And, it would be nice to be able to eventually either support a compiler-independent ABI (might already at least support gcc vs. clang), and have only truly incompatible modules separated by different ABI strings. To test that, we have to be able to force the ABI strings to match. |
Right. Thanks, @henryiii!
Well, the danger is not knowing it when the user forgets to report it. Guess we'll just have to be extra careful? |
When building on ubuntu 24.04 with gcc 13, and linking against the hsdk python bindings built on ubuntu 22.04 with gcc 11, trying to import these bindings, would fail like so: ``` ImportError: generic_type: type 'MyOp' referenced unknown base type 'holoscan::Operator' ``` Reference: - pybind/pybind11#3751 - pybind/pybind11#2602 The Holoscan SDK 3.3 will provide a new cmake target named 'holoscan::pybind11' with overriden PYBIND11 compiler definitions to disable strict ABI protection. This change stays backwards compatible with the Holoscan SDK 3.2 and below by simply warning if the 'holoscan::pybind11' target is not found, in which case developers will need to ensure they are using the same compiler and C++ library version as what was used in the version of the Holoscan SDK they're linking against, as warned in the cmake log. Signed-off-by: Alexis Girault <agirault@nvidia.com>
When building on ubuntu 24.04 with gcc 13, and linking against the hsdk python bindings built on ubuntu 22.04 with gcc 11, trying to import these bindings, would fail like so: ``` ImportError: generic_type: type 'MyOp' referenced unknown base type 'holoscan::Operator' ``` Reference: - pybind/pybind11#3751 - pybind/pybind11#2602 The Holoscan SDK 3.3 will provide a new cmake target named 'holoscan::pybind11' with overriden PYBIND11 compiler definitions to disable strict ABI protection. This change stays backwards compatible with the Holoscan SDK 3.2 and below by simply warning if the 'holoscan::pybind11' target is not found, in which case developers will need to ensure they are using the same compiler and C++ library version as what was used in the version of the Holoscan SDK they're linking against, as warned in the cmake log. Signed-off-by: Alexis Girault <agirault@nvidia.com>
When building on ubuntu 24.04 with gcc 13, and linking against the hsdk python bindings built on ubuntu 22.04 with gcc 11, trying to import these bindings, would fail like so: ``` ImportError: generic_type: type 'MyOp' referenced unknown base type 'holoscan::Operator' ``` Reference: - pybind/pybind11#3751 - pybind/pybind11#2602 The Holoscan SDK 3.3 will provide a new cmake target named 'holoscan::pybind11' with overriden PYBIND11 compiler definitions to disable strict ABI protection. This change stays backwards compatible with the Holoscan SDK 3.2 and below by simply warning if the 'holoscan::pybind11' target is not found, in which case developers will need to ensure they are using the same compiler and C++ library version as what was used in the version of the Holoscan SDK they're linking against, as warned in the cmake log. Signed-off-by: Alexis Girault <agirault@nvidia.com>
When building on ubuntu 24.04 with gcc 13, and linking against the hsdk python bindings built on ubuntu 22.04 with gcc 11, trying to import these bindings, would fail like so: ``` ImportError: generic_type: type 'MyOp' referenced unknown base type 'holoscan::Operator' ``` Reference: - pybind/pybind11#3751 - pybind/pybind11#2602 The Holoscan SDK 3.3 will provide a new cmake target named 'holoscan::pybind11' with overriden PYBIND11 compiler definitions to disable strict ABI protection. This change stays backwards compatible with the Holoscan SDK 3.2 and below by simply warning if the 'holoscan::pybind11' target is not found, in which case developers will need to ensure they are using the same compiler and C++ library version as what was used in the version of the Holoscan SDK they're linking against, as warned in the cmake log. Signed-off-by: Alexis Girault <agirault@nvidia.com> Signed-off-by: Cliff Burdick <cburdick@nvidia.com>
When building on ubuntu 24.04 with gcc 13, and linking against the hsdk python bindings built on ubuntu 22.04 with gcc 11, trying to import these bindings, would fail like so: ``` ImportError: generic_type: type 'MyOp' referenced unknown base type 'holoscan::Operator' ``` Reference: - pybind/pybind11#3751 - pybind/pybind11#2602 The Holoscan SDK 3.3 will provide a new cmake target named 'holoscan::pybind11' with overriden PYBIND11 compiler definitions to disable strict ABI protection. This change stays backwards compatible with the Holoscan SDK 3.2 and below by simply warning if the 'holoscan::pybind11' target is not found, in which case developers will need to ensure they are using the same compiler and C++ library version as what was used in the version of the Holoscan SDK they're linking against, as warned in the cmake log. Signed-off-by: Alexis Girault <agirault@nvidia.com>
When building on ubuntu 24.04 with gcc 13, and linking against the hsdk python bindings built on ubuntu 22.04 with gcc 11, trying to import these bindings, would fail like so: ``` ImportError: generic_type: type 'MyOp' referenced unknown base type 'holoscan::Operator' ``` Reference: - pybind/pybind11#3751 - pybind/pybind11#2602 The Holoscan SDK 3.3 will provide a new cmake target named 'holoscan::pybind11' with overriden PYBIND11 compiler definitions to disable strict ABI protection. This change stays backwards compatible with the Holoscan SDK 3.2 and below by simply warning if the 'holoscan::pybind11' target is not found, in which case developers will need to ensure they are using the same compiler and C++ library version as what was used in the version of the Holoscan SDK they're linking against, as warned in the cmake log. Signed-off-by: Alexis Girault <agirault@nvidia.com>
Description
In version 2.4, commit c9f5a added extra protections to the ABI string, which affect some power users (see commits there) as well as PyTorch. This is a small patch that simply allows the various components to be pre-defined by users who know what they are doing (or a user on an odd compiler could set the string for the new compiler!). This is not a "fix", per se, which would take carful study to check ABI compatibility, but would allow users stuck on 2.3 to upgrade or work in special cases.
To restore 2.3 like behavior:
To force a specfic compiler:
Suggested changelog entry:
Should it be only for power users, or have a small changelog entry, and maybe even be listed in the docs?