[llvm-dev] [cfe-dev] [RFC] Raise the minimum Visual Studio version to VS2019

Renato Golin via llvm-dev llvm-dev at lists.llvm.org
Wed Dec 1 04:50:14 PST 2021


On Wed, 1 Dec 2021 at 12:20, Aaron Ballman via llvm-dev <
llvm-dev at lists.llvm.org> wrote:

> That said, I'm also happy to see our GCC and Clang requirements
> updated if that's reasonable to do so. GCC 5.1 was released April 2015
> and Clang 3.5 was released Sept 2014, so these are not particularly
> new toolchains.


In the past, we have used availability in stable OSs as merit for upgrading
the minimum.

On *nix distros, release support usually ~2 years, give or take.

These are all old releases:
(Source: https://pkgs.org/)

Ubuntu 18.04 has clang 6 and gcc 7.3
Ubuntu 20.04 has clang 10 and gcc 9.3
Fedora 33 has clang 11 and gcc 9.2
Debian Stretch has clang 7 and gcc 6.1
Centos 8 has clang 12 gcc 8.5
FreeBSD 12 has clang 11 gcc 6.5 (and 9.3)
OpenSUSE 15 has clang 9 and gcc 7.5

Minimum clang and gcc is around  6.x.

I'm not sure on Mac, but I assume they have a more aggressive goals for the
system compiler than many of the Linux/BSD distros and probably have a
newer clang than most of them (at the same age).

With clang being the system compiler for Mac and BSD, getting a newer gcc
would be just a matter of looking at ports-equivalent.

On Windows, neither clang nor gcc are the system compiler, so not hard to
get the latest version.

Frankly, my biggest driver is the ability to
> eventually use C++17 in the code base. I believe the most responsible
> way for us to do that is to upgrade compilers before we switch default
> language modes so that we're not changing too much at once, which
> makes regressions easier to track down and report. However, getting a
> newer toolchain by itself is a good end result (we know we're doing
> the upgrades at some point and smaller version deltas are often less
> risky than larger version deltas).


+1 to all that.

Much of C++17 support is in GCC 6, but GCC 7 is a safer bet.
(Source: https://gcc.gnu.org/projects/cxx-status.html#cxx17)

Clang 5, 6 and 7 have varying degrees of C++17 support, with clang 8 being
the last that added something substantial.
(Source: https://clang.llvm.org/cxx_status.html#cxx17)

With that in mind, and the fact that *nix distros have ways to get a newer
compiler if needed (ports/PPA), I'd say:

Clang/GCC 6 is a safe minimum, but Clang/GCC 7 is a better move, if we
don't want to change it too soon.

cheers,
--renato
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20211201/b2e6ad82/attachment.html>


More information about the llvm-dev mailing list