Package: gcc-15
Severity: wishlist
Tags: forky sid
X-Debbugs-Cc: [email protected], [email protected],
[email protected], [email protected]
User: [email protected]
Usertags: i386
On Thu, 11 Sep 2025 at 14:38:10 +0200, on Bug#1095863, Paul Gevers wrote:
I've been thinking a tiny bit about what I think that "baseline" means
and it seems to align with the ArchitectureSpecificsMemo wiki page
[1]: "indicating the oldest or least capable CPU on which the
architecture can be used". It goes on to say: "The baseline is mostly
defined by the gcc-N package". How I now understand this now is that
normally gcc will provide the setting for most packages to build a
baseline compliant package, but that doesn't exactly mean these
packages build for exactly the baseline (it can be lower). So, with
the acceptance to have rustc/llvm build with SSE2/MMX, we actually
raised the baseline, it was just not reflected in gcc.
Now that the forky development is open, gcc should probably do its
thing to bump its baseline on i386. There was consensus in the tread
ending at [2] to bump the baseline to include SSE2/MMX, and several
remarks were made to make it the same as the current amd64 baseline
(without objections). At this moment, I agree with the latter.
[1] https://wiki.debian.org/ArchitectureSpecificsMemo#Architecture_baselines
[2] https://lists.debian.org/debian-devel/2025/01/msg00034.html
I would like to make this request official: please bump gcc's baseline
for i386 to be at least i686 + MMX + SSE + SSE2. We already announced in
the Debian 13 release notes that the purpose of the i386 port is to be
run on an x86_64 CPU in a chroot or container, or via multiarch or
multilib. Halfway through the Debian 14 cycle seems like enough of a
grace period before really enforcing this.
Given that announcement (and the fact that Ubuntu similarly only
supports a subset of i386 as a multiarch foreign architecture), if it is
possible to make the 32-bit compiler default to the equivalent of
-march=x86-64 (to use the 32-bit ABI with a baseline that is allowed to
use any x86-64-v1-compatible instruction), then I think that would be
the best thing to do.
Or, the default could be -march=pentium4 (a closer equivalent of what
LLVM already did). According to gcc documentation, that assumes the
presence of MMX, SSE, SSE2 and FXSR, all of which are guaranteed to be
available in x86-64-v1 according to the psABI
(https://gitlab.com/x86-psABIs/x86-64-ABI/-/blob/master/x86-64-ABI/low-level-sys-info.tex)
if I'm reading correctly.
Either way, it could also be a good improvement to make -mfpmath=sse the
default, which I believe would make arithmetic on i386 behave the same
way as on amd64 and every other release architecture (64-bit rather than
80-bit intermediate values), removing a frequent source of i386-specific
test failures. That could be a subsequent transition rather than part of
raising the baseline, if preferred.
Thanks,
smcv