From b49e4c689c4dc8e9c8da5b8f56d7ddf59e485d3b Mon Sep 17 00:00:00 2001 From: Hans-Christian Noren Egtvedt Date: Tue, 22 Apr 2025 14:41:19 +0200 Subject: binutils: add version 2.44 https://lists.gnu.org/archive/html/info-gnu/2025-02/msg00001.html Add the new version rebasing the patches we carry on top. Drop patches to gold, since this linker has been removed from upstream. Add a new Kconfig entry that removes visibility of enabling gold linker when selecting binutils version >= 2.44. Signed-off-by: Hans-Christian Noren Egtvedt --- packages/binutils/2.44/0003-Fix-darwin-build.patch | 46 ++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 packages/binutils/2.44/0003-Fix-darwin-build.patch (limited to 'packages/binutils/2.44/0003-Fix-darwin-build.patch') diff --git a/packages/binutils/2.44/0003-Fix-darwin-build.patch b/packages/binutils/2.44/0003-Fix-darwin-build.patch new file mode 100644 index 00000000..5f6cc8d2 --- /dev/null +++ b/packages/binutils/2.44/0003-Fix-darwin-build.patch @@ -0,0 +1,46 @@ +From caeb8d1403fa6ce3334ac8527bc89d3103b3c604 Mon Sep 17 00:00:00 2001 +From: Andrew Hsieh +Date: Wed, 18 Mar 2015 10:57:24 +0800 +Subject: [PATCH 5/8] Fix darwin build + +1. In Drawin PTHREAD_ONCE_INIT is {0x30B1BCBA, {0}} and the GCC < 4.4 + doesn't support ended initializer list +2. wcsncasecmp doesn't exist in MacSDK10.6.x + +Change-Id: I69204a72f853f5263dffedc448379d75ed4eca2e +--- + bfd/peXXigen.c | 22 ++++++++++++++++++++++ + gold/gold-threads.cc | 15 ++++++++++++--- + 2 files changed, 34 insertions(+), 3 deletions(-) + +--- a/bfd/peXXigen.c ++++ b/bfd/peXXigen.c +@@ -3681,6 +3681,28 @@ u16_mbtouc (wint_t * puc, const unsigned + } + #endif /* not Cygwin/Mingw */ + ++#if defined __APPLE__ && __DARWIN_C_LEVEL < 200809L ++/* wcsncasecmp isn't always defined in Mac SDK */ ++static int ++wcsncasecmp(const wchar_t *s1, const wchar_t *s2, size_t n) ++{ ++ wchar_t c1, c2; ++ ++ if (n == 0) ++ return (0); ++ for (; *s1; s1++, s2++) ++ { ++ c1 = towlower(*s1); ++ c2 = towlower(*s2); ++ if (c1 != c2) ++ return ((int)c1 - c2); ++ if (--n == 0) ++ return (0); ++ } ++ return (-*s2); ++} ++#endif ++ + /* Perform a comparison of two entries. */ + static signed int + rsrc_cmp (bool is_name, rsrc_entry * a, rsrc_entry * b) -- cgit v1.2.3