113498266Sopenharmony_ci/*************************************************************************** 213498266Sopenharmony_ci * _ _ ____ _ 313498266Sopenharmony_ci * Project ___| | | | _ \| | 413498266Sopenharmony_ci * / __| | | | |_) | | 513498266Sopenharmony_ci * | (__| |_| | _ <| |___ 613498266Sopenharmony_ci * \___|\___/|_| \_\_____| 713498266Sopenharmony_ci * 813498266Sopenharmony_ci * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al. 913498266Sopenharmony_ci * 1013498266Sopenharmony_ci * This software is licensed as described in the file COPYING, which 1113498266Sopenharmony_ci * you should have received as part of this distribution. The terms 1213498266Sopenharmony_ci * are also available at https://curl.se/docs/copyright.html. 1313498266Sopenharmony_ci * 1413498266Sopenharmony_ci * You may opt to use, copy, modify, merge, publish, distribute and/or sell 1513498266Sopenharmony_ci * copies of the Software, and permit persons to whom the Software is 1613498266Sopenharmony_ci * furnished to do so, under the terms of the COPYING file. 1713498266Sopenharmony_ci * 1813498266Sopenharmony_ci * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY 1913498266Sopenharmony_ci * KIND, either express or implied. 2013498266Sopenharmony_ci * 2113498266Sopenharmony_ci * SPDX-License-Identifier: curl 2213498266Sopenharmony_ci * 2313498266Sopenharmony_ci ***************************************************************************/ 2413498266Sopenharmony_ci 2513498266Sopenharmony_ci#include "curl_setup.h" 2613498266Sopenharmony_ci 2713498266Sopenharmony_ci#include <curl/curl.h> 2813498266Sopenharmony_ci#include "urldata.h" 2913498266Sopenharmony_ci#include "sendf.h" 3013498266Sopenharmony_ci#include "multiif.h" 3113498266Sopenharmony_ci#include "speedcheck.h" 3213498266Sopenharmony_ci 3313498266Sopenharmony_civoid Curl_speedinit(struct Curl_easy *data) 3413498266Sopenharmony_ci{ 3513498266Sopenharmony_ci memset(&data->state.keeps_speed, 0, sizeof(struct curltime)); 3613498266Sopenharmony_ci} 3713498266Sopenharmony_ci 3813498266Sopenharmony_ci/* 3913498266Sopenharmony_ci * @unittest: 1606 4013498266Sopenharmony_ci */ 4113498266Sopenharmony_ciCURLcode Curl_speedcheck(struct Curl_easy *data, 4213498266Sopenharmony_ci struct curltime now) 4313498266Sopenharmony_ci{ 4413498266Sopenharmony_ci if(data->req.keepon & KEEP_RECV_PAUSE) 4513498266Sopenharmony_ci /* A paused transfer is not qualified for speed checks */ 4613498266Sopenharmony_ci return CURLE_OK; 4713498266Sopenharmony_ci 4813498266Sopenharmony_ci if((data->progress.current_speed >= 0) && data->set.low_speed_time) { 4913498266Sopenharmony_ci if(data->progress.current_speed < data->set.low_speed_limit) { 5013498266Sopenharmony_ci if(!data->state.keeps_speed.tv_sec) 5113498266Sopenharmony_ci /* under the limit at this very moment */ 5213498266Sopenharmony_ci data->state.keeps_speed = now; 5313498266Sopenharmony_ci else { 5413498266Sopenharmony_ci /* how long has it been under the limit */ 5513498266Sopenharmony_ci timediff_t howlong = Curl_timediff(now, data->state.keeps_speed); 5613498266Sopenharmony_ci 5713498266Sopenharmony_ci if(howlong >= data->set.low_speed_time * 1000) { 5813498266Sopenharmony_ci /* too long */ 5913498266Sopenharmony_ci failf(data, 6013498266Sopenharmony_ci "Operation too slow. " 6113498266Sopenharmony_ci "Less than %ld bytes/sec transferred the last %ld seconds", 6213498266Sopenharmony_ci data->set.low_speed_limit, 6313498266Sopenharmony_ci data->set.low_speed_time); 6413498266Sopenharmony_ci return CURLE_OPERATION_TIMEDOUT; 6513498266Sopenharmony_ci } 6613498266Sopenharmony_ci } 6713498266Sopenharmony_ci } 6813498266Sopenharmony_ci else 6913498266Sopenharmony_ci /* faster right now */ 7013498266Sopenharmony_ci data->state.keeps_speed.tv_sec = 0; 7113498266Sopenharmony_ci } 7213498266Sopenharmony_ci 7313498266Sopenharmony_ci if(data->set.low_speed_limit) 7413498266Sopenharmony_ci /* if low speed limit is enabled, set the expire timer to make this 7513498266Sopenharmony_ci connection's speed get checked again in a second */ 7613498266Sopenharmony_ci Curl_expire(data, 1000, EXPIRE_SPEEDCHECK); 7713498266Sopenharmony_ci 7813498266Sopenharmony_ci return CURLE_OK; 7913498266Sopenharmony_ci} 80