From b22e03b2b2504e0561a0a3f434836f476f1b83f3 Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Wed, 14 Nov 2007 22:41:42 +0000 Subject: [PATCH] Fix how TFTP connections are treated when re-used, if the SessionHandle has been used for other protocols in between. I found this when test 2004 started to fail for me! --- lib/tftp.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lib/tftp.c b/lib/tftp.c index acab99334..8ed71df3b 100644 --- a/lib/tftp.c +++ b/lib/tftp.c @@ -698,8 +698,7 @@ static CURLcode Curl_tftp_done(struct connectdata *conn, CURLcode status, static CURLcode Curl_tftp(struct connectdata *conn, bool *done) { struct SessionHandle *data = conn->data; - tftp_state_data_t *state = - (tftp_state_data_t *) conn->data->reqdata.proto.tftp; + tftp_state_data_t *state; tftp_event_t event; CURLcode code; int rc; @@ -716,12 +715,14 @@ static CURLcode Curl_tftp(struct connectdata *conn, bool *done) make sure we have a good 'struct TFTP' to play with. For new connections, the struct TFTP is allocated and setup in the Curl_tftp_connect() function. */ - if(!state) { + Curl_reset_reqproto(conn); + + if(!data->reqdata.proto.tftp) { code = Curl_tftp_connect(conn, done); if(code) return code; - state = (tftp_state_data_t *)conn->data->reqdata.proto.tftp; } + state = (tftp_state_data_t *)conn->data->reqdata.proto.tftp; code = Curl_readwrite_init(conn); if(code)