 9437012b9e
			
		
	
	9437012b9e
	
	
	
		
			
			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>
		
	
		
			
				
	
	
		
			64 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| --- a/src/mklibs
 | |
| +++ b/src/mklibs
 | |
| @@ -173,9 +173,10 @@ def undefined_symbols(obj):
 | |
|      return result
 | |
|  
 | |
|  class ProvidedSymbol(Symbol):
 | |
| -    def __init__(self, name, version, library, default_version):
 | |
| +    def __init__(self, name, version, library, default_version, weak):
 | |
|          super(ProvidedSymbol, self).__init__(name, version, library)
 | |
|          self.default_version = default_version
 | |
| +        self.weak = weak
 | |
|  
 | |
|      def base_names(self):
 | |
|          ret = []
 | |
| @@ -216,11 +217,15 @@ def provided_symbols(obj):
 | |
|          if version_string.lower() not in ('base', 'none'):
 | |
|              version = version_string
 | |
|  
 | |
| +        weak = False
 | |
| +        if weak_string.lower() == 'true':
 | |
| +            weak = True
 | |
| +
 | |
|          default_version = False
 | |
|          if default_version_string.lower() == 'true':
 | |
|              default_version = True
 | |
|  
 | |
| -        result.append(ProvidedSymbol(name, version, library, default_version))
 | |
| +        result.append(ProvidedSymbol(name, version, library, default_version, weak))
 | |
|  
 | |
|      return result
 | |
|      
 | |
| @@ -509,6 +514,9 @@ while 1:
 | |
|              debug(DEBUG_SPAM, "present_symbols adding %s" % symbol)
 | |
|              names = symbol.base_names()
 | |
|              for name in names:
 | |
| +                if name in present_symbols:
 | |
| +                    if symbol.library != present_symbols[name].library:
 | |
| +                        needed_symbols[name] = UndefinedSymbol(name, True, symbol.version, symbol.library)
 | |
|                  present_symbols[name] = symbol
 | |
|  
 | |
|      # are we finished?
 | |
| @@ -600,12 +608,16 @@ while 1:
 | |
|                  # may segfault in ptmalloc_init due to undefined weak reference
 | |
|                  extra_pre_obj.append(sysroot + libc_extras_dir + "/soinit.o")
 | |
|                  extra_post_obj.append(sysroot + libc_extras_dir + "/sofini.o")
 | |
| -                symbols.add(ProvidedSymbol('__dso_handle', None, None, True))
 | |
| +                symbols.add(ProvidedSymbol('__dso_handle', None, None, True, True))
 | |
|  
 | |
| -            if soname in ("libc.so.0"):
 | |
| -                symbols.add(ProvidedSymbol('__uClibc_init', None, None, True))
 | |
| -                symbols.add(ProvidedSymbol('__uClibc_fini', None, None, True))
 | |
| -                extra_flags.append("-Wl,-init,__uClibc_init")
 | |
| +            if soname == "libc.so.0":
 | |
| +                symbols.add(ProvidedSymbol('__uClibc_init', None, None, True, True))
 | |
| +                symbols.add(ProvidedSymbol('__uClibc_fini', None, None, True, True))
 | |
| +                extra_pre_obj.append("-Wl,-init,__uClibc_init")
 | |
| +
 | |
| +            if soname == "libpthread.so.0":
 | |
| +                symbols.add(ProvidedSymbol('__pthread_initialize_minimal_internal', None, None, True, True))
 | |
| +                extra_flags.append("-Wl,-z,nodelete,-z,initfirst,-init=__pthread_initialize_minimal_internal")
 | |
|  
 | |
|              map_file = find_pic_map(library)
 | |
|              if map_file:
 |