patches/glibc/ports-2.10.1/180-resolv-dynamic.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Wed May 18 23:00:46 2011 +0200 (2011-05-18)
changeset 2467 200836977ce6
permissions -rw-r--r--
config: rename variables that are arrays

Make it explicit that a variable is an array bu the name of the variable.
It will be used later when .config gets munged to allow both multiple
arguments and arguments with spaces at the same time to be passed from the
configuration down to the build scripts.

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@1625
     1
ripped from SuSE
yann@1625
     2
yann@1625
     3
if /etc/resolv.conf is updated, then make sure applications
yann@1625
     4
already running get the updated information.
yann@1625
     5
yann@1625
     6
http://bugs.gentoo.org/177416
yann@1625
     7
yann@1625
     8
diff -durN glibc-2.10.1.orig/resolv/res_libc.c glibc-2.10.1/resolv/res_libc.c
yann@1625
     9
--- glibc-2.10.1.orig/resolv/res_libc.c	2009-02-07 05:27:42.000000000 +0100
yann@1625
    10
+++ glibc-2.10.1/resolv/res_libc.c	2009-11-13 00:49:59.000000000 +0100
yann@1625
    11
@@ -22,6 +22,7 @@
yann@1625
    12
 #include <arpa/nameser.h>
yann@1625
    13
 #include <resolv.h>
yann@1625
    14
 #include <bits/libc-lock.h>
yann@1625
    15
+#include <sys/stat.h>
yann@1625
    16
 
yann@1625
    17
 
yann@1625
    18
 /* The following bit is copied from res_data.c (where it is #ifdef'ed
yann@1625
    19
@@ -95,6 +96,20 @@
yann@1625
    20
 __res_maybe_init (res_state resp, int preinit)
yann@1625
    21
 {
yann@1625
    22
 	if (resp->options & RES_INIT) {
yann@1625
    23
+		static time_t last_mtime, last_check;
yann@1625
    24
+		time_t now;
yann@1625
    25
+		struct stat statbuf;
yann@1625
    26
+		
yann@1625
    27
+		time (&now);
yann@1625
    28
+		if (now != last_check) {
yann@1625
    29
+			last_check = now;
yann@1625
    30
+			if (stat (_PATH_RESCONF, &statbuf) == 0 && last_mtime != statbuf.st_mtime) {
yann@1625
    31
+				last_mtime = statbuf.st_mtime;
yann@1625
    32
+				atomicinclock (lock);
yann@1625
    33
+				atomicinc (__res_initstamp);
yann@1625
    34
+				atomicincunlock (lock);
yann@1625
    35
+			}
yann@1625
    36
+		}
yann@1625
    37
 		if (__res_initstamp != resp->_u._ext.initstamp) {
yann@1625
    38
 			if (resp->nscount > 0)
yann@1625
    39
 				__res_iclose (resp, true);