OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2013 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 #include "webrtc/base/checks.h" | 11 #include "webrtc/base/checks.h" |
12 #include "webrtc/base/logging.h" | 12 #include "webrtc/base/logging.h" |
13 #include "webrtc/base/trace_event.h" | 13 #include "webrtc/base/trace_event.h" |
14 #include "webrtc/common_types.h" | 14 #include "webrtc/common_types.h" |
15 #include "webrtc/common_video/libyuv/include/webrtc_libyuv.h" | 15 #include "webrtc/common_video/libyuv/include/webrtc_libyuv.h" |
16 #include "webrtc/modules/video_coding/include/video_codec_interface.h" | 16 #include "webrtc/modules/video_coding/include/video_codec_interface.h" |
17 #include "webrtc/modules/video_coding/encoded_frame.h" | 17 #include "webrtc/modules/video_coding/encoded_frame.h" |
18 #include "webrtc/modules/video_coding/jitter_buffer.h" | 18 #include "webrtc/modules/video_coding/jitter_buffer.h" |
19 #include "webrtc/modules/video_coding/packet.h" | 19 #include "webrtc/modules/video_coding/packet.h" |
20 #include "webrtc/modules/video_coding/video_coding_impl.h" | 20 #include "webrtc/modules/video_coding/video_coding_impl.h" |
21 #include "webrtc/system_wrappers/include/clock.h" | 21 #include "webrtc/system_wrappers/include/clock.h" |
22 | 22 |
23 // #define DEBUG_DECODER_BIT_STREAM | 23 // #define DEBUG_DECODER_BIT_STREAM |
24 | 24 |
25 namespace webrtc { | 25 namespace webrtc { |
26 namespace vcm { | 26 namespace vcm { |
27 | 27 |
28 VideoReceiver::VideoReceiver(Clock* clock, EventFactory* event_factory) | 28 VideoReceiver::VideoReceiver(Clock* clock, |
| 29 EventFactory* event_factory, |
| 30 NackSender* nack_sender, |
| 31 KeyFrameRequestSender* keyframe_request_sender) |
29 : clock_(clock), | 32 : clock_(clock), |
30 process_crit_sect_(CriticalSectionWrapper::CreateCriticalSection()), | 33 process_crit_sect_(CriticalSectionWrapper::CreateCriticalSection()), |
31 _receiveCritSect(CriticalSectionWrapper::CreateCriticalSection()), | 34 _receiveCritSect(CriticalSectionWrapper::CreateCriticalSection()), |
32 _timing(clock_), | 35 _timing(clock_), |
33 _receiver(&_timing, clock_, event_factory), | 36 _receiver(&_timing, |
| 37 clock_, |
| 38 event_factory, |
| 39 nack_sender, |
| 40 keyframe_request_sender), |
34 _decodedFrameCallback(&_timing, clock_), | 41 _decodedFrameCallback(&_timing, clock_), |
35 _frameTypeCallback(NULL), | 42 _frameTypeCallback(NULL), |
36 _receiveStatsCallback(NULL), | 43 _receiveStatsCallback(NULL), |
37 _decoderTimingCallback(NULL), | 44 _decoderTimingCallback(NULL), |
38 _packetRequestCallback(NULL), | 45 _packetRequestCallback(NULL), |
39 render_buffer_callback_(NULL), | 46 render_buffer_callback_(NULL), |
40 _decoder(NULL), | 47 _decoder(NULL), |
41 #ifdef DEBUG_DECODER_BIT_STREAM | 48 #ifdef DEBUG_DECODER_BIT_STREAM |
42 _bitStreamBeforeDecoder(NULL), | 49 _bitStreamBeforeDecoder(NULL), |
43 #endif | 50 #endif |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
103 _keyRequestTimer.Processed(); | 110 _keyRequestTimer.Processed(); |
104 bool request_key_frame = false; | 111 bool request_key_frame = false; |
105 { | 112 { |
106 CriticalSectionScoped cs(process_crit_sect_.get()); | 113 CriticalSectionScoped cs(process_crit_sect_.get()); |
107 request_key_frame = _scheduleKeyRequest && _frameTypeCallback != NULL; | 114 request_key_frame = _scheduleKeyRequest && _frameTypeCallback != NULL; |
108 } | 115 } |
109 if (request_key_frame) | 116 if (request_key_frame) |
110 RequestKeyFrame(); | 117 RequestKeyFrame(); |
111 } | 118 } |
112 | 119 |
| 120 if (_receiver.TimeUntilNextProcess() == 0) { |
| 121 _receiver.Process(); |
| 122 } |
| 123 |
113 // Packet retransmission requests | 124 // Packet retransmission requests |
114 // TODO(holmer): Add API for changing Process interval and make sure it's | 125 // TODO(holmer): Add API for changing Process interval and make sure it's |
115 // disabled when NACK is off. | 126 // disabled when NACK is off. |
116 if (_retransmissionTimer.TimeUntilProcess() == 0) { | 127 if (_retransmissionTimer.TimeUntilProcess() == 0) { |
117 _retransmissionTimer.Processed(); | 128 _retransmissionTimer.Processed(); |
118 bool callback_registered = false; | 129 bool callback_registered = false; |
119 uint16_t length; | 130 uint16_t length; |
120 { | 131 { |
121 CriticalSectionScoped cs(process_crit_sect_.get()); | 132 CriticalSectionScoped cs(process_crit_sect_.get()); |
122 length = max_nack_list_size_; | 133 length = max_nack_list_size_; |
(...skipping 20 matching lines...) Expand all Loading... |
143 int64_t VideoReceiver::TimeUntilNextProcess() { | 154 int64_t VideoReceiver::TimeUntilNextProcess() { |
144 int64_t timeUntilNextProcess = _receiveStatsTimer.TimeUntilProcess(); | 155 int64_t timeUntilNextProcess = _receiveStatsTimer.TimeUntilProcess(); |
145 if (_receiver.NackMode() != kNoNack) { | 156 if (_receiver.NackMode() != kNoNack) { |
146 // We need a Process call more often if we are relying on | 157 // We need a Process call more often if we are relying on |
147 // retransmissions | 158 // retransmissions |
148 timeUntilNextProcess = | 159 timeUntilNextProcess = |
149 VCM_MIN(timeUntilNextProcess, _retransmissionTimer.TimeUntilProcess()); | 160 VCM_MIN(timeUntilNextProcess, _retransmissionTimer.TimeUntilProcess()); |
150 } | 161 } |
151 timeUntilNextProcess = | 162 timeUntilNextProcess = |
152 VCM_MIN(timeUntilNextProcess, _keyRequestTimer.TimeUntilProcess()); | 163 VCM_MIN(timeUntilNextProcess, _keyRequestTimer.TimeUntilProcess()); |
| 164 timeUntilNextProcess = |
| 165 VCM_MIN(timeUntilNextProcess, _receiver.TimeUntilNextProcess()); |
153 | 166 |
154 return timeUntilNextProcess; | 167 return timeUntilNextProcess; |
155 } | 168 } |
156 | 169 |
157 int32_t VideoReceiver::SetReceiveChannelParameters(int64_t rtt) { | 170 int32_t VideoReceiver::SetReceiveChannelParameters(int64_t rtt) { |
158 CriticalSectionScoped receiveCs(_receiveCritSect); | 171 CriticalSectionScoped receiveCs(_receiveCritSect); |
159 _receiver.UpdateRtt(rtt); | 172 _receiver.UpdateRtt(rtt); |
160 return 0; | 173 return 0; |
161 } | 174 } |
162 | 175 |
(...skipping 364 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
527 } | 540 } |
528 | 541 |
529 void VideoReceiver::RegisterPreDecodeImageCallback( | 542 void VideoReceiver::RegisterPreDecodeImageCallback( |
530 EncodedImageCallback* observer) { | 543 EncodedImageCallback* observer) { |
531 CriticalSectionScoped cs(_receiveCritSect); | 544 CriticalSectionScoped cs(_receiveCritSect); |
532 pre_decode_image_callback_ = observer; | 545 pre_decode_image_callback_ = observer; |
533 } | 546 } |
534 | 547 |
535 } // namespace vcm | 548 } // namespace vcm |
536 } // namespace webrtc | 549 } // namespace webrtc |
OLD | NEW |