From 73384dd1ff9d14bf9f4509bca0c707efb6f26c5e Mon Sep 17 00:00:00 2001
From: Felix Fietkau <nbd@openwrt.org>
Date: Tue, 17 Nov 2009 04:36:07 +0000
Subject: [PATCH] mklibs: fix missing __pack_f symbol in uclibc after relink

SVN-Revision: 18438
---
 .../patches/009-uclibc_libgcc_link.patch      | 27 +++++++++++++++++++
 1 file changed, 27 insertions(+)
 create mode 100644 tools/mklibs/patches/009-uclibc_libgcc_link.patch

diff --git a/tools/mklibs/patches/009-uclibc_libgcc_link.patch b/tools/mklibs/patches/009-uclibc_libgcc_link.patch
new file mode 100644
index 0000000000..2312d6a2c5
--- /dev/null
+++ b/tools/mklibs/patches/009-uclibc_libgcc_link.patch
@@ -0,0 +1,27 @@
+--- a/src/mklibs.py
++++ b/src/mklibs.py
+@@ -560,6 +560,7 @@ while 1:
+             extra_flags = []
+             extra_pre_obj = []
+             extra_post_obj = []
++            libgcc_link = "-lgcc"
+ 
+             symbols.update(library_symbols_used[library])
+ 
+@@ -575,6 +576,7 @@ while 1:
+                 symbols.add(ProvidedSymbol('__uClibc_init', None, None, True))
+                 symbols.add(ProvidedSymbol('__uClibc_fini', None, None, True))
+                 extra_flags.append("-Wl,-init,__uClibc_init")
++                libgcc_link = "-lgcc_s_pic"
+ 
+             map_file = find_pic_map(library)
+             if map_file:
+@@ -590,7 +592,7 @@ while 1:
+             cmd.append(pic_file)
+             cmd.extend(extra_post_obj)
+             cmd.extend(extra_flags)
+-            cmd.append("-lgcc")
++            cmd.append(libgcc_link)
+             cmd.extend(["-L%s" % a for a in [dest_path] + [sysroot + b for b in lib_path if sysroot == "" or b not in ("/" + libdir + "/", "/usr/" + libdir + "/")]])
+             cmd.append(library_depends_gcc_libnames(so_file, soname))
+             command(target + "gcc", *cmd)
-- 
2.30.2