Implement GetRxAvailable ()
This commit is contained in:
@@ -78,7 +78,8 @@ TcpSocket::GetTypeId ()
|
||||
m_nextRxSequence (0),
|
||||
m_pendingData (0),
|
||||
m_rtt (0),
|
||||
m_lastMeasuredRtt (Seconds(0.0))
|
||||
m_lastMeasuredRtt (Seconds(0.0)),
|
||||
m_rxAvailable (0)
|
||||
{
|
||||
NS_LOG_FUNCTION (this);
|
||||
|
||||
@@ -122,7 +123,8 @@ TcpSocket::TcpSocket(const TcpSocket& sock)
|
||||
m_rtt (0),
|
||||
m_lastMeasuredRtt (Seconds(0.0)),
|
||||
m_cnTimeout (sock.m_cnTimeout),
|
||||
m_cnCount (sock.m_cnCount)
|
||||
m_cnCount (sock.m_cnCount),
|
||||
m_rxAvailable (0)
|
||||
{
|
||||
NS_LOG_FUNCTION_NOARGS ();
|
||||
NS_LOG_LOGIC("Invoked the copy constructor");
|
||||
@@ -450,9 +452,10 @@ TcpSocket::Recv (uint32_t maxSize, uint32_t flags)
|
||||
return 0;
|
||||
}
|
||||
Ptr<Packet> p = m_deliveryQueue.front ();
|
||||
if (p->GetSize() <= maxSize)
|
||||
if (p->GetSize () <= maxSize)
|
||||
{
|
||||
m_deliveryQueue.pop ();
|
||||
m_rxAvailable -= p->GetSize ();
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -461,6 +464,14 @@ TcpSocket::Recv (uint32_t maxSize, uint32_t flags)
|
||||
return p;
|
||||
}
|
||||
|
||||
uint32_t
|
||||
TcpSocket::GetRxAvailable (void) const
|
||||
{
|
||||
// We separately maintain this state to avoid walking the queue
|
||||
// every time this might be called
|
||||
return m_rxAvailable;
|
||||
}
|
||||
|
||||
void
|
||||
TcpSocket::ForwardUp (Ptr<Packet> packet, Ipv4Address ipv4, uint16_t port)
|
||||
{
|
||||
@@ -979,6 +990,7 @@ void TcpSocket::NewRx (Ptr<Packet> p,
|
||||
tag.SetAddress (fromAddress);
|
||||
p->AddTag (tag);
|
||||
m_deliveryQueue.push (p);
|
||||
m_rxAvailable += p->GetSize ();
|
||||
NotifyDataRecv ();
|
||||
if (m_closeNotified)
|
||||
{
|
||||
@@ -1035,6 +1047,7 @@ void TcpSocket::NewRx (Ptr<Packet> p,
|
||||
tag.SetAddress (fromAddress);
|
||||
p1->AddTag (tag);
|
||||
m_deliveryQueue.push (p1);
|
||||
m_rxAvailable += p->GetSize ();
|
||||
NotifyDataRecv ();
|
||||
|
||||
NS_LOG_LOGIC ("TcpSocket " << this << " adv rxseq1 by " << s1 );
|
||||
|
||||
@@ -71,6 +71,7 @@ public:
|
||||
virtual int Listen(uint32_t queueLimit);
|
||||
|
||||
virtual Ptr<Packet> Recv (uint32_t maxSize, uint32_t flags);
|
||||
virtual uint32_t GetRxAvailable (void) const;
|
||||
|
||||
private:
|
||||
friend class Tcp;
|
||||
@@ -175,6 +176,7 @@ private:
|
||||
|
||||
// Temporary queue for delivering data to application
|
||||
std::queue<Ptr<Packet> > m_deliveryQueue;
|
||||
uint32_t m_rxAvailable;
|
||||
};
|
||||
|
||||
}//namespace ns3
|
||||
|
||||
@@ -40,7 +40,8 @@ UdpSocket::UdpSocket ()
|
||||
m_errno (ERROR_NOTERROR),
|
||||
m_shutdownSend (false),
|
||||
m_shutdownRecv (false),
|
||||
m_connected (false)
|
||||
m_connected (false),
|
||||
m_rxAvailable (0)
|
||||
{
|
||||
NS_LOG_FUNCTION_NOARGS ();
|
||||
}
|
||||
@@ -333,9 +334,10 @@ UdpSocket::Recv (uint32_t maxSize, uint32_t flags)
|
||||
return 0;
|
||||
}
|
||||
Ptr<Packet> p = m_deliveryQueue.front ();
|
||||
if (p->GetSize() <= maxSize)
|
||||
if (p->GetSize () <= maxSize)
|
||||
{
|
||||
m_deliveryQueue.pop ();
|
||||
m_rxAvailable -= p->GetSize ();
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -344,6 +346,14 @@ UdpSocket::Recv (uint32_t maxSize, uint32_t flags)
|
||||
return p;
|
||||
}
|
||||
|
||||
uint32_t
|
||||
UdpSocket::GetRxAvailable (void) const
|
||||
{
|
||||
// We separately maintain this state to avoid walking the queue
|
||||
// every time this might be called
|
||||
return m_rxAvailable;
|
||||
}
|
||||
|
||||
void
|
||||
UdpSocket::ForwardUp (Ptr<Packet> packet, Ipv4Address ipv4, uint16_t port)
|
||||
{
|
||||
@@ -358,6 +368,7 @@ UdpSocket::ForwardUp (Ptr<Packet> packet, Ipv4Address ipv4, uint16_t port)
|
||||
tag.SetAddress (address);
|
||||
packet->AddTag (tag);
|
||||
m_deliveryQueue.push (packet);
|
||||
m_rxAvailable += packet->GetSize ();
|
||||
NotifyDataRecv ();
|
||||
}
|
||||
|
||||
@@ -410,12 +421,16 @@ void UdpSocketTest::ReceivePacket2 (Ptr<Socket> socket, Ptr<Packet> packet, cons
|
||||
|
||||
void UdpSocketTest::ReceivePkt (Ptr<Socket> socket)
|
||||
{
|
||||
uint32_t availableData = socket->GetRxAvailable ();
|
||||
m_receivedPacket = socket->Recv (std::numeric_limits<uint32_t>::max(), 0);
|
||||
NS_ASSERT (availableData == m_receivedPacket->GetSize ());
|
||||
}
|
||||
|
||||
void UdpSocketTest::ReceivePkt2 (Ptr<Socket> socket)
|
||||
{
|
||||
uint32_t availableData = socket->GetRxAvailable ();
|
||||
m_receivedPacket2 = socket->Recv (std::numeric_limits<uint32_t>::max(), 0);
|
||||
NS_ASSERT (availableData == m_receivedPacket2->GetSize ());
|
||||
}
|
||||
|
||||
bool
|
||||
|
||||
@@ -58,6 +58,7 @@ public:
|
||||
virtual int SendTo(const Address &address,Ptr<Packet> p);
|
||||
|
||||
virtual Ptr<Packet> Recv (uint32_t maxSize, uint32_t flags);
|
||||
virtual uint32_t GetRxAvailable (void) const;
|
||||
|
||||
private:
|
||||
friend class Udp;
|
||||
@@ -82,6 +83,7 @@ private:
|
||||
bool m_connected;
|
||||
|
||||
std::queue<Ptr<Packet> > m_deliveryQueue;
|
||||
uint32_t m_rxAvailable;
|
||||
};
|
||||
|
||||
}//namespace ns3
|
||||
|
||||
Reference in New Issue
Block a user