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

build: compile univalue as c++11 #12467

Closed
wants to merge 3 commits into from

Conversation

theuni
Copy link
Member

@theuni theuni commented Feb 17, 2018

Reported by irc user (and maybe github user?) @esotericnonsense.

Building bitcoin as c++11 and univalue as c++03/c++14 (depending on compiler version) is pretty scary. It's surprising that this hasn't caused any issues yet.

I'm afraid the fix is a big pile of autotools nonsense, but the changes are pretty straightforward:

  • Add a new macro to simplify passing args to subconfigures (univalue and secp256k1)
  • Pass our modified CXX down to univalue
  • If using depends, don't reset the values passed to subconfigures to their defaults

The good news is that this makes it much easier to tweak subconfigure args in the future.

@theuni
Copy link
Member Author

theuni commented Feb 17, 2018

Grr, there's a bug in the macro's handling of subdirs. I'll have to fix this up next week.

@laanwj
Copy link
Member

laanwj commented Feb 17, 2018

Concept ACK.

Building bitcoin as c++11 and univalue as c++03/c++14 (depending on compiler version) is pretty scary

There are certainly some rough edge cases, but in theory (no compiler bugs) this should be ok, right? Is there any official guideline about this?

Doesn't building against system libraries have the same risks? You can never be sure what c++ standard they were compiled with, certainly not with compilers changing the default all the time.

@theuni theuni force-pushed the fix-subconfigure-args branch from 68b0fbc to 812e171 Compare March 5, 2018 20:19
@theuni
Copy link
Member Author

theuni commented Mar 5, 2018

@laanwj I think we're probably ok here, but I have no idea what happens when differing abi's get linked in together.

This could certainly be a problem if univalue was built as a shared lib though, as we could miss thrown exceptions due to differing type signatures. IIRC we actually had that issue at some point catching boost exceptions.

@fanquake
Copy link
Member

This needs a rebase.

@theuni theuni force-pushed the fix-subconfigure-args branch from 812e171 to b8fa047 Compare March 15, 2018 20:14
theuni added 3 commits March 15, 2018 16:30
Also don't set the value if it's already set.

This allows the value to be updated then passed to a subconfigure, which
would otherwise be reinitialized by the config.site
AX_SUBDIRS_CONFIGURE allows us to cleanly add/remove/filter what gets passed to
subconfigures.

This should be a no op.
Once we're certain that our CXX is compiling as c++11, pass it to univalue for
use there as well.

This avoids having a binary trying to conform to 2 abi's simultaneously.
@theuni theuni force-pushed the fix-subconfigure-args branch from b8fa047 to 8816f3d Compare March 15, 2018 20:32
@maflcko
Copy link
Member

maflcko commented Mar 18, 2018

Travis fails with

/usr/lib/gcc-cross/arm-linux-gnueabihf/4.8/../../../../arm-linux-gnueabihf/bin/ld: univalue/.libs/libunivalue.a(libunivalue_la-univalue.o): relocation R_ARM_THM_MOVW_ABS_NC against `_ZNSs4_Rep20_S_empty_rep_storageE' can not be used when making a shared object; recompile with -fPIC
univalue/.libs/libunivalue.a: error adding symbols: Bad value
collect2: error: ld returned 1 exit status

@laanwj
Copy link
Member

laanwj commented Apr 10, 2018

@theuni ping

@fanquake
Copy link
Member

@theuni Do you want to get this into 0.17.0?

@theuni
Copy link
Member Author

theuni commented Jul 18, 2018

This hit an annoying snag and didn't end up working. Closing.

@theuni theuni closed this Jul 18, 2018
theuni added a commit to theuni/bitcoin that referenced this pull request Jul 15, 2021
This addresses issues like the one in bitcoin#12467, where some of our compiler flags
end up being dropped during the subconfigure of Univalue. Specifically, we're
still using the compiler-default c++ version rather than forcing c++11.

We can drop the need subconfigure completely in favor of a tighter build
integration, where the sources are listed separately from the build recipes,
so that they may be included directly by upstream projects. This is
similar to the way leveldb build integration works in Core.

Upstream benefits of this approach include:

    Better caching (for ex. ccache and autoconf)
    No need for a slow subconfigure
    No more missing compile flags
    Compile only the objects needed

There are no benefits to Univalue itself that I can think of. These changes
should be a no-op there, and to downstreams as well until they take advantage
of the new sources.mk. Once merged, This Core branch is ready-ish for PR, and
takes advantage of the features added here.

This also removes the option to use an external univalue to avoid similar ABI
issues with mystery binaries.
theuni added a commit to theuni/bitcoin that referenced this pull request Jul 15, 2021
Requires bitcoin-core/univalue-subtree#19 .

This addresses issues like the one in bitcoin#12467, where some of our compiler flags
end up being dropped during the subconfigure of Univalue. Specifically, we're
still using the compiler-default c++ version rather than forcing c++11.

We can drop the need subconfigure completely in favor of a tighter build
integration, where the sources are listed separately from the build recipes,
so that they may be included directly by upstream projects. This is
similar to the way leveldb build integration works in Core.

Upstream benefits of this approach include:

    Better caching (for ex. ccache and autoconf)
    No need for a slow subconfigure
    No more missing compile flags
    Compile only the objects needed

There are no benefits to Univalue itself that I can think of. These changes
should be a no-op there, and to downstreams as well until they take advantage
of the new sources.mk. Once merged, This Core branch is ready-ish for PR, and
takes advantage of the features added here.

This also removes the option to use an external univalue to avoid similar ABI
issues with mystery binaries.
theuni added a commit to theuni/bitcoin that referenced this pull request Jul 15, 2021
Requires bitcoin-core/univalue-subtree#19 .

This addresses issues like the one in bitcoin#12467, where some of our compiler flags
end up being dropped during the subconfigure of Univalue. Specifically, we're
still using the compiler-default c++ version rather than forcing c++17.

We can drop the need subconfigure completely in favor of a tighter build
integration, where the sources are listed separately from the build recipes,
so that they may be included directly by upstream projects. This is
similar to the way leveldb build integration works in Core.

Core benefits of this approach include:
- Better caching (for ex. ccache and autoconf)
- No need for a slow subconfigure
- Faster autoconf
- No more missing compile flags
- Compile only the objects needed

There are no benefits to Univalue itself that I can think of. These changes
should be a no-op there, and to downstreams as well until they take advantage
of the new sources.mk.

This also removes the option to use an external univalue to avoid similar ABI
issues with mystery binaries.
fanquake pushed a commit to fanquake/bitcoin that referenced this pull request Aug 6, 2021
Requires bitcoin-core/univalue-subtree#19 .

This addresses issues like the one in bitcoin#12467, where some of our compiler flags
end up being dropped during the subconfigure of Univalue. Specifically, we're
still using the compiler-default c++ version rather than forcing c++17.

We can drop the need subconfigure completely in favor of a tighter build
integration, where the sources are listed separately from the build recipes,
so that they may be included directly by upstream projects. This is
similar to the way leveldb build integration works in Core.

Core benefits of this approach include:
- Better caching (for ex. ccache and autoconf)
- No need for a slow subconfigure
- Faster autoconf
- No more missing compile flags
- Compile only the objects needed

There are no benefits to Univalue itself that I can think of. These changes
should be a no-op there, and to downstreams as well until they take advantage
of the new sources.mk.

This also removes the option to use an external univalue to avoid similar ABI
issues with mystery binaries.
@bitcoin bitcoin locked as resolved and limited conversation to collaborators Sep 8, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants