blob: b0d734bf29e44ade199719361c024eaa1cc58218 [file] [log] [blame]
isheriff00cc0452016-06-08 07:24:211/*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef WEBRTC_MODULES_RTP_RTCP_SOURCE_PLAYOUT_DELAY_ORACLE_H_
12#define WEBRTC_MODULES_RTP_RTCP_SOURCE_PLAYOUT_DELAY_ORACLE_H_
13
pbos67d12ed2017-01-02 16:42:3214#include <stdint.h>
15
isheriff00cc0452016-06-08 07:24:2116#include "webrtc/modules/include/module_common_types.h"
17#include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h"
Edward Lemur76de83e2017-07-06 17:44:3418#include "webrtc/rtc_base/criticalsection.h"
19#include "webrtc/rtc_base/thread_annotations.h"
isheriff00cc0452016-06-08 07:24:2120
21namespace webrtc {
22
23// This class tracks the application requests to limit minimum and maximum
24// playout delay and makes a decision on whether the current RTP frame
25// should include the playout out delay extension header.
26//
27// Playout delay can be defined in terms of capture and render time as follows:
28//
29// Render time = Capture time in receiver time + playout delay
30//
31// The application specifies a minimum and maximum limit for the playout delay
32// which are both communicated to the receiver and the receiver can adapt
33// the playout delay within this range based on observed network jitter.
34class PlayoutDelayOracle {
35 public:
36 PlayoutDelayOracle();
37 ~PlayoutDelayOracle();
38
39 // Returns true if the current frame should include the playout delay
40 // extension
41 bool send_playout_delay() const {
42 rtc::CritScope lock(&crit_sect_);
43 return send_playout_delay_;
44 }
45
Danil Chapovalov812fea52016-09-07 11:29:4746 // Returns current playout delay.
47 PlayoutDelay playout_delay() const {
isheriff338a67c2016-06-14 17:55:3648 rtc::CritScope lock(&crit_sect_);
Danil Chapovalov812fea52016-09-07 11:29:4749 return playout_delay_;
isheriff00cc0452016-06-08 07:24:2150 }
51
52 // Updates the application requested playout delay, current ssrc
53 // and the current sequence number.
54 void UpdateRequest(uint32_t ssrc,
55 PlayoutDelay playout_delay,
56 uint16_t seq_num);
57
58 void OnReceivedRtcpReportBlocks(const ReportBlockList& report_blocks);
59
60 private:
isheriff338a67c2016-06-14 17:55:3661 // The playout delay information is updated from the encoder thread(s).
isheriff00cc0452016-06-08 07:24:2162 // The sequence number feedback is updated from the worker thread.
isheriff338a67c2016-06-14 17:55:3663 // Guards access to data across multiple threads.
isheriff00cc0452016-06-08 07:24:2164 rtc::CriticalSection crit_sect_;
65 // The current highest sequence number on which playout delay has been sent.
danilchapc4ae80f2017-09-07 14:53:4566 int64_t high_sequence_number_ RTC_GUARDED_BY(crit_sect_);
isheriff00cc0452016-06-08 07:24:2167 // Indicates whether the playout delay should go on the next frame.
danilchapc4ae80f2017-09-07 14:53:4568 bool send_playout_delay_ RTC_GUARDED_BY(crit_sect_);
isheriff00cc0452016-06-08 07:24:2169 // Sender ssrc.
danilchapc4ae80f2017-09-07 14:53:4570 uint32_t ssrc_ RTC_GUARDED_BY(crit_sect_);
isheriff00cc0452016-06-08 07:24:2171 // Sequence number unwrapper.
danilchapc4ae80f2017-09-07 14:53:4572 SequenceNumberUnwrapper unwrapper_ RTC_GUARDED_BY(crit_sect_);
Danil Chapovalov812fea52016-09-07 11:29:4773 // Playout delay values on the next frame if |send_playout_delay_| is set.
danilchapc4ae80f2017-09-07 14:53:4574 PlayoutDelay playout_delay_ RTC_GUARDED_BY(crit_sect_);
isheriff00cc0452016-06-08 07:24:2175
76 RTC_DISALLOW_COPY_AND_ASSIGN(PlayoutDelayOracle);
77};
78
79} // namespace webrtc
80
81#endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_PLAYOUT_DELAY_ORACLE_H_