This port provides external GCC toolchains for GCC 13.2.0 for the
aarch64, amd64, armv6, armv7, i386, powerpc, powerpc64, and riscv64
platforms.
Details
Diff Detail
- Repository
- R11 FreeBSD ports repository
- Lint
Lint Skipped - Unit
Tests Skipped - Build Status
Buildable 54398 Build 51288: arc lint + arc unit
Event Timeline
Some feedback, as requested.
devel/freebsd-gcc13/Makefile | ||
---|---|---|
2 | This should use DISTVERSION if possible. | |
15 | Why is the port not supported? Try to give a more meaningful description. | |
92–94 | This could be solved more elegantly. | |
110–132 | This looks like it could also be solved in a more declarative manner without the big .if cascade. | |
138 | Do not silence commands in install targets (cf. § 5.17 Porter's Handbook). | |
devel/freebsd-gcc13/files/patch-i686 | ||
9 | This should probably check if the system was actually built for i486 or be a port option. It is still possible to configure FreeBSD for i486. | |
devel/freebsd-gcc13/pkg-descr | ||
2 | This description sounds a bit outdated. We no longer build base with gcc. Also see if you can make it at least three lines. E.g. mention which languages the port supports. |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 | Commit acd121613431056e253039951f66b062a4104746 for devel/freebsd-gcc12 has more details but not sure there is a better summary than this one line. This type of language is used fairly commonly in IGNORE_FreeBSD_12 already (3 other uses of this phrase, several others are just "not supported < 13.1"). | |
92–94 | I'm not sure that is more readable, especially if we added this for more arches (namely aarch64) in the future. | |
110–132 | It's almost 'PLIST+= ${.CURDIR}/pkg-plist.${TARGETARCH}' but not quite. There are several special cases. | |
devel/freebsd-gcc13/files/patch-i686 | ||
9 | No. We require 64-bit atomics in userland for i386 starting with FreeBSD 11.x. Same is true in clang. This patch is already present in the devel/freebsd-gcc12 port and one I will likely upstream to GCC at some point. | |
devel/freebsd-gcc13/pkg-descr | ||
2 | The sole purpose of this port is to build the base system via CROSS_TOOLCHAIN. That's why it is different than lang/gcc*. For example, it defaults to using the base system libc++ instead of libstdc++ from GCC. |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
110–132 | I have tried to clean this up for the existing ports in D42590 and have similar changes for this port if that review is ok'd. | |
138 | Humm, that rule is newer than the original version of this port. I appreciate its goal, but in this case this isn't installing new files, but removing things that were previously installed. Still, rather simple to remove the silence. |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 | You could write something like “missing support, see acd1216” so an interested developer can find the reason for the lack of support.
Doesn't make it any better. | |
92–94 | Your call. I prefer the declarative style as it's easier to deal with when the special cases pile up. | |
110–132 | Thanks, I have responded to your proposed changes over at the other review. | |
138 | Especially for removals. Imagine you're wondering while a file that is clearly being built and installed doesn't show up in the package. You won't be able to tell from the build log that it's being removed last minute. This can be very frustrating to debug. Just make the commands visible so there's no surprise. | |
devel/freebsd-gcc13/pkg-descr | ||
2 | That sounds reasonable but is not perfectly clear from pkg-descr. Though I can see how it is meant that way. |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 |
Should use 12 chars acd121613431 |
devel/freebsd-gcc13/pkg-descr | ||
---|---|---|
2 | This description is certainly been inherited from several generations of this port (back to devel/powerpc64-gcc). Would this be clearer: GCC, the GNU C/C++ Compiler, customized to build the FreeBSD base system. |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 | Perhaps FreeBSD 12.x cannot be built with this version of GCC? |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 | Only sort of. GCC hardcodes the target version it is building for at compile time unlike clang which accepts -target, so that means if there is a behavior change for a given major version (e.g. requiring 64-bit atomics for x86 for 11+, or when we switched to .init_array by default), you have to build a GCC targeted for that version. Right now these ports use the same target version as the host version, so they only support cross-arch, but technically not cross-version builds. In practice that tends to be good enough most of the time (e.g. there haven't been any target-facing changes in several major versions now, so 13 can build 14, etc.), but it's only fully supported to use the GCC port/package on FreeBSD X to build version X. |
LGTM.
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 | Reasonable and possible worth explaining in more detail, too. It is not obvious that only cross-arch is supported. | |
devel/freebsd-gcc13/files/patch-i686 | ||
9 | The FreeBSD 13 release notes read like you can still build for i486 and then the toolchain will use the same workarounds as before (i.e. “Users who need to run on 486- or 586-class CPUs need to build their own releases.”) |
devel/freebsd-gcc13/Makefile | ||
---|---|---|
15 | Probably it is worth expanding pkg-descr further to clarify this. | |
devel/freebsd-gcc13/files/patch-i686 | ||
9 | Yes, I believe the intent of that is that you would need to use an explicit -march in your CFLAGS (or set CPUTYPE explicitly which does that). Even then you probably have to build with WITHOUT_LLDB to get a build that doesn't fail. And that is true for clang as well, not just if you are using GCC as the external compiler. This patch is merely changing the default -march for the compiler and matches what is in clang here: https://github.com/llvm/llvm-project/blob/main/clang/lib/Driver/ToolChains/Arch/X86.cpp#L111 Actually, it seems for clang the default to i686 is not even conditional on major version, it was just changed for the in-tree clang starting in 11.0 before being merged upstream: https://github.com/llvm/llvm-project/commit/02cfa7530d9e7cfd8ea940dab4173afb7938b831 |