mirror of
https://github.com/curl/curl.git
synced 2025-01-18 14:04:30 +08:00
multi: when erroring in TOOFAST state, act as for PERFORM
When failing in TOOFAST, the multi_done() wasn't called so the same cleanup and handling wasn't done like when it fails in PERFORM, which in the case of FTP could mean that the control connection wouldn't be marked as "dead" for the CURLE_ABORTED_BY_CALLBACK case. Which caused ftp_disconnect() to use it to send "QUIT", which could end up waiting for a response a long time before giving up! Reported-by: Tomas Berger Fixes #6333 Closes #6337
This commit is contained in:
parent
ad338b390b
commit
3e17c8ab72
10
lib/multi.c
10
lib/multi.c
@ -2079,7 +2079,15 @@ static CURLMcode multi_runsingle(struct Curl_multi *multi,
|
|||||||
else
|
else
|
||||||
result = Curl_speedcheck(data, *nowp);
|
result = Curl_speedcheck(data, *nowp);
|
||||||
|
|
||||||
if(!result) {
|
if(result) {
|
||||||
|
if(!(data->conn->handler->flags & PROTOPT_DUAL) &&
|
||||||
|
result != CURLE_HTTP2_STREAM)
|
||||||
|
streamclose(data->conn, "Transfer returned error");
|
||||||
|
|
||||||
|
Curl_posttransfer(data);
|
||||||
|
multi_done(data, result, TRUE);
|
||||||
|
}
|
||||||
|
else {
|
||||||
send_timeout_ms = 0;
|
send_timeout_ms = 0;
|
||||||
if(data->set.max_send_speed > 0)
|
if(data->set.max_send_speed > 0)
|
||||||
send_timeout_ms =
|
send_timeout_ms =
|
||||||
|
Loading…
Reference in New Issue
Block a user