mklibs: handle duplicate symbols properly
authorFelix Fietkau <nbd@openwrt.org>
Mon, 19 Oct 2009 23:26:00 +0000 (23:26 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Mon, 19 Oct 2009 23:26:00 +0000 (23:26 +0000)
SVN-Revision: 18084

tools/mklibs/patches/006-duplicate_syms.patch [new file with mode: 0644]

diff --git a/tools/mklibs/patches/006-duplicate_syms.patch b/tools/mklibs/patches/006-duplicate_syms.patch
new file mode 100644 (file)
index 0000000..3f39ee5
--- /dev/null
@@ -0,0 +1,32 @@
+--- a/src/mklibs.py
++++ b/src/mklibs.py
+@@ -507,7 +507,6 @@ while 1:
+     library_symbols = {}
+     library_symbols_used = {}
+-    symbol_provider = {}
+     # WORKAROUND: Always add libgcc on old-abi arm
+     header = elf_header(find_lib(libraries.copy().pop()))
+@@ -525,17 +524,13 @@ while 1:
+         library_symbols_used[library] = set()
+         for symbol in symbols:
+             for name in symbol.base_names():
+-                if name in symbol_provider:
+-                    debug(DEBUG_SPAM, "duplicate symbol %s in %s and %s" % (symbol, symbol_provider[name], library))
+-                else:
+-                    library_symbols[library][name] = symbol
+-                    symbol_provider[name] = library
++                library_symbols[library][name] = symbol
+     # which symbols are actually used from each lib
+     for name in needed_symbols:
+-        if name in symbol_provider:
+-            lib = symbol_provider[name]
+-            library_symbols_used[lib].add(library_symbols[lib][name])
++        for lib in libraries:
++            if name in library_symbols[lib]:
++                library_symbols_used[lib].add(library_symbols[lib][name])
+     # reduce libraries
+     for library in libraries: