| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |  This file is a part of JRTPLIB | 
					
						
							|  |  |  |  Copyright (c) 1999-2017 Jori Liesenborgs | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Contact: jori.liesenborgs@gmail.com | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  This library was developed at the Expertise Centre for Digital Media | 
					
						
							|  |  |  |  (http://www.edm.uhasselt.be), a research center of the Hasselt University
 | 
					
						
							|  |  |  |  (http://www.uhasselt.be). The library is based upon work done for
 | 
					
						
							|  |  |  |  my thesis at the School for Knowledge Technology (Belgium/The Netherlands). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Permission is hereby granted, free of charge, to any person obtaining a | 
					
						
							|  |  |  |  copy of this software and associated documentation files (the "Software"), | 
					
						
							|  |  |  |  to deal in the Software without restriction, including without limitation | 
					
						
							|  |  |  |  the rights to use, copy, modify, merge, publish, distribute, sublicense, | 
					
						
							|  |  |  |  and/or sell copies of the Software, and to permit persons to whom the | 
					
						
							|  |  |  |  Software is furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  The above copyright notice and this permission notice shall be included | 
					
						
							|  |  |  |  in all copies or substantial portions of the Software. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | 
					
						
							|  |  |  |  OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL | 
					
						
							|  |  |  |  THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | 
					
						
							|  |  |  |  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | 
					
						
							|  |  |  |  IN THE SOFTWARE. | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * \file rtcprrpacket.h | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef RTCPRRPACKET_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RTCPRRPACKET_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "rtpconfig.h"
 | 
					
						
							|  |  |  | #include "rtcppacket.h"
 | 
					
						
							|  |  |  | #include "rtpstructs.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-27 02:14:45 +01:00
										 |  |  | #include "rtpendian.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 13:49:21 +01:00
										 |  |  | #include "export.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-03 20:23:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | namespace qrtplib | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class RTCPCompoundPacket; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Describes an RTCP receiver report packet. */ | 
					
						
							| 
									
										
										
										
											2018-03-03 20:23:38 +01:00
										 |  |  | class QRTPLIB_API RTCPRRPacket: public RTCPPacket | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Creates an instance based on the data in \c data with length \c datalen.
 | 
					
						
							|  |  |  |      *  Creates an instance based on the data in \c data with length \c datalen. Since the \c data pointer | 
					
						
							|  |  |  |      *  is referenced inside the class (no copy of the data is made) one must make sure that the memory it points | 
					
						
							|  |  |  |      *  to is valid as long as the class instance exists. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     RTCPRRPacket(uint8_t *data, std::size_t datalen); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     ~RTCPRRPacket() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the SSRC of the participant who sent this packet. */ | 
					
						
							|  |  |  |     uint32_t GetSenderSSRC() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the number of reception report blocks present in this packet. */ | 
					
						
							|  |  |  |     int GetReceptionReportCount() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the SSRC of the reception report block described by \c index which may have a value
 | 
					
						
							|  |  |  |      *  from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetSSRC(int index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the `fraction lost' field of the reception report described by \c index which may have
 | 
					
						
							|  |  |  |      *  a value from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint8_t GetFractionLost(int index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the number of lost packets in the reception report block described by \c index which may have
 | 
					
						
							|  |  |  |      *  a value from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int32_t GetLostPacketCount(int index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the extended highest sequence number of the reception report block described by \c index which may have
 | 
					
						
							|  |  |  |      *  a value from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetExtendedHighestSequenceNumber(int index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the jitter field of the reception report block described by \c index which may have
 | 
					
						
							|  |  |  |      *  a value from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetJitter(int index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the LSR field of the reception report block described by \c index which may have
 | 
					
						
							|  |  |  |      *  a value from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetLSR(int index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the DLSR field of the reception report block described by \c index which may have
 | 
					
						
							|  |  |  |      *  a value from 0 to GetReceptionReportCount()-1 (note that no check is performed to see if \c index is | 
					
						
							|  |  |  |      *  valid). | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetDLSR(int index) const; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     RTCPReceiverReport *GotoReport(int index) const; | 
					
						
							| 
									
										
										
										
											2018-02-27 02:14:45 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     RTPEndian m_endian; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint32_t RTCPRRPacket::GetSenderSSRC() const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     uint32_t *ssrcptr = (uint32_t *) (data + sizeof(RTCPCommonHeader)); | 
					
						
							|  |  |  |     return m_endian.qToHost(*ssrcptr); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | inline int RTCPRRPacket::GetReceptionReportCount() const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPCommonHeader *hdr = (RTCPCommonHeader *) data; | 
					
						
							|  |  |  |     return ((int) hdr->count); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline RTCPReceiverReport *RTCPRRPacket::GotoReport(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     RTCPReceiverReport *r = (RTCPReceiverReport *) (data + sizeof(RTCPCommonHeader) + sizeof(uint32_t) + index * sizeof(RTCPReceiverReport)); | 
					
						
							|  |  |  |     return r; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint32_t RTCPRRPacket::GetSSRC(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     return m_endian.qToHost(r->ssrc); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint8_t RTCPRRPacket::GetFractionLost(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     return r->fractionlost; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline int32_t RTCPRRPacket::GetLostPacketCount(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     uint32_t count = ((uint32_t) r->packetslost[2]) | (((uint32_t) r->packetslost[1]) << 8) | (((uint32_t) r->packetslost[0]) << 16); | 
					
						
							|  |  |  |     if ((count & 0x00800000) != 0) // test for negative number
 | 
					
						
							|  |  |  |         count |= 0xFF000000; | 
					
						
							|  |  |  |     int32_t *count2 = (int32_t *) (&count); | 
					
						
							|  |  |  |     return (*count2); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint32_t RTCPRRPacket::GetExtendedHighestSequenceNumber(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     return m_endian.qToHost(r->exthighseqnr); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint32_t RTCPRRPacket::GetJitter(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     return m_endian.qToHost(r->jitter); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint32_t RTCPRRPacket::GetLSR(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     return m_endian.qToHost(r->lsr); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline uint32_t RTCPRRPacket::GetDLSR(int index) const | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     if (!knownformat) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     RTCPReceiverReport *r = GotoReport(index); | 
					
						
							|  |  |  |     return m_endian.qToHost(r->dlsr); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // end namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // RTCPRRPACKET_H
 | 
					
						
							|  |  |  | 
 |