1
0
Fork 0
Univerxel/deps/picoquic/cc_common.h

86 lines
3.3 KiB
C

/*
* Author: Christian Huitema
* Copyright (c) 2019, Private Octopus, Inc.
* All rights reserved.
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL Private Octopus, Inc. BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef CC_COMMON_H
#define CC_COMMON_H
#define PICOQUIC_MIN_MAX_RTT_SCOPE 7
#define PICOQUIC_SMOOTHED_LOSS_SCOPE 32
#define PICOQUIC_SMOOTHED_LOSS_FACTOR (1.0/16.0)
#define PICOQUIC_SMOOTHED_LOSS_THRESHOLD (0.2)
typedef struct st_picoquic_min_max_rtt_t {
uint64_t last_rtt_sample_time;
uint64_t rtt_filtered_min;
int nb_rtt_excess;
int sample_current;
int is_init;
double smoothed_drop_rate;
uint64_t last_lost_packet_number;
uint64_t sample_min;
uint64_t sample_max;
uint64_t samples[PICOQUIC_MIN_MAX_RTT_SCOPE];
} picoquic_min_max_rtt_t;
uint64_t picoquic_cc_get_sequence_number(picoquic_cnx_t* cnx);
uint64_t picoquic_cc_get_ack_number(picoquic_cnx_t* cnx);
void picoquic_filter_rtt_min_max(picoquic_min_max_rtt_t* rtt_track, uint64_t rtt);
int picoquic_hystart_loss_test(picoquic_min_max_rtt_t* rtt_track, picoquic_congestion_notification_t event, uint64_t lost_packet_number);
int picoquic_hystart_test(picoquic_min_max_rtt_t* rtt_track, uint64_t rtt_measurement, uint64_t packet_time, uint64_t current_time, int is_one_way_delay_enabled);
void picoquic_hystart_increase(picoquic_path_t* path_x, picoquic_min_max_rtt_t* rtt_filter, uint64_t nb_delivered);
/* Many congestion control algorithms run a parallel version of new reno in order
* to provide a lower bound estimate of either the congestion window or the
* the minimal bandwidth. This implementation of new reno does not directly
* refer to the connection and path variables (e.g. cwin) but instead sets
* its entire state in memory.
*/
typedef enum {
picoquic_newreno_alg_slow_start = 0,
picoquic_newreno_alg_congestion_avoidance
} picoquic_newreno_alg_state_t;
typedef struct st_picoquic_newreno_sim_state_t {
picoquic_newreno_alg_state_t alg_state;
uint64_t cwin;
uint64_t residual_ack;
uint64_t ssthresh;
uint64_t recovery_start;
uint64_t recovery_sequence;
} picoquic_newreno_sim_state_t;
void picoquic_newreno_sim_reset(picoquic_newreno_sim_state_t* nrss);
void picoquic_newreno_sim_notify(
picoquic_newreno_sim_state_t* nr_state,
picoquic_cnx_t* cnx,
picoquic_path_t* path_x,
picoquic_congestion_notification_t notification,
uint64_t nb_bytes_acknowledged,
uint64_t current_time);
#endif