summaryrefslogtreecommitdiffstats
path: root/src/rtcpscheduler.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/rtcpscheduler.h')
-rw-r--r--src/rtcpscheduler.h183
1 files changed, 183 insertions, 0 deletions
diff --git a/src/rtcpscheduler.h b/src/rtcpscheduler.h
new file mode 100644
index 0000000..e5736a3
--- /dev/null
+++ b/src/rtcpscheduler.h
@@ -0,0 +1,183 @@
+/*
+
+ This file is a part of JRTPLIB
+ Copyright (c) 1999-2007 Jori Liesenborgs
+
+ Contact: jori.liesenborgs@gmail.com
+
+ This library was developed at the "Expertisecentrum Digitale 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 rtcpscheduler.h
+ */
+
+#ifndef RTCPSCHEDULER_H
+
+#define RTCPSCHEDULER_H
+
+#include "rtpconfig.h"
+#include "rtptimeutilities.h"
+#include "rtprandom.h"
+
+class RTCPCompoundPacket;
+class RTPPacket;
+class RTPSources;
+
+/** Describes parameters used by the RTCPScheduler class. */
+class RTCPSchedulerParams
+{
+public:
+ RTCPSchedulerParams();
+ ~RTCPSchedulerParams();
+
+ /** Sets the RTCP bandwidth to be used to \c bw (in bytes per second). */
+ int SetRTCPBandwidth(double bw);
+
+ /** Returns the used RTCP bandwidth in bytes per second (default is 1000). */
+ double GetRTCPBandwidth() const { return bandwidth; }
+
+ /** Sets the fraction of the RTCP bandwidth reserved for senders to \c fraction. */
+ int SetSenderBandwidthFraction(double fraction);
+
+ /** Returns the fraction of the RTCP bandwidth reserved for senders (default is 25%). */
+ double GetSenderBandwidthFraction() const { return senderfraction; }
+
+ /** Sets the minimum (deterministic) interval between RTCP compound packets to \c t. */
+ int SetMinimumTransmissionInterval(const RTPTime &t);
+
+ /** Returns the minimum RTCP transmission interval (default is 5 seconds). */
+ RTPTime GetMinimumTransmissionInterval() const { return mininterval; }
+
+ /** If \c usehalf is \c true, only use half the minimum interval before sending the first RTCP compound packet. */
+ void SetUseHalfAtStartup(bool usehalf) { usehalfatstartup = usehalf; }
+
+ /** Returns \c true if only half the minimum interval should be used before sending the first RTCP compound packet
+ * (defualt is \c true).
+ */
+ bool GetUseHalfAtStartup() const { return usehalfatstartup; }
+
+ /** If \c v is \c true, the scheduler will schedule a BYE packet to be sent immediately if allowed. */
+ void SetRequestImmediateBYE(bool v) { immediatebye = v; }
+
+ /** Returns if the scheduler will schedule a BYE packet to be sent immediately if allowed
+ * (default is \c true).
+ */
+ bool GetRequestImmediateBYE() const { return immediatebye; }
+private:
+ double bandwidth;
+ double senderfraction;
+ RTPTime mininterval;
+ bool usehalfatstartup;
+ bool immediatebye;
+};
+
+/** This class determines when RTCP compound packets should be sent. */
+class RTCPScheduler
+{
+public:
+ /** Creates an instance which will use the source table RTPSources to determine when RTCP compound
+ * packets should be scheduled.
+ * Creates an instance which will use the source table RTPSources to determine when RTCP compound
+ * packets should be scheduled. Note that for correct operation the \c sources instance should have information
+ * about the own SSRC (added by RTPSources::CreateOwnSSRC).
+ */
+ RTCPScheduler(RTPSources &sources);
+ ~RTCPScheduler();
+
+ /** Resets the scheduler. */
+ void Reset();
+
+ /** Sets the scheduler parameters to be used to \c params. */
+ void SetParameters(const RTCPSchedulerParams &params) { schedparams = params; }
+
+ /** Returns the currently used scheduler parameters. */
+ RTCPSchedulerParams GetParameters() const { return schedparams; }
+
+ /** Sets the header overhead from underlying protocols (for example UDP and IP) to \c numbytes. */
+ void SetHeaderOverhead(size_t numbytes) { headeroverhead = numbytes; }
+
+ /** Returns the currently used header overhead. */
+ size_t GetHeaderOverhead() const { return headeroverhead; }
+
+ /** For each incoming RTCP compound packet, this function has to be called for the scheduler to work correctly. */
+ void AnalyseIncoming(RTCPCompoundPacket &rtcpcomppack);
+
+ /** For each outgoing RTCP compound packet, this function has to be called for the scheduler to work correctly. */
+ void AnalyseOutgoing(RTCPCompoundPacket &rtcpcomppack);
+
+ /** This function has to be called each time a member times out or sends a BYE packet. */
+ void ActiveMemberDecrease();
+
+ /** Asks the scheduler to schedule an RTCP compound packet containing a BYE packetl; the compound packet
+ * has size \c packetsize.
+ */
+ void ScheduleBYEPacket(size_t packetsize);
+
+ /** Returns the delay after which an RTCP compound will possibly have to be sent.
+ * Returns the delay after which an RTCP compound will possibly have to be sent. The IsTime member function
+ * should be called afterwards to make sure that it actually is time to send an RTCP compound packet.
+ */
+ RTPTime GetTransmissionDelay();
+
+ /** This function returns \c true if it's time to send an RTCP compound packet and \c false otherwise.
+ * This function returns \c true if it's time to send an RTCP compound packet and \c false otherwise.
+ * If the function returns \c true, it will also have calculated the next time at which a packet should
+ * be sent, so if it is called again right away, it will return \c false.
+ */
+ bool IsTime();
+
+ /** Calculates the deterministic interval at this time.
+ * Calculates the deterministic interval at this time. This is used - in combination with a certain multiplier -
+ * to time out members, senders etc.
+ */
+ RTPTime CalculateDeterministicInterval(bool sender = false);
+private:
+ void CalculateNextRTCPTime();
+ void PerformReverseReconsideration();
+ RTPTime CalculateBYETransmissionInterval();
+ RTPTime CalculateTransmissionInterval(bool sender);
+
+ RTPSources &sources;
+ RTCPSchedulerParams schedparams;
+ size_t headeroverhead;
+ size_t avgrtcppacksize;
+ bool hassentrtcp;
+ bool firstcall;
+ RTPTime nextrtcptime;
+ RTPTime prevrtcptime;
+ int pmembers;
+
+ // for BYE packet scheduling
+ bool byescheduled;
+ int byemembers,pbyemembers;
+ size_t avgbyepacketsize;
+ bool sendbyenow;
+
+ RTPRandom rtprand;
+};
+
+#endif // RTCPSCHEDULER_H
+