patches/glibc/ports-2.10.1/630-mips_shn_undef-hack.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Thu May 26 22:51:03 2011 +0200 (2011-05-26)
changeset 2481 30644208c955
permissions -rw-r--r--
configure: add possibility to set arbitrary variable in check_for

If check_for is able to find the required prog/inc/lib, allow it to
set an arbitrary variable to 'y'. This variable is then pushed down
to the kconfig definition.

For example:
has_or_abort prog=foobar kconfig=has_foobar

If foobar is available, it yields a kconfig variable defaulting to y:
config CONFIGURE_has_foobar
bool
default y

If foobar is missing, it yields a kconfig variable defaulting to n:
config CONFIGURE_has_foobar
bool

Thus it is possible to depends on that variabel to show/hide options:
config SOME_FEATURE
bool
prompt "Some feature"
depends on CONFIGURE_has_foobar

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
     1 	Hack from Debian to hopefully get sandbox working on mips
     2 
     3 <`Kumba> ths: given the SHN_UNDEF thing is a hack, what's the preferred solution?
     4 <ths> For fakeroot the simplest trigger is "fakeroot file /bin/ls".
     5 <ths> `Kumba: I haven't found a better one yet.
     6 <ths> Probably marker symbols around the stub section, and then exclude it from the link map.
     7 <ths> This needs a ld change.
     8 
     9 diff -durN glibc-2.10.1.orig/elf/do-lookup.h glibc-2.10.1/elf/do-lookup.h
    10 --- glibc-2.10.1.orig/elf/do-lookup.h	2009-03-30 23:14:32.000000000 +0200
    11 +++ glibc-2.10.1/elf/do-lookup.h	2009-11-13 00:51:36.000000000 +0100
    12 @@ -248,6 +248,12 @@
    13  		}
    14  	      /* FALLTHROUGH */
    15  	    case STB_GLOBAL:
    16 +#ifdef __mips__
    17 +	      /* HACK: MIPS marks its lazy evaluation stubs with SHN_UNDEF
    18 +		 symbols, we skip them. */
    19 +	      if (sym->st_shndx == SHN_UNDEF)
    20 +		break;
    21 +#endif
    22  	      /* Global definition.  Just what we need.  */
    23  	      result->s = sym;
    24  	      result->m = (struct link_map *) map;