mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-31 05:54:26 -04:00 
			
		
		
		
	Since the switch to Python 3 build fails if CONFIG_USE_MKLIBS is set
("Strip unnecessary functions from libraries" in menuconfig) as
mklibs hasn't been converted to run on Python 3.
 * update to most recent upstream version which brings some
   reproducibility fixes
 * converted to Python 3 using 2to3
 * fixed mixed tab/spaces indentation
 * fixed use of string.* functions
 * some more minor fixes to make Python 3 happy
Fixes commit 19938c8de7 ("build: switch to Python 3")
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
		
	
			
		
			
				
	
	
		
			36 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| --- a/src/mklibs
 | |
| +++ b/src/mklibs
 | |
| @@ -540,7 +540,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()))
 | |
| @@ -558,20 +557,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 not name in symbol_provider:
 | |
| -            if not needed_symbols[name].weak:
 | |
| -                print "WARNING: Unresolvable symbol %s" % name
 | |
| -        else:
 | |
| -            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 sorted(libraries):
 |