Bugs item #3112579, was opened at 2010-11-19 15:27
Message generated for change (Tracker Item Submitted) made by lesch
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=100976&aid=3112579&group_id=976
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: libcurl
Group: wrong behaviour
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: NotGeneratedYet (lesch)
Assigned to: Daniel Stenberg (bagder)
Summary: Premature timeout in Curl_wait_for_resolv
Initial Comment:
File curl-7.21.2\lib\hostares.c function Curl_wait_for_resolv line 268
This function uses the timeout variable as remaining time.
Every round, timeout is decremented using time difference between waitperform() calls:
timeout -= timediff?timediff:1;
But, timediff is calculated incorrectly. timediff is elapsed time not difference time:
timediff = Curl_tvdiff(Curl_tvnow(), now); /* spent time */
So, the timeout variable may end much earlier than the real time.
Proposed solution:
Replace:
timediff = Curl_tvdiff(Curl_tvnow(), now); /* spent time */
timeout -= timediff?timediff:1; /* always deduct at least 1 */
By:
struct timeval nowNew = Curl_tvnow();
timediff = Curl_tvdiff(nowNew, now); /* difference between waitperform() calls */
now = nowNew;
timeout -= timediff?timediff:1; /* always deduct at least 1 */
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=100976&aid=3112579&group_id=976
Received on 2010-11-19