From a7e04cac78ac0ff3475aa7983183d33e8abb681f Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Sun, 15 Feb 2004 16:57:53 +0000 Subject: Mark the dns entry 'inuse' properly even when used from the cache. This seems to correct some host cache screw-ups I could reproduce. --- lib/hostip.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/lib/hostip.c b/lib/hostip.c index 3e2196120..f1583eaed 100644 --- a/lib/hostip.c +++ b/lib/hostip.c @@ -191,7 +191,7 @@ hostcache_prune(curl_hash *hostcache, int cache_timeout, int now) user.cache_timeout = cache_timeout; user.now = now; - + Curl_hash_clean_with_criterium(hostcache, (void *) &user, hostcache_timestamp_remove); @@ -367,8 +367,10 @@ int Curl_resolv(struct connectdata *conn, rc = 0; } } - else + else { + dns->inuse++; /* we use it! */ rc = 0; + } *entry = dns; @@ -382,9 +384,15 @@ void Curl_resolv_unlock(struct SessionHandle *data, struct Curl_dns_entry *dns) dns->inuse--; +#ifdef CURLDEBUG + if(dns->inuse < 0) { + infof(data, "Interal host cache screw-up!"); + *(char **)0=NULL; + } +#endif + if(data->share) Curl_share_unlock(data, CURL_LOCK_DATA_DNS); - } /* -- cgit v1.2.3