2
1
Fork 0
mirror of https://git.savannah.gnu.org/git/gnuboot.git synced 2025-01-12 02:19:15 +01:00
gnuboot/resources/coreboot/fam15h_rdimm/patches
Adrien Bourmault c18e78555d
ressources/coreboot/fam15h*: fix building crossgcc 8.3.0 (fixes #64870)
This commit fixes an error encountered on Trisquel 11 while trying to
build the fam15h coreboot crossgcc 8.3.0:

In file included from /usr/include/signal.h:328,
                 from /usr/include/x86_64-linux-gnu/sys/param.h:28,
                 from ../../gcc-8.3.0/gcc/system.h:298,
                 from ../../gcc-8.3.0/gcc/ada/init.c:65:
../../gcc-8.3.0/gcc/ada/init.c:575:18: error: missing binary operator before token "("
  575 | # if 16 * 1024 < MINSIGSTKSZ
      |                  ^~~~~~~~~~~
make[1]: *** [Makefile:1110 : ada/init.o] Erreur 1

The changes of the GLIBC that removed the MINSKTSZ constant was
introduced only for systems using the Linux kernel, and while the
changelog is recommanding using sysconf to get the value of
`_SC_MINSTKSZ`. The problem is that it does not allow to get the value
in the preprocessor context.

This error has been corrected on upstream GCC by Eric Botcazou <ebotcazou@adacore.com>
but this was not applied on upstream coreboot (even 4.11 branch).
It has been accepted by GCC and the bug report has been set as RESOLVED
FIXED, meaning it solved the bug.

The MINSTKSZ patch is needed for all GCC versions from 8 to 9, since this
commit solved the bug for 9, 10 and later versions. It has been adopted
by OpenSUSE for its GCC 8 package:
https://build.opensuse.org/projects/devel:gcc/packages/gcc8/files/gcc8-ada-MINSTKSZ.patch

Here's the corresponding patch header (in debian's format:
https://dep-team.pages.debian.net/deps/dep3/):
    Origin: upstream, https://gcc.gnu.org/git/gitweb.cgi?p=gcc.git;h=a5a7cdcaa0c29ee547c41d24f495e9694a6fe7f1
    Bug: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=99264
    Bug-GNU Boot: https://savannah.gnu.org/bugs/?64870

The MINSTKSZ patch added by this commit is unmodified from the
OpenSUSE one mentioned above, and the OpenSUSE patch is probably a
backport of the upstream GCC patch as there is not difference in what
it does.

Signed-off-by: Adrien 'neox' Bourmault <neox@gnu.org>
GNUtoo: small formatting of the commit message + last paragraph.
Acked-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
2024-09-09 16:05:14 +02:00
..
0003-Tweak-cmos-defaults-for-KCMA-D8-for-a-little-speed-b.patch libreboot! 2021-05-18 13:56:12 +01:00
0004-Do-not-use-microcode-updates-on-AMD-platforms.patch libreboot! 2021-05-18 13:56:12 +01:00
0006-asus-kgpe-d16-enable-lc_cache_partitioning-and-exper.patch libreboot! 2021-05-18 13:56:12 +01:00
0008-crossgcc-patch-binutils-2.32-for-newer-hostcc.patch coreboot/fam15h: fixing binutils not building properly 2023-08-22 21:14:49 +02:00
0009-fix-crossgcc-acpica-build-on-newer-hostcc.patch coreboot/fam15h: fix crossgcc acpica build on newer hostcc 2023-08-22 21:15:09 +02:00
0010-coreboot-fam15h-use-new-upstream-for-acpica.patch coreboot/default, coreboot/fam15h: use GNU mirror for acpica 2023-08-22 21:14:24 +02:00
0011-gcc-8.3.0_gnat_eh_new.patch coreboot/fam15h: fix for gcc/gnat building 2023-08-22 21:15:00 +02:00
0012-gcc-8.3.0_ada-MINSTKSZ.patch ressources/coreboot/fam15h*: fix building crossgcc 8.3.0 (fixes #64870) 2024-09-09 16:05:14 +02:00