KEMBAR78
fix: allow the ABI string to be forced by henryiii · Pull Request #2602 · pybind/pybind11 · GitHub
Skip to content

Conversation

@henryiii
Copy link
Collaborator

@henryiii henryiii commented Oct 16, 2020

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:

#define PYBIND11_COMPILER_TYPE ""
#define PYBIND11_STDLIB ""
#define PYBIND11_BUILD_ABI ""

To force a specfic compiler:

#define PYBIND11_COMPILER_TYPE "_gcc"

Suggested changelog entry:

Should it be only for power users, or have a small changelog entry, and maybe even be listed in the docs?


/// On MSVC, debug and release builds are not ABI-compatible!
#if defined(_MSC_VER) && defined(_DEBUG)
# define PYBIND11_BUILD_TYPE "_debug"
Copy link
Collaborator

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.

Copy link
Collaborator Author

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.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Collaborator Author

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 ;) )

Copy link
Collaborator

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!

@henryiii henryiii merged commit 064362f into pybind:master Oct 16, 2020
@henryiii henryiii deleted the fix/abistr branch October 16, 2020 21:23
@wjakob
Copy link
Member

wjakob commented Oct 17, 2020

(Already merged, but for the record this look all good to me.)

@YannickJadoul
Copy link
Collaborator

YannickJadoul commented Oct 17, 2020

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

@henryiii
Copy link
Collaborator Author

henryiii commented Oct 17, 2020

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.

we'll have to debug for users

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.

See pytorch/pytorch#46415 and pytorch/pytorch#46367

@YannickJadoul
Copy link
Collaborator

Right. Thanks, @henryiii!

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?

Well, the danger is not knowing it when the user forgets to report it. Guess we'll just have to be extra careful?

agirault added a commit to nvidia-holoscan/holohub that referenced this pull request May 14, 2025
    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>
agirault added a commit to nvidia-holoscan/holohub that referenced this pull request May 15, 2025
    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>
agirault added a commit to nvidia-holoscan/holohub that referenced this pull request May 15, 2025
    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>
cliffburdick pushed a commit to cliffburdick/holohub that referenced this pull request May 29, 2025
    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>
mocsharp pushed a commit to mocsharp/holohub that referenced this pull request Jun 5, 2025
    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>
cdinea pushed a commit to cdinea/holohub that referenced this pull request Aug 27, 2025
    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>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants