patches/uClibc/0.9.29/200-fix-internal_function-definition.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sat Apr 26 21:31:05 2008 +0000 (2008-04-26)
changeset 454 372b2f397baa
permissions -rw-r--r--
Configure tsocks with a simple heuristic.

Consider the proxy has to be in a 'local' network. It means it is directly
reachable by the local machine, even if the local machine has to hop through
one or more gates to reach the proxy (often the case in enterprise networks
where class A 10.0.0.0/8 is in fact sub-divided into smaller networks, each
one of them in a different location, eg. 10.1.0.0/16 in a place, while
10.2.0.0/16 would be on the other side of the world). Not being in the same
subnet does not mean the proxy is not available.

So we will build a mask with at most high bits set, which defines a network
that has both the local machine and the proxy. Because a machine may have
more than one interface, build a mask for each of them, removing 127.0.0.1
which is added automagically by tsocks, and removing duplicate masks.

If all of this does not work, then it means the local machine can NOT in fact
reach the proxy, which in turn means the user mis-configured something (most
probably a typo...).

/trunk/scripts/crosstool.sh | 61 52 9 0 +++++++++++++++++++++++++++++++++++++++++++--------
1 file changed, 52 insertions(+), 9 deletions(-)
     1 Index: uClibc/libc/sysdeps/linux/i386/bits/uClibc_arch_features.h
     2 ===================================================================
     3 --- uClibc/libc/sysdeps/linux/i386/bits/uClibc_arch_features.h	(revision 18898)
     4 +++ uClibc/libc/sysdeps/linux/i386/bits/uClibc_arch_features.h	(working copy)
     5 @@ -42,6 +42,8 @@
     6  /* define if target supports IEEE signed zero floats */
     7  #define __UCLIBC_HAVE_SIGNED_ZERO__
     8  
     9 +#if defined _LIBC
    10  #define internal_function __attribute__ ((regparm (3), stdcall))
    11 +#endif
    12  
    13  #endif /* _BITS_UCLIBC_ARCH_FEATURES_H */
    14 Index: uClibc/include/libc-symbols.h
    15 ===================================================================
    16 --- uClibc/include/libc-symbols.h	(revision 18898)
    17 +++ uClibc/include/libc-symbols.h	(working copy)
    18 @@ -22,6 +22,16 @@
    19  #ifndef _LIBC_SYMBOLS_H
    20  #define _LIBC_SYMBOLS_H	1
    21  
    22 +/* This is defined for the compilation of all C library code.  features.h
    23 +   tests this to avoid inclusion of stubs.h while compiling the library,
    24 +   before stubs.h has been generated.  Some library code that is shared
    25 +   with other packages also tests this symbol to see if it is being
    26 +   compiled as part of the C library.  We must define this before including
    27 +   config.h, because it makes some definitions conditional on whether libc
    28 +   itself is being compiled, or just some generator program.  */
    29 +#define _LIBC	1
    30 +
    31 +
    32  /* This file's macros are included implicitly in the compilation of every
    33     file in the C library by -imacros.
    34  
    35 @@ -40,16 +50,6 @@
    36  
    37  #include <bits/uClibc_arch_features.h>
    38  
    39 -
    40 -/* This is defined for the compilation of all C library code.  features.h
    41 -   tests this to avoid inclusion of stubs.h while compiling the library,
    42 -   before stubs.h has been generated.  Some library code that is shared
    43 -   with other packages also tests this symbol to see if it is being
    44 -   compiled as part of the C library.  We must define this before including
    45 -   config.h, because it makes some definitions conditional on whether libc
    46 -   itself is being compiled, or just some generator program.  */
    47 -#define _LIBC	1
    48 -
    49  /* Enable declarations of GNU extensions, since we are compiling them.  */
    50  #define _GNU_SOURCE	1
    51