mirror of
https://github.com/RetroShare/RetroShare.git
synced 2024-12-29 01:16:20 -05:00
various changes to measure RTTs more accurately
This commit is contained in:
parent
87764abe4c
commit
a4430647de
@ -47,6 +47,7 @@ int rsserverzone = 101;
|
|||||||
/****
|
/****
|
||||||
#define DEBUG_TICK 1
|
#define DEBUG_TICK 1
|
||||||
****/
|
****/
|
||||||
|
#define DEBUG_TICK 1
|
||||||
|
|
||||||
#define WARN_BIG_CYCLE_TIME (0.2)
|
#define WARN_BIG_CYCLE_TIME (0.2)
|
||||||
#ifdef WINDOWS_SYS
|
#ifdef WINDOWS_SYS
|
||||||
@ -69,8 +70,8 @@ static double getCurrentTS()
|
|||||||
return cts;
|
return cts;
|
||||||
}
|
}
|
||||||
|
|
||||||
const double RsServer::minTimeDelta = 0.1; // 25;
|
const double RsServer::minTimeDelta = 0.05; // 25;
|
||||||
const double RsServer::maxTimeDelta = 0.5;
|
const double RsServer::maxTimeDelta = 0.1;
|
||||||
const double RsServer::kickLimit = 0.15;
|
const double RsServer::kickLimit = 0.15;
|
||||||
|
|
||||||
|
|
||||||
@ -139,6 +140,8 @@ void RsServer::data_tick()
|
|||||||
double ts = getCurrentTS();
|
double ts = getCurrentTS();
|
||||||
double delta = ts - mLastts;
|
double delta = ts - mLastts;
|
||||||
|
|
||||||
|
std::cerr << "[data tick] delta = " << delta << std::endl;
|
||||||
|
|
||||||
/* for the fast ticked stuff */
|
/* for the fast ticked stuff */
|
||||||
if (delta > mTimeDelta)
|
if (delta > mTimeDelta)
|
||||||
{
|
{
|
||||||
|
@ -23,6 +23,8 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <iomanip>
|
||||||
|
|
||||||
#include "util/rsdir.h"
|
#include "util/rsdir.h"
|
||||||
#include "retroshare/rsiface.h"
|
#include "retroshare/rsiface.h"
|
||||||
#include "pqi/pqibin.h"
|
#include "pqi/pqibin.h"
|
||||||
@ -37,6 +39,7 @@
|
|||||||
/****
|
/****
|
||||||
* #define DEBUG_RTT 1
|
* #define DEBUG_RTT 1
|
||||||
****/
|
****/
|
||||||
|
#define DEBUG_RTT 1
|
||||||
|
|
||||||
|
|
||||||
/* DEFINE INTERFACE POINTER! */
|
/* DEFINE INTERFACE POINTER! */
|
||||||
@ -147,6 +150,7 @@ RsServiceInfo p3rtt::getServiceInfo()
|
|||||||
|
|
||||||
int p3rtt::tick()
|
int p3rtt::tick()
|
||||||
{
|
{
|
||||||
|
std::cerr << "p3rtt::tick() " << getCurrentTS() << std::endl;
|
||||||
sendPackets();
|
sendPackets();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -168,7 +172,7 @@ int p3rtt::sendPackets()
|
|||||||
pt = mSentPingTime;
|
pt = mSentPingTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (now - pt > RTT_PING_PERIOD)
|
if (now >= pt+RTT_PING_PERIOD)
|
||||||
{
|
{
|
||||||
sendPingMeasurements();
|
sendPingMeasurements();
|
||||||
|
|
||||||
@ -190,19 +194,10 @@ void p3rtt::sendPingMeasurements()
|
|||||||
|
|
||||||
mServiceCtrl->getPeersConnected(getServiceInfo().mServiceType, idList);
|
mServiceCtrl->getPeersConnected(getServiceInfo().mServiceType, idList);
|
||||||
|
|
||||||
#ifdef DEBUG_RTT
|
|
||||||
std::cerr << "p3rtt::sendPingMeasurements() @ts: " << ts;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* prepare packets */
|
/* prepare packets */
|
||||||
std::set<RsPeerId>::iterator it;
|
std::set<RsPeerId>::iterator it;
|
||||||
for(it = idList.begin(); it != idList.end(); ++it)
|
for(it = idList.begin(); it != idList.end(); ++it)
|
||||||
{
|
{
|
||||||
#ifdef DEBUG_RTT
|
|
||||||
std::cerr << "p3rtt::sendPingMeasurements() Pinging: " << *it;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
double ts = getCurrentTS();
|
double ts = getCurrentTS();
|
||||||
|
|
||||||
/* create the packet */
|
/* create the packet */
|
||||||
@ -214,11 +209,8 @@ void p3rtt::sendPingMeasurements()
|
|||||||
storePingAttempt(*it, ts, mCounter);
|
storePingAttempt(*it, ts, mCounter);
|
||||||
|
|
||||||
#ifdef DEBUG_RTT
|
#ifdef DEBUG_RTT
|
||||||
std::cerr << "p3rtt::sendPingMeasurements() With Packet:";
|
std::cerr << "p3rtt::sendPingMeasurements() Pinging: " << *it << " [" << pingPkt->mSeqNo << "," << std::hex << pingPkt->mPingTS << std::dec << "]" << std::endl;;
|
||||||
std::cerr << std::endl;
|
|
||||||
pingPkt->print(std::cerr, 10);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
sendItem(pingPkt);
|
sendItem(pingPkt);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,30 +248,26 @@ int p3rtt::handlePing(RsItem *item)
|
|||||||
/* cast to right type */
|
/* cast to right type */
|
||||||
RsRttPingItem *ping = (RsRttPingItem *) item;
|
RsRttPingItem *ping = (RsRttPingItem *) item;
|
||||||
|
|
||||||
|
double ts = getCurrentTS();
|
||||||
#ifdef DEBUG_RTT
|
#ifdef DEBUG_RTT
|
||||||
std::cerr << "p3rtt::handlePing() Recvd Packet from: " << ping->PeerId();
|
std::cerr << "p3rtt::handlePing() from: " << ping->PeerId() << " - [" << ping->mSeqNo << "," << std::hex << ping->mPingTS << std::dec << "] " << std::endl;
|
||||||
std::cerr << std::endl;
|
std::cerr << "incoming ping travel time: " << ts - convert64bitsToTs(ping->mPingTS) << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* with a ping, we just respond as quickly as possible - they do all the analysis */
|
/* with a ping, we just respond as quickly as possible - they do all the analysis */
|
||||||
RsRttPongItem *pong = new RsRttPongItem();
|
RsRttPongItem *pong = new RsRttPongItem();
|
||||||
|
|
||||||
|
|
||||||
pong->PeerId(ping->PeerId());
|
pong->PeerId(ping->PeerId());
|
||||||
pong->mPingTS = ping->mPingTS;
|
pong->mPingTS = ping->mPingTS;
|
||||||
pong->mSeqNo = ping->mSeqNo;
|
pong->mSeqNo = ping->mSeqNo;
|
||||||
|
|
||||||
// add our timestamp.
|
// add our timestamp.
|
||||||
double ts = getCurrentTS();
|
|
||||||
pong->mPongTS = convertTsTo64bits(ts);
|
pong->mPongTS = convertTsTo64bits(ts);
|
||||||
|
|
||||||
|
static double mLastResponseToPong = 0.0 ;// bad stuff
|
||||||
|
std::cerr << "Delay since last response to PONG: " << ts - mLastResponseToPong << std::endl;
|
||||||
|
|
||||||
#ifdef DEBUG_RTT
|
mLastResponseToPong = ts ;
|
||||||
std::cerr << "p3rtt::handlePing() With Packet:";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
pong->print(std::cerr, 10);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
sendItem(pong);
|
sendItem(pong);
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
@ -291,9 +279,7 @@ int p3rtt::handlePong(RsItem *item)
|
|||||||
RsRttPongItem *pong = (RsRttPongItem *) item;
|
RsRttPongItem *pong = (RsRttPongItem *) item;
|
||||||
|
|
||||||
#ifdef DEBUG_RTT
|
#ifdef DEBUG_RTT
|
||||||
std::cerr << "p3rtt::handlePong() Recvd Packet from: " << pong->PeerId();
|
std::cerr << "p3rtt::handlePong() from: " << pong->PeerId() << " - [" << pong->mSeqNo << "," << std::hex << pong->mPingTS << " -> " << pong->mPongTS << std::dec << "] "<< std::endl;
|
||||||
std::cerr << std::endl;
|
|
||||||
pong->print(std::cerr, 10);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* with a pong, we do the maths! */
|
/* with a pong, we do the maths! */
|
||||||
@ -305,21 +291,12 @@ int p3rtt::handlePong(RsItem *item)
|
|||||||
double offset = pongTS - (recvTS - rtt / 2.0); // so to get to their time, we go ourTS + offset.
|
double offset = pongTS - (recvTS - rtt / 2.0); // so to get to their time, we go ourTS + offset.
|
||||||
|
|
||||||
#ifdef DEBUG_RTT
|
#ifdef DEBUG_RTT
|
||||||
std::cerr << "p3rtt::handlePong() Timing:";
|
std::cerr << "incoming pong travel time: " << recvTS - convert64bitsToTs(pong->mPongTS) << std::endl;
|
||||||
std::cerr << std::endl;
|
std::cerr << " RTT analysis: pingTS: " << std::setprecision(16) << pingTS << ", pongTS: " << pongTS
|
||||||
std::cerr << "\tpingTS: " << pingTS;
|
<< ", recvTS: " << std::setprecision(16) << recvTS << " ==> rtt: " << rtt << ", offset: " << offset << std::endl;
|
||||||
std::cerr << std::endl;
|
|
||||||
std::cerr << "\tpongTS: " << pongTS;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
std::cerr << "\trecvTS: " << recvTS;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
std::cerr << "\t ==> rtt: " << rtt;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
std::cerr << "\t ==> offset: " << offset;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
storePongResult(pong->PeerId(), pong->mSeqNo, pingTS, rtt, offset);
|
storePongResult(pong->PeerId(), pong->mSeqNo, recvTS, rtt, offset);
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -333,6 +310,7 @@ int p3rtt::storePingAttempt(const RsPeerId& id, double ts, uint32_t seqno)
|
|||||||
/* find corresponding local data */
|
/* find corresponding local data */
|
||||||
RttPeerInfo *peerInfo = locked_GetPeerInfo(id);
|
RttPeerInfo *peerInfo = locked_GetPeerInfo(id);
|
||||||
|
|
||||||
|
std::cerr << "Delay since previous ping attempt: " << ts - peerInfo->mCurrentPingTS << std::endl;
|
||||||
peerInfo->mCurrentPingTS = ts;
|
peerInfo->mCurrentPingTS = ts;
|
||||||
peerInfo->mCurrentPingCounter = seqno;
|
peerInfo->mCurrentPingCounter = seqno;
|
||||||
|
|
||||||
@ -349,7 +327,7 @@ int p3rtt::storePingAttempt(const RsPeerId& id, double ts, uint32_t seqno)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
int p3rtt::storePongResult(const RsPeerId& id, uint32_t counter, double ts, double rtt, double offset)
|
int p3rtt::storePongResult(const RsPeerId& id, uint32_t counter, double recv_ts, double rtt, double offset)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mRttMtx); /****** LOCKED MUTEX *******/
|
RsStackMutex stack(mRttMtx); /****** LOCKED MUTEX *******/
|
||||||
|
|
||||||
@ -366,8 +344,10 @@ int p3rtt::storePongResult(const RsPeerId& id, uint32_t counter, double ts, doub
|
|||||||
{
|
{
|
||||||
peerInfo->mCurrentPongRecvd = true;
|
peerInfo->mCurrentPongRecvd = true;
|
||||||
}
|
}
|
||||||
|
if(!peerInfo->mPongResults.empty())
|
||||||
|
std::cerr << "Delay since last pong: " << recv_ts - peerInfo->mPongResults.back().mTS << std::endl;
|
||||||
|
|
||||||
peerInfo->mPongResults.push_back(RsRttPongResult(ts, rtt, offset));
|
peerInfo->mPongResults.push_back(RsRttPongResult(recv_ts, rtt, offset));
|
||||||
|
|
||||||
|
|
||||||
while(peerInfo->mPongResults.size() > MAX_PONG_RESULTS)
|
while(peerInfo->mPongResults.size() > MAX_PONG_RESULTS)
|
||||||
|
@ -84,7 +84,7 @@ virtual bool recvItem(RsItem *item); // Overloaded from p3FastService.
|
|||||||
int handlePong(RsItem *item);
|
int handlePong(RsItem *item);
|
||||||
|
|
||||||
int storePingAttempt(const RsPeerId& id, double ts, uint32_t mCounter);
|
int storePingAttempt(const RsPeerId& id, double ts, uint32_t mCounter);
|
||||||
int storePongResult(const RsPeerId& id, uint32_t counter, double ts, double rtt, double offset);
|
int storePongResult(const RsPeerId& id, uint32_t counter, double recv_ts, double rtt, double offset);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
Loading…
Reference in New Issue
Block a user