Skip to content

Commit

Permalink
Use filter fn
Browse files Browse the repository at this point in the history
  • Loading branch information
mxinden committed Jul 10, 2024
1 parent 5c06141 commit 3808dcc
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 18 deletions.
29 changes: 14 additions & 15 deletions neqo-transport/src/cc/classic_cc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -308,15 +308,14 @@ impl<T: WindowAdjustment> CongestionControl for ClassicCongestionControl<T> {
&[QlogMetric::BytesInFlight(self.bytes_in_flight)],
);

let is_pmtud_probe = self.pmtud.is_pmtud_probe_filter();

// Lost PMTUD probes do not elicit a congestion control reaction.
let probe_size = self.pmtud.probe_size();
let probe_sent = self.pmtud.probe_sent();
let mut lost_packets = lost_packets
let Some(last_lost_packet) = lost_packets
.iter()
.filter(|pkt| !probe_sent || pkt.len() < probe_size)
.rev()
.peekable();
let Some(last_lost_packet) = lost_packets.peek() else {
.filter(|pkt| !is_pmtud_probe(pkt))
.last()
else {
return false;
};

Expand All @@ -325,7 +324,7 @@ impl<T: WindowAdjustment> CongestionControl for ClassicCongestionControl<T> {
first_rtt_sample_time,
prev_largest_acked_sent,
pto,
lost_packets.rev(),
lost_packets.iter().filter(|pkt| !is_pmtud_probe(pkt)),
);
qdebug!(
"on_packets_lost this={:p}, bytes_in_flight={}, cwnd={}, state={:?}",
Expand Down Expand Up @@ -469,16 +468,13 @@ impl<T: WindowAdjustment> ClassicCongestionControl<T> {
}
}

fn detect_persistent_congestion<'a, I>(
fn detect_persistent_congestion<'a>(
&mut self,
first_rtt_sample_time: Option<Instant>,
prev_largest_acked_sent: Option<Instant>,
pto: Duration,
lost_packets: I,
) -> bool
where
I: Iterator<Item = &'a SentPacket>,
{
lost_packets: impl IntoIterator<Item = &'a SentPacket>,
) -> bool {
if first_rtt_sample_time.is_none() {
return false;
}
Expand All @@ -493,7 +489,10 @@ impl<T: WindowAdjustment> ClassicCongestionControl<T> {
// Also, make sure to ignore any packets sent before we got an RTT estimate
// as we might not have sent PTO packets soon enough after those.
let cutoff = max(first_rtt_sample_time, prev_largest_acked_sent);
for p in lost_packets.skip_while(|p| Some(p.time_sent()) < cutoff) {
for p in lost_packets
.into_iter()
.skip_while(|p| Some(p.time_sent()) < cutoff)
{
if p.pn() != last_pn + 1 {
// Not a contiguous range of lost packets, start over.
start = None;
Expand Down
18 changes: 15 additions & 3 deletions neqo-transport/src/pmtud.rs
Original file line number Diff line number Diff line change
Expand Up @@ -132,14 +132,26 @@ impl Pmtud {
);
}

/// Provides a [`Fn`] that returns true if the packet is a PMTUD probe.
///
/// Allows filtering packets without holding a reference to [`Pmtud`]. When
/// in doubt, use [`Pmtud::is_pmtud_probe`].
#[must_use]
pub fn is_pmtud_probe_filter(&self) -> impl Fn(&SentPacket) -> bool {
let probe_state = Probe::Sent;
let probe_size = self.probe_size();

move |p: &SentPacket| -> bool { probe_state == Probe::Sent && p.len() == probe_size }
}

/// Returns true if the packet is a PMTUD probe.
fn is_probe(&self, p: &SentPacket) -> bool {
self.probe_state == Probe::Sent && p.len() == self.probe_size()
fn is_pmtud_probe(&self, p: &SentPacket) -> bool {
self.is_pmtud_probe_filter()(p)
}

/// Count the PMTUD probes included in `pkts`.
fn count_probes(&self, pkts: &[SentPacket]) -> usize {
pkts.iter().filter(|p| self.is_probe(p)).count()
pkts.iter().filter(|p| self.is_pmtud_probe(p)).count()
}

/// Checks whether a PMTUD probe has been acknowledged, and if so, updates the PMTUD state.
Expand Down

0 comments on commit 3808dcc

Please sign in to comment.