realtimenetprots/rtp/shimrtp/src/rtp/rtcp.cpp
author Petteri Saari <petteri.saari@digia.com>
Thu, 02 Dec 2010 15:23:48 +0200
branchMSRP_FrameWork
changeset 60 7634585a4347
parent 22 f1578314b8da
permissions -rw-r--r--
This release addresses the following: - Multiple concurrent file transfer bug fixes. i.e. one device is concurrently receiving multiple files from multiple devices

// 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 TUint RRtcpRRItem::SenderSSRC() const
	{
	__RTP_LOG(_L("RRtcpSRItem::SenderSSRC() ... "));
	return AboutSSRC();
	}
	

/******/
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;
	}