patches/uClibc/0.9.29/130-fix-gethostent_r-failure-retval.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Mon Dec 12 21:41:16 2011 +0200 (2011-12-12)
branch1.13
changeset 2845 0dc9d4931246
parent 108 69407950a2a2
permissions -rw-r--r--
scripts: unset CONFIG_SITE

Some distributions (eg. openSUSE 12.1) systematically export
the CONFIG_SITE environment variable to point to a custom
script setting misc paths for ./configure.

This can, and does, break when cross-compiling for architectures
that are not supported by this script.

The simple workaround is to unset this variable.
NB: buildroot has a similar fix:
http://git.buildroot.org/buildroot/commit/?id=12c9f7dd6dee9c6029b4f9a12d6aac1516911ab4

Reported-by: Trevor Woerner <twoerner@gmail.com>
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 21f4f28e60ec0342133086c9a51e7f0e5b181fb8)
yann@108
     1
diff -ur uClibc-0.9.29/libc/inet/resolv.c uClibc-0.9.29-patched/libc/inet/resolv.c
yann@108
     2
--- uClibc-0.9.29/libc/inet/resolv.c	2007-04-23 12:01:05.000000000 -0500
yann@108
     3
+++ uClibc-0.9.29-patched/libc/inet/resolv.c	2007-05-09 18:05:33.563404419 -0500
yann@108
     4
@@ -1700,7 +1700,7 @@
yann@108
     5
 int gethostent_r(struct hostent *result_buf, char *buf, size_t buflen,
yann@108
     6
 	struct hostent **result, int *h_errnop)
yann@108
     7
 {
yann@108
     8
-    int ret;
yann@108
     9
+    int ret = HOST_NOT_FOUND;
yann@108
    10
 
yann@108
    11
     __UCLIBC_MUTEX_LOCK(mylock);
yann@108
    12
     if (__gethostent_fp == NULL) {