guix_mirror_bot pushed a commit to branch master
in repository guix.
commit 129ff35366c866f0bf60cd2a291ce352bc5e936f
Author: Ricardo Wurmus <[email protected]>
AuthorDate: Mon Mar 2 20:27:13 2026 +0100
gnu: make-propeller-gcc-4: Build with GCC 5.
* gnu/packages/patches/gcc-4.6-gnu-inline.patch: Remove file.
* gnu/local.mk (dist_patch_DATA): Remove it.
* gnu/packages/embedded.scm (make-propeller-gcc-4)[source]: Remove patch.
[arguments]: Remove 'pre-x86-configure phase.
[native-inputs]: Replace gcc-4.9 with gcc-5.
Change-Id: Ifb4b00952edc9053e7496ffe33f8beacd34e11ca
---
gnu/local.mk | 1 -
gnu/packages/embedded.scm | 4 +-
gnu/packages/patches/gcc-4.6-gnu-inline.patch | 65 ---------------------------
3 files changed, 2 insertions(+), 68 deletions(-)
diff --git a/gnu/local.mk b/gnu/local.mk
index 6696ee44ee..59de6a1649 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -1382,7 +1382,6 @@ dist_patch_DATA =
\
%D%/packages/patches/gcc-libvtv-runpath.patch \
%D%/packages/patches/gcc-strmov-store-file-names.patch \
%D%/packages/patches/gcc-4-compile-with-gcc-5.patch \
- %D%/packages/patches/gcc-4.6-gnu-inline.patch \
%D%/packages/patches/gcc-4.9.3-mingw-gthr-default.patch \
%D%/packages/patches/gcc-5-hurd.patch \
%D%/packages/patches/gcc-5.0-libvtv-runpath.patch \
diff --git a/gnu/packages/embedded.scm b/gnu/packages/embedded.scm
index f5fa70c75d..3ec68e78d0 100644
--- a/gnu/packages/embedded.scm
+++ b/gnu/packages/embedded.scm
@@ -1147,17 +1147,17 @@ with a layered architecture of JTAG interface and TAP
support.")
(append
(origin-patches (package-source gcc-base))
(search-patches
- "gcc-4.6-gnu-inline.patch"
"gcc-cross-environment-variables.patch")))))
(arguments
(substitute-keyword-arguments (package-arguments xgcc)
((#:phases phases)
#~(modify-phases #$phases
+ (delete 'pre-x86-configure)
(add-after 'unpack 'chdir
(lambda _ (chdir "gcc")))))))
(native-inputs
(modify-inputs (package-native-inputs xgcc)
- (prepend gcc-4.9)))
+ (prepend gcc-5)))
(home-page "https://github.com/parallaxinc/propgcc")
(supported-systems (delete "aarch64-linux" %supported-systems))))))
diff --git a/gnu/packages/patches/gcc-4.6-gnu-inline.patch
b/gnu/packages/patches/gcc-4.6-gnu-inline.patch
deleted file mode 100644
index 710d358a8b..0000000000
--- a/gnu/packages/patches/gcc-4.6-gnu-inline.patch
+++ /dev/null
@@ -1,65 +0,0 @@
-This patch was taken from
https://gcc.gnu.org/ml/gcc-patches/2015-08/msg00375.html.
-It is used by propeller-gcc-4.
-
-Since the 3.0.3 release of gperf (made in May 2007), the generated func
-has had the gnu_inline attribute applied to it. The gcc source however
-has not been updated to include that which has lead to a mismatch.
-
-In practice, this hasn't been an issue for two reasons:
-(1) Before gcc-5, the default standard was (gnu) C89, and gcc does not
-warn or throw an error in this mode.
-(2) Starting with gcc-4.8, the compiler driver used to build gcc was
-changed to C++, and g++ does not warn or throw an error in this mode.
-
-This error does show up though when using gcc-5 to build gcc-4.7 or
-older as then the default is (gnu) C11 and the C compiler driver is
-used. That failure looks like:
-In file included from .../gcc-4.7.4/gcc/cp/except.c:990:0:
-cfns.gperf: At top level:
-cfns.gperf:101:1: error: 'gnu_inline' attribute present on 'libc_name_p'
-cfns.gperf:26:14: error: but not here
-
-Whether the compiler should always emit this error regardless of the
-active standard or compiler driver is debatable (I think it should be
-consistent -- either always do it or never do it).
-
-2015-08-06 Mike Frysinger <[email protected]>
-
- * cfns.gperf [__GNUC__, __GNUC_STDC_INLINE__]: Apply the
- __gnu_inline__ attribute.
- * cfns.h: Regenerated.
----
- gcc/cp/cfns.gperf | 3 +++
- gcc/cp/cfns.h | 3 +++
- 2 files changed, 6 insertions(+)
-
-diff --git a/gcc/cp/cfns.gperf b/gcc/cp/cfns.gperf
-index 68acd3d..953262f 100644
---- a/gcc/cp/cfns.gperf
-+++ b/gcc/cp/cfns.gperf
-@@ -22,6 +22,9 @@ __inline
- static unsigned int hash (const char *, unsigned int);
- #ifdef __GNUC__
- __inline
-+#ifdef __GNUC_STDC_INLINE__
-+__attribute__ ((__gnu_inline__))
-+#endif
- #endif
- const char * libc_name_p (const char *, unsigned int);
- %}
-diff --git a/gcc/cp/cfns.h b/gcc/cp/cfns.h
-index 1c6665d..6d00c0e 100644
---- a/gcc/cp/cfns.h
-+++ b/gcc/cp/cfns.h
-@@ -53,6 +53,9 @@ __inline
- static unsigned int hash (const char *, unsigned int);
- #ifdef __GNUC__
- __inline
-+#ifdef __GNUC_STDC_INLINE__
-+__attribute__ ((__gnu_inline__))
-+#endif
- #endif
- const char * libc_name_p (const char *, unsigned int);
- /* maximum key range = 391, duplicates = 0 */
---
-2.4.4