1
0
mirror of https://github.com/mfontanini/libtins synced 2026-01-27 12:14:26 +01:00

Allow asking whether segment was acked

This commit is contained in:
Matias Fontanini
2016-02-13 22:45:11 -08:00
parent 2498ebf7d6
commit abe94ece52
5 changed files with 72 additions and 1 deletions

View File

@@ -38,11 +38,23 @@
using std::vector;
using std::numeric_limits;
using boost::icl::interval_bounds;
using boost::icl::contains;
using Tins::Internals::seq_compare;
namespace Tins {
namespace TCPIP {
uint32_t interval_end(const AckedRange::interval_type& interval) {
if (interval.bounds() == interval_bounds::right_open()) {
return interval.upper() - 1;
}
else {
return interval.upper();
}
}
// AckedRange
AckedRange::AckedRange(uint32_t first, uint32_t last)
@@ -140,6 +152,22 @@ const AckTracker::interval_set_type& AckTracker::acked_intervals() const {
return acked_intervals_;
}
bool AckTracker::is_segment_acked(uint32_t sequence_number, uint32_t length) const {
if (length == 0) {
return true;
}
AckedRange range(sequence_number, sequence_number + length - 1);
while (range.has_next()) {
AckedRange::interval_type interval = range.next();
const int comparison = seq_compare(interval_end(interval), ack_number_);
// Only check for SACKed intervals if the segment finishes after our ACK number
if (comparison >= 0 && !contains(acked_intervals_, interval)) {
return false;
}
}
return true;
}
} // TCPIP
} // Tins

View File

@@ -319,6 +319,17 @@ bool Flow::ack_tracking_enabled() const {
return flags_.ack_tracking;
}
#ifdef HAVE_ACK_TRACKER
const AckTracker& Flow::ack_tracker() const {
return ack_tracker_;
}
AckTracker& Flow::ack_tracker() {
return ack_tracker_;
}
#endif // HAVE_ACK_TRACKER
} // TCPIP
} // Tins