mirror of
https://github.com/ton-blockchain/ton
synced 2025-03-09 15:40:10 +00:00
integrating the existing state of TON Storage / TON Payments / CPS Fift development branches
This commit is contained in:
parent
040df63c98
commit
4e2624459b
153 changed files with 10760 additions and 1695 deletions
34
rldp2/RldpReceiver.cpp
Normal file
34
rldp2/RldpReceiver.cpp
Normal file
|
@ -0,0 +1,34 @@
|
|||
#include "RldpReceiver.h"
|
||||
|
||||
namespace ton {
|
||||
namespace rldp2 {
|
||||
td::Variant<RldpReceiver::ActionSendAck, RldpReceiver::ActionWait> RldpReceiver::next_action(td::Timestamp now) {
|
||||
if (send_ack_at_ && (send_ack_at_.is_in_past(now))) {
|
||||
return ActionSendAck{ack};
|
||||
}
|
||||
return ActionWait{send_ack_at_};
|
||||
}
|
||||
|
||||
void RldpReceiver::on_ack_sent(td::Timestamp now) {
|
||||
if (cnt_ != 0) {
|
||||
//LOG(ERROR) << "RESEND ACK " << cnt_;
|
||||
}
|
||||
cnt_++;
|
||||
if (cnt_ > 7) {
|
||||
send_ack_at_ = {};
|
||||
} else {
|
||||
send_ack_at_.relax(td::Timestamp::at(now.at() + config_.ack_delay * (1 << cnt_)));
|
||||
}
|
||||
}
|
||||
|
||||
bool RldpReceiver::on_received(td::uint32 seqno, td::Timestamp now) {
|
||||
if (!ack.on_got_packet(seqno)) {
|
||||
return false;
|
||||
}
|
||||
cnt_ = 0;
|
||||
send_ack_at_.relax(td::Timestamp::at(now.at() + config_.ack_delay));
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace rldp2
|
||||
} // namespace ton
|
Loading…
Add table
Add a link
Reference in a new issue