realtimenetprots/rtp/shimrtp/src/rtp/rtcp.cpp
changeset 0 307788aac0a8
child 20 a7d1e54a7332
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/realtimenetprots/rtp/shimrtp/src/rtp/rtcp.cpp	Tue Feb 02 01:03:15 2010 +0200
@@ -0,0 +1,143 @@
+// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// class for handling rtcp data
+// 
+//
+
+/**
+ @file
+*/
+ 
+#include <e32base.h>
+
+#include "rtcp.h"
+#include "rtcppacket.h"
+
+
+EXPORT_C RRtcpRRItem::RRtcpRRItem() :iPtr(NULL)
+	{}
+
+EXPORT_C TUint RRtcpRRItem::PacketsLost() const
+	{
+	__RTP_LOG(_L("RRtcpRRItem::PacketLost() ... "));
+	return iPtr->lost;
+	}
+
+EXPORT_C TUint RRtcpRRItem::AboutSSRC() const
+	{
+	__RTP_LOG(_L("RRtcpSRItem::AboutSSRC() ... "));
+	return iPtr->ssrc;
+	}
+
+EXPORT_C TUint RRtcpRRItem::FractionLost() const
+	{
+	__RTP_LOG(_L("RRtcpRRItem::FractionLost() ... "));
+	return iPtr->fraction;
+	}
+
+EXPORT_C TUint RRtcpRRItem::ExtendedHighestSequenceNumber() const
+	{
+	__RTP_LOG(_L("RRtcpSRItem::ExtendedHighestSequenceNumber() ... "));
+	return iPtr->last_seq;
+	}
+
+EXPORT_C TUint RRtcpRRItem::InterarrivalJitter() const
+	{
+	__RTP_LOG(_L("RRtcpSRItem::InterarrivalJitter() ... "));
+	return iPtr->jitter;
+	}
+
+EXPORT_C TUint RRtcpRRItem::LastSRTimestamp() const
+	{
+	__RTP_LOG(_L("RRtcpSRItem::LastSRTimeStamp() ... "));
+	return iPtr->lsr;
+	}
+
+EXPORT_C TUint RRtcpRRItem::DelaySinceLastSR() const
+	{
+	__RTP_LOG(_L("RRtcpRRItem::DelaySinceLastSR() ... "));
+	return iPtr->dlsr;
+	}
+
+
+/******/
+EXPORT_C RRtcpRRPart::RRtcpRRPart(TRtcpRRPart& aRR) :iRRPart(aRR)
+	{}
+
+EXPORT_C TInt RRtcpRRPart::Count() const
+	{
+	__RTP_LOG(_L("RRtcpRRPart::Count() ... "));
+	return iRRPart.iRRItems.Count();
+	}
+
+EXPORT_C TUint RRtcpRRPart::SenderSSRC() const
+	{
+	__RTP_LOG(_L("RRtcpRRPart::SenderSSRC() ... "));
+	return iRRPart.ssrc;
+	}
+
+EXPORT_C RRtcpRRItem RRtcpRRPart::operator[](TInt aIndex) const
+	{	
+	__RTP_LOG(_L("RRtcpRRItem::Operator[]() ... "));
+	RRtcpRRItem item;
+	item.iPtr = &iRRPart.iRRItems[aIndex];
+	return item;	
+	}
+
+/******/
+
+EXPORT_C RRtcpSRPart::RRtcpSRPart(TRtcpSRPart& aSr) :iSrPtr(aSr)
+	{}
+
+EXPORT_C void RRtcpSRPart::NTPTimestamp(TTime& aTime) const
+	{
+	__RTP_LOG(_L("RRtcpSRPart::NtpTimeStamp() ... "));
+	//_LIT(KNTPBaseTime,"190000101:000000");
+	TDateTime dateTime(1900,EJanuary,01,0,0,0,0);
+	TTime ntpBaseTime(dateTime); 
+	
+
+	//TTime ntpBaseTime(KNTPBaseTime);
+	aTime = (TUint64)(iSrPtr.ntp_sec * 1000000) + (TUint64) iSrPtr.ntp_frac;
+	aTime = aTime.Int64() + ntpBaseTime.Int64();
+	}
+	
+ // A New api added , for NtpTimeStamp
+EXPORT_C void RRtcpSRPart::NTPTimestamp(TUint32& aSec,TUint32& aFrac) const
+	{
+	__RTP_LOG(_L("RRtcpSRPart::NtpTimeStamp() ... "));
+	aSec = iSrPtr.ntp_sec;
+ 	aFrac = iSrPtr.ntp_frac;
+ 	}
+  
+EXPORT_C TUint RRtcpSRPart::RTPTimestamp() const
+	{
+	__RTP_LOG(_L("RRtcpSRPart::RtpTimeStamp() ... "));
+	return iSrPtr.rtp_ts;
+	}
+
+EXPORT_C TUint RRtcpSRPart::PacketCount() const
+	{
+	__RTP_LOG(_L("RRtcpSRPart::PacketCount() ... "));
+	return iSrPtr.psent;
+	}
+
+EXPORT_C TUint RRtcpSRPart::ByteCount() const
+	{
+	__RTP_LOG(_L("RRtcpSRPart::ByeCount() ... "));
+	return iSrPtr.osent;
+	}
+
+
+