20
#include "SenderPackets.h"
22
#include "td/utils/bits.h"
26
td::uint32 SenderPackets::next_seqno() const {
27
return last_seqno_ + 1;
30
SenderPackets::DropUpdate SenderPackets::drop_packets(const Limits &limits) {
31
while (!packets.empty()) {
32
auto &packet = packets.front();
33
if (!limits.should_drop(packet)) {
36
mark_ack_or_lost(packet);
40
update.new_ack = total_ack_ - last_total_ack_;
41
update.new_lost = total_lost_ - last_total_lost_;
42
last_total_ack_ = total_ack_;
43
last_total_lost_ = total_lost_;
44
update.o_loss_at = std::move(last_loss_);
48
SenderPackets::Update SenderPackets::on_ack(Ack ack) {
49
ack.max_seqno = td::min(ack.max_seqno, last_seqno_);
50
ack.received_count = td::min(ack.received_count, ack.max_seqno);
54
if (received_count_ < ack.received_count) {
55
update.new_received = ack.received_count - received_count_;
56
left_ack_ += update.new_received;
57
left_ack_ = td::min(left_ack_, in_flight_count_);
58
received_count_ = ack.received_count;
61
if (max_packet_.seqno > ack.max_seqno) {
65
auto packet = get_packet(ack.max_seqno);
70
if (max_packet_.seqno < ack.max_seqno) {
71
update.was_max_updated = true;
72
max_packet_ = *packet;
75
for (td::uint32 i : td::BitsRange(ack.received_mask)) {
76
if (ack.max_seqno < i) {
79
auto seqno = ack.max_seqno - i;
80
auto packet = get_packet(seqno);
89
void SenderPackets::mark_ack_or_lost(Packet &packet) {
97
void SenderPackets::mark_lost(Packet &packet) {
98
if (!packet.is_in_flight) {
103
packet.is_in_flight = false;
104
last_loss_ = packet.sent_at;
107
void SenderPackets::mark_ack(Packet &packet) {
108
if (!packet.is_in_flight) {
116
packet.is_in_flight = false;
119
SenderPackets::Packet *SenderPackets::get_packet(td::uint32 seqno) {
120
if (packets.empty()) {
123
auto front_seqno = packets.front().seqno;
124
if (front_seqno > seqno) {
127
td::uint32 index = seqno - front_seqno;
128
if (index >= packets.size()) {
131
auto packet = packets.data() + index;
132
CHECK(packet->seqno == seqno);
136
void SenderPackets::send(Packet packet) {
137
CHECK(next_seqno() == packet.seqno);
138
packets.push(packet);
140
in_flight_count_ += packet.is_in_flight;