patches/glibc/ports-2.10.1/180-resolv-dynamic.patch
author "Yann E. MORIN" <yann.morin.1998@free.fr>
Mon Feb 13 21:47:25 2012 +0100 (2012-02-13)
changeset 2883 cea814c9932a
permissions -rw-r--r--
libc/glibc: do not consume parameters when parsing them

Currently, there are two constructs used to parse arguments in
glibc backends, one that consumes args as they are parsed, and
one that does not.

Always use the construct that does not eat args as they are parsed.

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