mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-11-05 00:11:16 -05:00
365 lines
13 KiB
C++
365 lines
13 KiB
C++
/*
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
/**
|
|
* \file rtcppacketbuilder.h
|
|
*/
|
|
|
|
#ifndef RTCPPACKETBUILDER_H
|
|
|
|
#define RTCPPACKETBUILDER_H
|
|
|
|
#include "rtpconfig.h"
|
|
#include "rtptypes.h"
|
|
#include "rtperrors.h"
|
|
#include "rtcpsdesinfo.h"
|
|
#include "rtptimeutilities.h"
|
|
|
|
#include "export.h"
|
|
|
|
namespace qrtplib
|
|
{
|
|
|
|
class RTPSources;
|
|
class RTPPacketBuilder;
|
|
class RTCPScheduler;
|
|
class RTCPCompoundPacket;
|
|
class RTCPCompoundPacketBuilder;
|
|
|
|
/** This class can be used to build RTCP compound packets, on a higher level than the RTCPCompoundPacketBuilder.
|
|
* The class RTCPPacketBuilder can be used to build RTCP compound packets. This class is more high-level
|
|
* than the RTCPCompoundPacketBuilder class: it uses the information of an RTPPacketBuilder instance and of
|
|
* an RTPSources instance to automatically generate the next compound packet which should be sent. It also
|
|
* provides functions to determine when SDES items other than the CNAME item should be sent.
|
|
*/
|
|
class QRTPLIB_API RTCPPacketBuilder
|
|
{
|
|
public:
|
|
/** Creates an RTCPPacketBuilder instance.
|
|
* Creates an instance which will use the source table \c sources and the RTP packet builder
|
|
* \c rtppackbuilder to determine the information for the next RTCP compound packet. Optionally,
|
|
* the memory manager \c mgr can be installed.
|
|
*/
|
|
RTCPPacketBuilder(RTPSources &sources, RTPPacketBuilder &rtppackbuilder);
|
|
~RTCPPacketBuilder();
|
|
|
|
/** Initializes the builder.
|
|
* Initializes the builder to use the maximum allowed packet size \c maxpacksize, timestamp unit
|
|
* \c timestampunit and the SDES CNAME item specified by \c cname with length \c cnamelen.
|
|
* The timestamp unit is defined as a time interval divided by the timestamp interval corresponding to
|
|
* that interval: for 8000 Hz audio this would be 1/8000.
|
|
*/
|
|
int Init(std::size_t maxpacksize, double timestampunit, const void *cname, std::size_t cnamelen);
|
|
|
|
/** Cleans up the builder. */
|
|
void Destroy();
|
|
|
|
/** Sets the timestamp unit to be used to \c tsunit.
|
|
* Sets the timestamp unit to be used to \c tsunit. The timestamp unit is defined as a time interval
|
|
* divided by the timestamp interval corresponding to that interval: for 8000 Hz audio this would
|
|
* be 1/8000.
|
|
*/
|
|
int SetTimestampUnit(double tsunit)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
if (tsunit < 0)
|
|
return ERR_RTP_RTCPPACKETBUILDER_ILLEGALTIMESTAMPUNIT;
|
|
timestampunit = tsunit;
|
|
return 0;
|
|
}
|
|
|
|
/** Sets the maximum size allowed size of an RTCP compound packet to \c maxpacksize. */
|
|
int SetMaximumPacketSize(std::size_t maxpacksize)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
if (maxpacksize < RTP_MINPACKETSIZE)
|
|
return ERR_RTP_RTCPPACKETBUILDER_ILLEGALMAXPACKSIZE;
|
|
maxpacketsize = maxpacksize;
|
|
return 0;
|
|
}
|
|
|
|
/** This function allows you to inform RTCP packet builder about the delay between sampling the first
|
|
* sample of a packet and sending the packet.
|
|
* This function allows you to inform RTCP packet builder about the delay between sampling the first
|
|
* sample of a packet and sending the packet. This delay is taken into account when calculating the
|
|
* relation between RTP timestamp and wallclock time, used for inter-media synchronization.
|
|
*/
|
|
int SetPreTransmissionDelay(const RTPTime &delay)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
transmissiondelay = delay;
|
|
return 0;
|
|
}
|
|
|
|
/** Builds the next RTCP compound packet which should be sent and stores it in \c pack. */
|
|
int BuildNextPacket(RTCPCompoundPacket **pack);
|
|
|
|
/** Builds a BYE packet with reason for leaving specified by \c reason and length \c reasonlength.
|
|
* Builds a BYE packet with reason for leaving specified by \c reason and length \c reasonlength. If
|
|
* \c useSRifpossible is set to \c true, the RTCP compound packet will start with a sender report if
|
|
* allowed. Otherwise, a receiver report is used.
|
|
*/
|
|
int BuildBYEPacket(RTCPCompoundPacket **pack, const void *reason, std::size_t reasonlength, bool useSRifpossible = true);
|
|
|
|
/** Sets the RTCP interval for the SDES name item.
|
|
* After all possible sources in the source table have been processed, the class will check if other
|
|
* SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count
|
|
* is positive, an SDES name item will be added after the sources in the source table have been
|
|
* processed \c count times.
|
|
*/
|
|
void SetNameInterval(int count)
|
|
{
|
|
if (!init)
|
|
return;
|
|
interval_name = count;
|
|
}
|
|
|
|
/** Sets the RTCP interval for the SDES e-mail item.
|
|
* After all possible sources in the source table have been processed, the class will check if other
|
|
* SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count
|
|
* is positive, an SDES e-mail item will be added after the sources in the source table have been
|
|
* processed \c count times.
|
|
*/
|
|
void SetEMailInterval(int count)
|
|
{
|
|
if (!init)
|
|
return;
|
|
interval_email = count;
|
|
}
|
|
|
|
/** Sets the RTCP interval for the SDES location item.
|
|
* After all possible sources in the source table have been processed, the class will check if other
|
|
* SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count
|
|
* is positive, an SDES location item will be added after the sources in the source table have been
|
|
* processed \c count times.
|
|
*/
|
|
void SetLocationInterval(int count)
|
|
{
|
|
if (!init)
|
|
return;
|
|
interval_location = count;
|
|
}
|
|
|
|
/** Sets the RTCP interval for the SDES phone item.
|
|
* After all possible sources in the source table have been processed, the class will check if other
|
|
* SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count
|
|
* is positive, an SDES phone item will be added after the sources in the source table have been
|
|
* processed \c count times.
|
|
*/
|
|
void SetPhoneInterval(int count)
|
|
{
|
|
if (!init)
|
|
return;
|
|
interval_phone = count;
|
|
}
|
|
|
|
/** Sets the RTCP interval for the SDES tool item.
|
|
* After all possible sources in the source table have been processed, the class will check if other
|
|
* SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count
|
|
* is positive, an SDES tool item will be added after the sources in the source table have been
|
|
* processed \c count times.
|
|
*/
|
|
void SetToolInterval(int count)
|
|
{
|
|
if (!init)
|
|
return;
|
|
interval_tool = count;
|
|
}
|
|
|
|
/** Sets the RTCP interval for the SDES note item.
|
|
* After all possible sources in the source table have been processed, the class will check if other
|
|
* SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count
|
|
* is positive, an SDES note item will be added after the sources in the source table have been
|
|
* processed \c count times.
|
|
*/
|
|
void SetNoteInterval(int count)
|
|
{
|
|
if (!init)
|
|
return;
|
|
interval_note = count;
|
|
}
|
|
|
|
/** Sets the SDES name item for the local participant to the value \c s with length \c len. */
|
|
int SetLocalName(const void *s, std::size_t len)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
return ownsdesinfo.SetName((const uint8_t *) s, len);
|
|
}
|
|
|
|
/** Sets the SDES e-mail item for the local participant to the value \c s with length \c len. */
|
|
int SetLocalEMail(const void *s, std::size_t len)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
return ownsdesinfo.SetEMail((const uint8_t *) s, len);
|
|
}
|
|
|
|
/** Sets the SDES location item for the local participant to the value \c s with length \c len. */
|
|
int SetLocalLocation(const void *s, std::size_t len)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
return ownsdesinfo.SetLocation((const uint8_t *) s, len);
|
|
}
|
|
|
|
/** Sets the SDES phone item for the local participant to the value \c s with length \c len. */
|
|
int SetLocalPhone(const void *s, std::size_t len)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
return ownsdesinfo.SetPhone((const uint8_t *) s, len);
|
|
}
|
|
|
|
/** Sets the SDES tool item for the local participant to the value \c s with length \c len. */
|
|
int SetLocalTool(const void *s, std::size_t len)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
return ownsdesinfo.SetTool((const uint8_t *) s, len);
|
|
}
|
|
|
|
/** Sets the SDES note item for the local participant to the value \c s with length \c len. */
|
|
int SetLocalNote(const void *s, std::size_t len)
|
|
{
|
|
if (!init)
|
|
return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
|
|
return ownsdesinfo.SetNote((const uint8_t *) s, len);
|
|
}
|
|
|
|
/** Returns the own CNAME item with length \c len */
|
|
uint8_t *GetLocalCNAME(std::size_t *len) const
|
|
{
|
|
if (!init)
|
|
return 0;
|
|
return ownsdesinfo.GetCNAME(len);
|
|
}
|
|
private:
|
|
void ClearAllSourceFlags();
|
|
int FillInReportBlocks(RTCPCompoundPacketBuilder *pack, const RTPTime &curtime, int maxcount, bool *full, int *added, int *skipped, bool *atendoflist);
|
|
int FillInSDES(RTCPCompoundPacketBuilder *pack, bool *full, bool *processedall, int *added);
|
|
void ClearAllSDESFlags();
|
|
|
|
RTPSources &sources;
|
|
RTPPacketBuilder &rtppacketbuilder;
|
|
|
|
bool init;
|
|
std::size_t maxpacketsize;
|
|
double timestampunit;
|
|
bool firstpacket;
|
|
RTPTime prevbuildtime, transmissiondelay;
|
|
|
|
class RTCPSDESInfoInternal: public RTCPSDESInfo
|
|
{
|
|
public:
|
|
RTCPSDESInfoInternal()
|
|
{
|
|
ClearFlags();
|
|
}
|
|
void ClearFlags()
|
|
{
|
|
pname = false;
|
|
pemail = false;
|
|
plocation = false;
|
|
pphone = false;
|
|
ptool = false;
|
|
pnote = false;
|
|
}
|
|
bool ProcessedName() const
|
|
{
|
|
return pname;
|
|
}
|
|
bool ProcessedEMail() const
|
|
{
|
|
return pemail;
|
|
}
|
|
bool ProcessedLocation() const
|
|
{
|
|
return plocation;
|
|
}
|
|
bool ProcessedPhone() const
|
|
{
|
|
return pphone;
|
|
}
|
|
bool ProcessedTool() const
|
|
{
|
|
return ptool;
|
|
}
|
|
bool ProcessedNote() const
|
|
{
|
|
return pnote;
|
|
}
|
|
void SetProcessedName(bool v)
|
|
{
|
|
pname = v;
|
|
}
|
|
void SetProcessedEMail(bool v)
|
|
{
|
|
pemail = v;
|
|
}
|
|
void SetProcessedLocation(bool v)
|
|
{
|
|
plocation = v;
|
|
}
|
|
void SetProcessedPhone(bool v)
|
|
{
|
|
pphone = v;
|
|
}
|
|
void SetProcessedTool(bool v)
|
|
{
|
|
ptool = v;
|
|
}
|
|
void SetProcessedNote(bool v)
|
|
{
|
|
pnote = v;
|
|
}
|
|
private:
|
|
bool pname, pemail, plocation, pphone, ptool, pnote;
|
|
};
|
|
|
|
RTCPSDESInfoInternal ownsdesinfo;
|
|
int interval_name, interval_email, interval_location;
|
|
int interval_phone, interval_tool, interval_note;
|
|
bool doname, doemail, doloc, dophone, dotool, donote;
|
|
bool processingsdes;
|
|
|
|
int sdesbuildcount;
|
|
};
|
|
|
|
} // end namespace
|
|
|
|
#endif // RTCPPACKETBUILDER_H
|
|
|