OLD | NEW |
---|---|
(Empty) | |
1 /* | |
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 | |
14 #include "webrtc/base/basictypes.h" | |
15 #include "webrtc/base/criticalsection.h" | |
16 #include "webrtc/base/thread_checker.h" | |
17 #include "webrtc/base/thread_annotations.h" | |
18 #include "webrtc/modules/include/module_common_types.h" | |
19 #include "webrtc/modules/rtp_rtcp/include/rtp_rtcp_defines.h" | |
20 | |
21 namespace 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. | |
34 class 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 | |
46 // Returns current minimum playout delay in milliseconds. | |
47 int min_playout_delay_ms() const { | |
48 RTC_DCHECK(thread_checker_.CalledOnValidThread()); | |
49 return min_playout_delay_ms_; | |
50 } | |
51 | |
52 // Returns current maximum playout delay in milliseconds. | |
53 int max_playout_delay_ms() const { | |
54 RTC_DCHECK(thread_checker_.CalledOnValidThread()); | |
55 return max_playout_delay_ms_; | |
56 } | |
57 | |
58 // Updates the application requested playout delay, current ssrc | |
59 // and the current sequence number. | |
60 void UpdateRequest(uint32_t ssrc, | |
61 PlayoutDelay playout_delay, | |
62 uint16_t seq_num); | |
63 | |
64 void OnReceivedRtcpReceiverReport(const ReportBlockList& report_blocks); | |
65 | |
66 private: | |
67 // The playout delay information is updated from the encoder thread or | |
68 // a thread controlled by application in case of external encoder. | |
69 // The sequence number feedback is updated from the worker thread. | |
70 // Guards access to data across the two threads. | |
71 rtc::CriticalSection crit_sect_; | |
72 // The current highest sequence number on which playout delay has been sent. | |
73 int64_t high_sequence_number_ GUARDED_BY(crit_sect_); | |
74 // Indicates whether the playout delay should go on the next frame. | |
75 bool send_playout_delay_ GUARDED_BY(crit_sect_); | |
76 // Sender ssrc. | |
77 uint32_t ssrc_ GUARDED_BY(crit_sect_); | |
78 | |
79 // Data in this section is accessed on the sending/encoder thread alone. | |
80 rtc::ThreadChecker thread_checker_; | |
81 // Sequence number unwrapper. | |
82 SequenceNumberUnwrapper unwrapper_; | |
danilchap
2016/06/02 12:12:34
SequenceNumberUnwrapper unwrapper_ ACCESS_ON(threa
Irfan
2016/06/02 18:15:52
Done.
| |
83 // Min playout delay value on the next frame if |send_playout_delay_| is set. | |
84 int min_playout_delay_ms_; | |
85 // Max playout delay value on the next frame if |send_playout_delay_| is set. | |
86 int max_playout_delay_ms_; | |
87 | |
88 RTC_DISALLOW_COPY_AND_ASSIGN(PlayoutDelayOracle); | |
89 }; | |
90 | |
91 } // namespace webrtc | |
92 | |
93 #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_PLAYOUT_DELAY_ORACLE_H_ | |
OLD | NEW |