fanquake
commented at 8:47 am on May 31, 2018:
member
Opening an issue after some recent IRC discussion about moving to requiring C++14.
GCC:
C++14 is available from GCC 5, and is the default mode in GCC 6.1.
“The default mode for C++ is now -std=gnu++14 instead of -std=gnu++98.”.
We currently require GCC 4.8+.
Clang:
C++14 is available from Clang 3.4+.
We currently require Clang 3.3+.
Usage:
We currently already use shared mutex.
fanquake added the label
Brainstorming
on May 31, 2018
fanquake added the label
Build system
on May 31, 2018
MarcoFalke added this to the milestone 0.18.0
on May 31, 2018
MarcoFalke
commented at 9:36 am on May 31, 2018:
member
I think we should wait for trusty to be EOL, which probably happens around the day we release 0.18.0
luke-jr
commented at 12:18 pm on May 31, 2018:
member
Latest RHEL is only GCC 4.8.x
MarcoFalke
commented at 7:37 pm on May 31, 2018:
member
Also should check OpenSuse and CentOS.
According to today’s irc chat debian oldstable will only support C++14 in time for our ~0.19.0 release:
02019-03-011-----------
2- Split off `0.18` branch from `master`
The pull request itself can be prepared and reviewed in advance, of course.
practicalswift
commented at 8:34 pm on December 10, 2018:
contributor
@MarcoFalke Excellent news! Thanks for the quick reply!
MarcoFalke added the label
Up for grabs
on Jan 25, 2019
MarcoFalke
commented at 2:31 am on January 25, 2019:
member
This is now up for grabs. The previous bump was done in “build: Enable C++11 in build, require C++11 compiler” #7165
gmaxwell
commented at 8:06 am on January 26, 2019:
contributor
The current released version of RHEL is still on GCC 4.8, and even when things are released we can’t expect users to be instantly upgraded. I’m somewhat concerned that we’re going to block the next softfork’s activation the way we did with segwit by mandating a new OS in the release of or before the softfork and then end up with mining pools unwilling to upgrade for six months because it requires a whole new OS.
JeremyRubin
commented at 9:50 pm on January 26, 2019:
contributor
Is there a problem running a binary compiled with c++14 on a machine that only has a c++11 compiler? The RHEL OS requirement would purely be for building Core, which seems unlikely to be a blocking factor for adopting a soft fork? Unless there is something I’m missing…
luke-jr
commented at 10:10 pm on January 26, 2019:
member
Usually binaries only run on the system they’re built on.
gmaxwell
commented at 10:22 pm on January 26, 2019:
contributor
@JeremyRubin Miners routinely modify their software and we encourage them to do so (at least in various sensible ways). If you can’t compile you can’t run your modifications. Also, and perhaps more importantly, critical fixes are always first available as source code.
Before we actually experienced the issue I would have regarded the concern as largely hypothetical, it was an excusable mistake. I don’t see why we shouldn’t learn from that mistake…
Rapidly advancing the required language version has costs. These costs could be justified with commiserate benefits, but I’m not aware of a case being made here.
JeremyRubin
commented at 10:37 pm on January 26, 2019:
contributor
Thanks for the information on that @gmaxwell. I was unaware that there was an issue with that during SegWit – do you have any link to discussion on this? I was unable to find it in my bitcoin-dev email archives, just this article https://www.nasdaq.com/article/where-bitcoin-mining-pools-stand-on-segregated-witness-cm713991 / tweet https://twitter.com/satofishi/status/843910700124717058@luke-jr I know that’s generally true (e.g., Linux, Windows, and OSX). But I figured for Bitcoin the compatibility is sufficient across most linux distributions so as not to require recompilation per-distro. Perhaps it depends on what kinds of changes miners are compiling in…
anyways, I’m indifferent on if to upgrade to 14 or not (the changes in 14 are relatively minor and low advantage compared to say, 17). Just wanted to learn more about the practical issue.
luke-jr
commented at 10:43 pm on January 26, 2019:
member
There is basically no compatibility across Linux distributions, even different versions of the same distro are likely to have issues sometimes.
And despite our efforts to build a hacky gitian static binary that is supposed to run everywhere, in practice even that seems to be a failure (I can’t run them!). In any case, the gitian process currently includes a significant amount of trust, and people shouldn’t be required to use its binaries.
MarcoFalke referenced this in commit
d6e700e40f
on Jan 28, 2019
MarcoFalke removed this from the milestone 0.19.0
on Feb 11, 2019
MarcoFalke added this to the milestone Future
on Feb 11, 2019
MarcoFalke
commented at 9:21 pm on February 11, 2019:
member
Moved to “Future” due to concerns that this will break builds on currently supported platforms.
ysangkok
commented at 9:16 pm on September 24, 2019:
none
The current released version of RHEL is still on GCC 4.8, and even when things are released we can’t expect users to be instantly upgraded.
Just want to note that RHEL 8 (with GCC 8.2) has been out for half a year now. And Ubuntu 18.04 has gcc-8 in universe.
Which distributions are most popular with miners?
MarcoFalke
commented at 10:26 pm on September 24, 2019:
member
Some might be using CentOS 7
ajtowns
commented at 6:56 am on September 25, 2019:
member
Some might be using CentOS 7
Red Hat has a devtoolset software collection that provides a new version of gcc and such for either RHEL or CentOS. I get gcc 8.3.1 on CentOS 7 if I run:
0# yum install centos-release-scl1# yum install devtoolset-82# scl enable devtoolset-8 bash3# gcc --version | head -n14gcc (GCC) 8.3.120190311 (Red Hat 8.3.1-3)
5# exit6# gcc --version | head -n17gcc (GCC) 4.8.520150623 (Red Hat 4.8.5-39)
Doing yum install boost-devel libevent-devel openssl-devel lets me build with --disable-wallet in that environment. I think that should let you get a newer compiler on RHEL/CentOS 6 as well? Looks like clang is available too.
MarcoFalke
commented at 12:58 pm on October 1, 2019:
member
CentOS 8 was released a few days ago, so it seems ok to move forward with this for 0.20.0?
practicalswift
commented at 1:40 pm on October 1, 2019:
contributor
This is a metadata mirror of the GitHub repository
bitcoin/bitcoin.
This site is not affiliated with GitHub.
Content is generated from a GitHub metadata backup.
generated: 2025-01-22 03:12 UTC
This site is hosted by @0xB10C More mirrored repositories can be found on mirror.b10c.me