diff options
Diffstat (limited to 'lib/tftp.c')
| -rw-r--r-- | lib/tftp.c | 46 | 
1 files changed, 16 insertions, 30 deletions
| diff --git a/lib/tftp.c b/lib/tftp.c index 46b3ecfcb..9b44a9b3d 100644 --- a/lib/tftp.c +++ b/lib/tftp.c @@ -23,27 +23,19 @@  #include "setup.h"  #ifndef CURL_DISABLE_TFTP -/* -- WIN32 approved -- */ -#include <stdio.h> -#include <stdarg.h> -#include <stdlib.h> -#include <ctype.h> - -#if defined(WIN32) -#include <time.h> -#include <io.h> -#else +  #ifdef HAVE_SYS_SOCKET_H  #include <sys/socket.h>  #endif +#ifdef HAVE_NETINET_IN_H  #include <netinet/in.h> -#ifdef HAVE_SYS_TIME_H -#include <sys/time.h>  #endif  #ifdef HAVE_UNISTD_H  #include <unistd.h>  #endif +#ifdef HAVE_NETDB_H  #include <netdb.h> +#endif  #ifdef HAVE_ARPA_INET_H  #include <arpa/inet.h>  #endif @@ -58,8 +50,6 @@  #include <sys/param.h>  #endif -#endif /* WIN32 */ -  #include "urldata.h"  #include <curl/curl.h>  #include "transfer.h" @@ -194,6 +184,7 @@ const struct Curl_handler Curl_handler_tftp = {    tftp_doing,                           /* doing */    tftp_getsock,                         /* proto_getsock */    tftp_getsock,                         /* doing_getsock */ +  ZERO_NULL,                            /* domore_getsock */    ZERO_NULL,                            /* perform_getsock */    tftp_disconnect,                      /* disconnect */    ZERO_NULL,                            /* readwrite */ @@ -216,7 +207,7 @@ static CURLcode tftp_set_timeouts(tftp_state_data_t *state)  {    time_t maxtime, timeout;    long timeout_ms; -  bool start = (bool)(state->state == TFTP_STATE_START); +  bool start = (state->state == TFTP_STATE_START) ? TRUE : FALSE;    time(&state->start_time); @@ -258,11 +249,11 @@ static CURLcode tftp_set_timeouts(tftp_state_data_t *state)      state->max_time = state->start_time+maxtime; -    /* Set per-block timeout to 10% of total */ -    timeout = maxtime/10 ; +    /* Set per-block timeout to total */ +    timeout = maxtime; -    /* Average reposting an ACK after 15 seconds */ -    state->retry_max = (int)timeout/15; +    /* Average reposting an ACK after 5 seconds */ +    state->retry_max = (int)timeout/5;    }    /* But bound the total number */    if(state->retry_max<3) @@ -601,15 +592,10 @@ static CURLcode tftp_rx(tftp_state_data_t *state, tftp_event_t event)      /* Is this the block we expect? */      rblock = getrpacketblock(&state->rpacket);      if(NEXT_BLOCKNUM(state->block) != rblock) { -      /* No, log it, up the retry count and fail if over the limit */ +      /* No, log it */        infof(data, -            "Received unexpected DATA packet block %d\n", rblock); -      state->retries++; -      if(state->retries > state->retry_max) { -        failf(data, "tftp_rx: giving up waiting for block %d", -              NEXT_BLOCKNUM(state->block)); -        return CURLE_TFTP_ILLEGAL; -      } +            "Received unexpected DATA packet block %d, expecting block %d\n", +            rblock, NEXT_BLOCKNUM(state->block));        break;      }      /* This is the expected block.  Reset counters and ACK it. */ @@ -627,7 +613,7 @@ static CURLcode tftp_rx(tftp_state_data_t *state, tftp_event_t event)      }      /* Check if completed (That is, a less than full packet is received) */ -    if(state->rbytes < (ssize_t)state->blksize+4){ +    if(state->rbytes < (ssize_t)state->blksize+4) {        state->state = TFTP_STATE_FIN;      }      else { @@ -1344,7 +1330,7 @@ static CURLcode tftp_multi_statemach(struct connectdata *conn, bool *done)      result = tftp_state_machine(state, event);      if(result != CURLE_OK)        return(result); -    *done = (bool)(state->state == TFTP_STATE_FIN); +    *done = (state->state == TFTP_STATE_FIN) ? TRUE : FALSE;      if(*done)        /* Tell curl we're done */        Curl_setup_transfer(conn, -1, -1, FALSE, NULL, -1, NULL); @@ -1366,7 +1352,7 @@ static CURLcode tftp_multi_statemach(struct connectdata *conn, bool *done)        result = tftp_state_machine(state, state->event);        if(result != CURLE_OK)          return(result); -      *done = (bool)(state->state == TFTP_STATE_FIN); +      *done = (state->state == TFTP_STATE_FIN) ? TRUE : FALSE;        if(*done)          /* Tell curl we're done */          Curl_setup_transfer(conn, -1, -1, FALSE, NULL, -1, NULL); | 
