From b1becd0ed593005edf82b1aa3a596443effd47bf Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Wed, 1 May 2002 11:36:13 +0000 Subject: [PATCH] Jacky Lam's fix to make the realloc() of the hostent data work properly even when the realloc() actually gets a new memory block --- lib/hostip.c | 36 ++++++++++++++++++++++++++++++------ 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/lib/hostip.c b/lib/hostip.c index f84e26e..6591354 100644 --- a/lib/hostip.c +++ b/lib/hostip.c @@ -453,14 +453,30 @@ static char *MakeIP(unsigned long num,char *addr, int addr_len) return (addr); } -/* The original code to this function was once stolen from the Dancer source - code, written by Bjorn Reese, it has since been patched and modified - considerably. */ - #ifndef INADDR_NONE #define INADDR_NONE (in_addr_t) ~0 #endif +static void hostcache_fixoffset(struct hostent *h, int offset) +{ + int i=0; + h->h_name=(char *)((int)h->h_name+offset); + h->h_aliases=(char **)((int)h->h_aliases+offset); + while(h->h_aliases[i]) { + h->h_aliases[i]=(char *)((int)h->h_aliases[i]+offset); + i++; + } + h->h_addr_list=(char **)((int)h->h_addr_list+offset); + i=0; + while(h->h_addr_list[i]) { + h->h_addr_list[i]=(char *)((int)h->h_addr_list[i]+offset); + i++; + } +} + +/* The original code to this function was once stolen from the Dancer source + code, written by Bjorn Reese, it has since been patched and modified + considerably. */ Curl_addrinfo *Curl_getaddrinfo(struct SessionHandle *data, char *hostname, int port, @@ -535,7 +551,11 @@ Curl_addrinfo *Curl_getaddrinfo(struct SessionHandle *data, #endif if(h) { - buf=(int *)realloc(buf, step_size); + int offset; + h=(struct hostent *)realloc(buf, step_size); + offset=(int)h-(int)buf; + hostcache_fixoffset(h, offset); + buf=(int *)h; *bufp=(char *)buf; } else @@ -555,7 +575,11 @@ Curl_addrinfo *Curl_getaddrinfo(struct SessionHandle *data, infof(data, "gethostbyname_r() uses %d bytes\n", step_size); #endif if(!res) { - buf=(int *)realloc(buf, step_size); + int offset; + h=(struct hostent *)realloc(buf, step_size); + offset=(int)h-(int)buf; + hostcache_fixoffset(h, offset); + buf=(int *)h; *bufp=(char *)buf; } else -- 2.7.4