Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

time: fix type conversions and compiler warnings #1499

Closed
wants to merge 1 commit into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 7 additions & 3 deletions lib/asyn-ares.c
Original file line number Diff line number Diff line change
Expand Up @@ -373,7 +373,6 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn,
/* Wait for the name resolve query to complete. */
while(!result) {
struct timeval *tvp, tv, store;
long timediff;
int itimeout;
int timeout_ms;

Expand Down Expand Up @@ -402,8 +401,13 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn,
result = CURLE_ABORTED_BY_CALLBACK;
else {
struct timeval now2 = Curl_tvnow();
timediff = Curl_tvdiff(now2, now); /* spent time */
timeout -= timediff?timediff:1; /* always deduct at least 1 */
time_t timediff = Curl_tvdiff(now2, now); /* spent time */
if(timediff <= 0)
timeout -= 1; /* always deduct at least 1 */
else if(timediff > timeout)
timeout = -1;
else
timeout -= (long)timediff;
now = now2; /* for next loop */
}
if(timeout < 0)
Expand Down
12 changes: 9 additions & 3 deletions lib/easy.c
Original file line number Diff line number Diff line change
Expand Up @@ -615,12 +615,18 @@ static CURLcode wait_or_timeout(struct Curl_multi *multi, struct events *ev)
}
}

if(!ev->msbump)
if(!ev->msbump) {
/* If nothing updated the timeout, we decrease it by the spent time.
* If it was updated, it has the new timeout time stored already.
*/
ev->ms += (long)curlx_tvdiff(after, before);

time_t timediff = curlx_tvdiff(after, before);
if(timediff > 0) {
if(timediff > ev->ms)
ev->ms = 0;
else
ev->ms -= (long)timediff;
}
}
}
else
return CURLE_RECV_ERROR;
Expand Down
7 changes: 4 additions & 3 deletions lib/hostip.c
Original file line number Diff line number Diff line change
Expand Up @@ -596,7 +596,7 @@ int Curl_resolv_timeout(struct connectdata *conn,
/* Ignore the timeout when signals are disabled */
timeout = 0;
else
timeout = timeoutms;
timeout = (timeoutms > LONG_MAX) ? LONG_MAX : (long)timeoutms;

if(!timeout)
/* USE_ALARM_TIMEOUT defined, but no timeout actually requested */
Expand Down Expand Up @@ -688,10 +688,11 @@ int Curl_resolv_timeout(struct connectdata *conn,
the time we spent until now! */
if(prev_alarm) {
/* there was an alarm() set before us, now put it back */
unsigned long elapsed_ms = Curl_tvdiff(Curl_tvnow(), conn->created);
unsigned long elapsed_secs = (unsigned long) (Curl_tvdiff(Curl_tvnow(),
conn->created) / 1000);

/* the alarm period is counted in even number of seconds */
unsigned long alarm_set = prev_alarm - elapsed_ms/1000;
unsigned long alarm_set = prev_alarm - elapsed_secs;

if(!alarm_set ||
((alarm_set >= 0x80000000) && (prev_alarm < 0x80000000)) ) {
Expand Down
6 changes: 0 additions & 6 deletions lib/timeval.c
Original file line number Diff line number Diff line change
Expand Up @@ -141,9 +141,3 @@ double curlx_tvdiff_secs(struct timeval newer, struct timeval older)
(double)(newer.tv_usec-older.tv_usec)/1000000.0;
return (double)(newer.tv_usec-older.tv_usec)/1000000.0;
}

/* return the number of seconds in the given input timeval struct */
time_t Curl_tvlong(struct timeval t1)
{
return t1.tv_sec;
}
2 changes: 0 additions & 2 deletions lib/timeval.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,6 @@ time_t curlx_tvdiff(struct timeval t1, struct timeval t2);
*/
double curlx_tvdiff_secs(struct timeval t1, struct timeval t2);

time_t Curl_tvlong(struct timeval t1);

/* These two defines below exist to provide the older API for library
internals only. */
#define Curl_tvnow() curlx_tvnow()
Expand Down
11 changes: 2 additions & 9 deletions src/tool_util.c
Original file line number Diff line number Diff line change
Expand Up @@ -121,8 +121,8 @@ struct timeval tool_tvnow(void)
*/
long tool_tvdiff(struct timeval newer, struct timeval older)
{
return (newer.tv_sec-older.tv_sec)*1000+
(newer.tv_usec-older.tv_usec)/1000;
return (long)(newer.tv_sec-older.tv_sec)*1000+
(long)(newer.tv_usec-older.tv_usec)/1000;
}

/*
Expand All @@ -137,10 +137,3 @@ double tool_tvdiff_secs(struct timeval newer, struct timeval older)
(double)(newer.tv_usec-older.tv_usec)/1000000.0;
return (double)(newer.tv_usec-older.tv_usec)/1000000.0;
}

/* return the number of seconds in the given input timeval struct */
long tool_tvlong(struct timeval t1)
{
return t1.tv_sec;
}

2 changes: 0 additions & 2 deletions src/tool_util.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,12 +45,10 @@ long tool_tvlong(struct timeval t1);
#undef tvnow
#undef tvdiff
#undef tvdiff_secs
#undef tvlong

#define tvnow() tool_tvnow()
#define tvdiff(a,b) tool_tvdiff((a), (b))
#define tvdiff_secs(a,b) tool_tvdiff_secs((a), (b))
#define tvlong(a) tool_tvlong((a))

#endif /* HEADER_CURL_TOOL_UTIL_H */

25 changes: 5 additions & 20 deletions tests/libtest/lib1501.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,22 +31,7 @@

/* 500 milliseconds allowed. An extreme number but lets be really conservative
to allow old and slow machines to run this test too */
#define MAX_BLOCKED_TIME_US 500000

/* return the number of microseconds between two time stamps */
static int elapsed(struct timeval *before,
struct timeval *after)
{
ssize_t result;

result = (after->tv_sec - before->tv_sec) * 1000000 +
after->tv_usec - before->tv_usec;
if(result < 0)
result = 0;

return curlx_sztosi(result);
}

#define MAX_BLOCKED_TIME_MS 500

int test(char *URL)
{
Expand Down Expand Up @@ -80,7 +65,7 @@ int test(char *URL)
int maxfd = -99;
struct timeval before;
struct timeval after;
int e;
long e;

timeout.tv_sec = 0;
timeout.tv_usec = 100000L; /* 100 ms */
Expand All @@ -105,10 +90,10 @@ int test(char *URL)
abort_on_test_timeout();

after = tutil_tvnow();
e = elapsed(&before, &after);
fprintf(stderr, "pong = %d\n", e);
e = tutil_tvdiff(after, before);
fprintf(stderr, "pong = %ld\n", e);

if(e > MAX_BLOCKED_TIME_US) {
if(e > MAX_BLOCKED_TIME_MS) {
res = 100;
break;
}
Expand Down
21 changes: 2 additions & 19 deletions tests/libtest/lib1507.c
Original file line number Diff line number Diff line change
Expand Up @@ -44,23 +44,6 @@ static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp)
return CURL_READFUNC_ABORT;
}

static struct timeval tvnow(void)
{
/*
** time() returns the value of time in seconds since the Epoch.
*/
struct timeval now;
now.tv_sec = (long)time(NULL);
now.tv_usec = 0;
return now;
}

static long tvdiff(struct timeval newer, struct timeval older)
{
return (newer.tv_sec-older.tv_sec)*1000+
(newer.tv_usec-older.tv_usec)/1000;
}

int test(char *URL)
{
int res = 0;
Expand Down Expand Up @@ -93,7 +76,7 @@ int test(char *URL)
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
multi_add_handle(mcurl, curl);

mp_start = tvnow();
mp_start = tutil_tvnow();

/* we start some action by calling perform right away */
curl_multi_perform(mcurl, &still_running);
Expand Down Expand Up @@ -137,7 +120,7 @@ int test(char *URL)

rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout);

if(tvdiff(tvnow(), mp_start) > MULTI_PERFORM_HANG_TIMEOUT) {
if(tutil_tvdiff(tutil_tvnow(), mp_start) > MULTI_PERFORM_HANG_TIMEOUT) {
fprintf(stderr, "ABORTING TEST, since it seems "
"that it would have run forever.\n");
break;
Expand Down
5 changes: 1 addition & 4 deletions tests/libtest/lib1900.c
Original file line number Diff line number Diff line change
Expand Up @@ -167,7 +167,6 @@ int test(char *URL)
for(;;) {
struct timeval interval;
struct timeval now;
long int msnow, mslast;
fd_set rd, wr, exc;
int maxfd = -99;
long timeout;
Expand All @@ -177,9 +176,7 @@ int test(char *URL)

if(handlenum < num_handles) {
now = tutil_tvnow();
msnow = now.tv_sec * 1000 + now.tv_usec / 1000;
mslast = last_handle_add.tv_sec * 1000 + last_handle_add.tv_usec / 1000;
if((msnow - mslast) >= urltime[handlenum]) {
if(tutil_tvdiff(now, last_handle_add) >= urltime[handlenum]) {
fprintf(stdout, "Adding handle %d\n", handlenum);
setup_handle(URL, m, handlenum);
last_handle_add = now;
Expand Down
4 changes: 2 additions & 2 deletions tests/libtest/lib582.c
Original file line number Diff line number Diff line change
Expand Up @@ -174,8 +174,8 @@ static int getMicroSecondTimeout(struct timeval* timeout)
struct timeval now;
ssize_t result;
now = tutil_tvnow();
result = (timeout->tv_sec - now.tv_sec) * 1000000 +
timeout->tv_usec - now.tv_usec;
result = (ssize_t)((timeout->tv_sec - now.tv_sec) * 1000000 +
timeout->tv_usec - now.tv_usec);
if(result < 0)
result = 0;

Expand Down
15 changes: 4 additions & 11 deletions tests/libtest/testutil.c
Original file line number Diff line number Diff line change
Expand Up @@ -111,10 +111,11 @@ struct timeval tutil_tvnow(void)
*/
long tutil_tvdiff(struct timeval newer, struct timeval older)
{
return (newer.tv_sec-older.tv_sec)*1000+
(newer.tv_usec-older.tv_usec)/1000;
return (long)(newer.tv_sec-older.tv_sec)*1000+
(long)(newer.tv_usec-older.tv_usec)/1000;
}


/*
* Same as tutil_tvdiff but with full usec resolution.
*
Expand All @@ -125,13 +126,5 @@ double tutil_tvdiff_secs(struct timeval newer, struct timeval older)
if(newer.tv_sec != older.tv_sec)
return (double)(newer.tv_sec-older.tv_sec)+
(double)(newer.tv_usec-older.tv_usec)/1000000.0;
else
return (double)(newer.tv_usec-older.tv_usec)/1000000.0;
}

/* return the number of seconds in the given input timeval struct */
long tutil_tvlong(struct timeval t1)
{
return t1.tv_sec;
return (double)(newer.tv_usec-older.tv_usec)/1000000.0;
}

2 changes: 0 additions & 2 deletions tests/libtest/testutil.h
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,6 @@ long tutil_tvdiff(struct timeval t1, struct timeval t2);
*/
double tutil_tvdiff_secs(struct timeval t1, struct timeval t2);

long tutil_tvlong(struct timeval t1);


#endif /* HEADER_CURL_LIBTEST_TESTUTIL_H */