aboutsummaryrefslogtreecommitdiffstats
path: root/libtransport/src/hicn/transport/protocols/rtc.cc
diff options
context:
space:
mode:
authormichele papalini <micpapal@cisco.com>2019-10-15 12:01:48 +0200
committermichele papalini <micpapal@cisco.com>2019-10-15 12:01:48 +0200
commit41d3c5be7c61046f430c401c29d9a55a5f6b163c (patch)
tree8e39a2ecfbb18dfab01e3130bcfc25605ce8b7a1 /libtransport/src/hicn/transport/protocols/rtc.cc
parent1f25155b97472252c42b8379e6baf01a0e491896 (diff)
[HICN-239] retransmissions on RTC
Signed-off-by: michele papalini <micpapal@cisco.com> Change-Id: I9777e445acf0dd0f70af0a9446b3b9a1424c0c6f
Diffstat (limited to 'libtransport/src/hicn/transport/protocols/rtc.cc')
-rw-r--r--libtransport/src/hicn/transport/protocols/rtc.cc70
1 files changed, 37 insertions, 33 deletions
diff --git a/libtransport/src/hicn/transport/protocols/rtc.cc b/libtransport/src/hicn/transport/protocols/rtc.cc
index accd98495..3e2fe9131 100644
--- a/libtransport/src/hicn/transport/protocols/rtc.cc
+++ b/libtransport/src/hicn/transport/protocols/rtc.cc
@@ -205,7 +205,7 @@ void RTCTransportProtocol::updateStats(uint32_t round_duration) {
((1 - HICN_ESTIMATED_BW_ALPHA) * bytesPerSec);
}
- uint64_t minRtt = UINT_MAX;
+ uint64_t minRtt = 150;
uint64_t maxRtt = 0;
for (auto it = pathTable_.begin(); it != pathTable_.end(); it++) {
@@ -509,7 +509,9 @@ void RTCTransportProtocol::addRetransmissions(uint32_t start, uint32_t stop) {
for (uint32_t i = start; i < stop; i++) {
auto it = interestRetransmissions_.find(i);
if (it == interestRetransmissions_.end()) {
- if (lastSegNacked_ <= i) {
+ uint32_t pkt = actualSegment_ & modMask_;
+ if (lastSegNacked_ <= i &&
+ inflightInterests_[pkt].state != received_) {
// it must be larger than the last past nack received
packetLost_++;
interestRetransmissions_[i] = 0;
@@ -564,17 +566,19 @@ void RTCTransportProtocol::retransmit() {
uint64_t sent_time = inflightInterests_[pkt].transmissionTime;
uint64_t rtx_time = sent_time;
- if(it->second == 0){
- if(pathTable_.find(producerPathLabels_[0]) != pathTable_.end() &&
- pathTable_.find(producerPathLabels_[1]) != pathTable_.end()){
+ if(it->second == 0 &&
+ pathTable_.find(producerPathLabels_[0]) != pathTable_.end() &&
+ (pathTable_[producerPathLabels_[0]]->getInterArrivalGap() <
+ pathTable_[producerPathLabels_[0]]->getMinRtt())){
+ if(pathTable_.find(producerPathLabels_[1]) != pathTable_.end()){
//first rtx: wait RTTmax - RTTmin + gap
rtx_time = sent_time + pathTable_[producerPathLabels_[1]]->getMinRtt() -
pathTable_[producerPathLabels_[0]]->getMinRtt() +
- pathTable_[producerPathLabels_[1]]->getInterArrivalGap();
+ pathTable_[producerPathLabels_[0]]->getInterArrivalGap();
}
}else{
if(pathTable_.find(producerPathLabels_[0]) != pathTable_.end()){
- //second+ rtx: waint min rtt
+ //second+ rtx: wait min rtt
rtx_time = sent_time + pathTable_[producerPathLabels_[0]]->getMinRtt();
}
}
@@ -609,7 +613,9 @@ void RTCTransportProtocol::checkRtx() {
auto pathStats = pathTable_.find(producerPathLabels_[0]);
uint64_t wait = 1;
if(pathStats != pathTable_.end()){
- wait = floor(pathStats->second->getInterArrivalGap() / 2.0);
+ uint32_t GAP = floor(pathStats->second->getInterArrivalGap() / 2.0);
+ uint32_t RTT = floor(pathStats->second->getMinRtt() / 2.0);
+ wait = min(RTT,GAP);
if(wait < 1)
wait = 1;
}
@@ -678,6 +684,12 @@ bool RTCTransportProtocol::onNack(const ContentObject &content_object, bool rtx)
bool old_nack = false;
+ // if we did not received anything between lastReceived_ + 1 and productionSeg
+ // most likelly some packets got lost
+ if(lastReceived_ != 0){
+ addRetransmissions(lastReceived_ + 1, productionSeg);
+ }
+
if(!rtx){
gotNack_ = true;
// we synch the estimated production rate with the actual one
@@ -697,16 +709,6 @@ bool RTCTransportProtocol::onNack(const ContentObject &content_object, bool rtx)
increaseWindow();
}
- //we need to remove the rtx for packets with seq number
- //< productionSeg
- for(auto it = interestRetransmissions_.begin(); it !=
- interestRetransmissions_.end();){
- if(it->first < productionSeg)
- it = interestRetransmissions_.erase(it);
- else
- ++it;
- }
-
lastSegNacked_ = productionSeg;
old_nack = true;
@@ -791,10 +793,12 @@ void RTCTransportProtocol::onContentObject(
//multiple times. In fact, every time that we receive an event related to an
//interest (timeout, nacked, content) we cange the state. In this way we are
//sure that we do not decrease twice the counter
- if(old_nack)
+ if(old_nack){
inflightInterests_[pkt].state = lost_;
- else
+ interestRetransmissions_.erase(segmentNumber);
+ }else{
inflightInterests_[pkt].state = nacked_;
+ }
} else {
avgPacketSize_ = (HICN_ESTIMATED_PACKET_SIZE * avgPacketSize_) +
@@ -812,28 +816,28 @@ void RTCTransportProtocol::onContentObject(
receivedBytes_ += (uint32_t)(content_object->headerSize() +
content_object->payloadSize());
updateDelayStats(*content_object);
-
- addRetransmissions(lastReceived_ + 1, segmentNumber);
- if(segmentNumber > highestReceived_)
- highestReceived_ = segmentNumber;
- // lastReceived_ is updated only for data packets received without RTX
- lastReceived_ = segmentNumber;
}
+ addRetransmissions(lastReceived_ + 1, segmentNumber);
+ if(segmentNumber > highestReceived_){
+ highestReceived_ = segmentNumber;
+ }
+ if(segmentNumber > lastReceived_){
+ lastReceived_ = segmentNumber;
+ }
receivedData_++;
inflightInterests_[pkt].state = received_;
+ auto it = interestRetransmissions_.find(segmentNumber);
+ if(it != interestRetransmissions_.end())
+ lossRecovered_ ++;
+
+ interestRetransmissions_.erase(segmentNumber);
+
reassemble(std::move(content_object));
increaseWindow();
}
- // in any case we remove the packet from the rtx list
- auto it = interestRetransmissions_.find(segmentNumber);
- if(it != interestRetransmissions_.end())
- lossRecovered_ ++;
-
- interestRetransmissions_.erase(segmentNumber);
-
scheduleNextInterests();
}