OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2015 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/audio/audio_receive_stream.h" | 11 #include "webrtc/audio/audio_receive_stream.h" |
12 | 12 |
13 #include <string> | 13 #include <string> |
14 #include <utility> | 14 #include <utility> |
15 | 15 |
16 #include "webrtc/audio_sink.h" | 16 #include "webrtc/audio_sink.h" |
17 #include "webrtc/audio/audio_state.h" | 17 #include "webrtc/audio/audio_state.h" |
18 #include "webrtc/audio/conversion.h" | 18 #include "webrtc/audio/conversion.h" |
19 #include "webrtc/base/checks.h" | 19 #include "webrtc/base/checks.h" |
20 #include "webrtc/base/logging.h" | 20 #include "webrtc/base/logging.h" |
21 #include "webrtc/base/timeutils.h" | |
21 #include "webrtc/modules/congestion_controller/include/congestion_controller.h" | 22 #include "webrtc/modules/congestion_controller/include/congestion_controller.h" |
22 #include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimat or.h" | 23 #include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimat or.h" |
23 #include "webrtc/system_wrappers/include/tick_util.h" | |
24 #include "webrtc/voice_engine/channel_proxy.h" | 24 #include "webrtc/voice_engine/channel_proxy.h" |
25 #include "webrtc/voice_engine/include/voe_base.h" | 25 #include "webrtc/voice_engine/include/voe_base.h" |
26 #include "webrtc/voice_engine/include/voe_codec.h" | 26 #include "webrtc/voice_engine/include/voe_codec.h" |
27 #include "webrtc/voice_engine/include/voe_neteq_stats.h" | 27 #include "webrtc/voice_engine/include/voe_neteq_stats.h" |
28 #include "webrtc/voice_engine/include/voe_rtp_rtcp.h" | 28 #include "webrtc/voice_engine/include/voe_rtp_rtcp.h" |
29 #include "webrtc/voice_engine/include/voe_video_sync.h" | 29 #include "webrtc/voice_engine/include/voe_video_sync.h" |
30 #include "webrtc/voice_engine/include/voe_volume_control.h" | 30 #include "webrtc/voice_engine/include/voe_volume_control.h" |
31 #include "webrtc/voice_engine/voice_engine_impl.h" | 31 #include "webrtc/voice_engine/voice_engine_impl.h" |
32 | 32 |
33 namespace webrtc { | 33 namespace webrtc { |
(...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
163 RTPHeader header; | 163 RTPHeader header; |
164 if (!rtp_header_parser_->Parse(packet, length, &header)) { | 164 if (!rtp_header_parser_->Parse(packet, length, &header)) { |
165 return false; | 165 return false; |
166 } | 166 } |
167 | 167 |
168 // Only forward if the parsed header has one of the headers necessary for | 168 // Only forward if the parsed header has one of the headers necessary for |
169 // bandwidth estimation. RTP timestamps has different rates for audio and | 169 // bandwidth estimation. RTP timestamps has different rates for audio and |
170 // video and shouldn't be mixed. | 170 // video and shouldn't be mixed. |
171 if (remote_bitrate_estimator_ && | 171 if (remote_bitrate_estimator_ && |
172 header.extension.hasTransportSequenceNumber) { | 172 header.extension.hasTransportSequenceNumber) { |
173 int64_t arrival_time_ms = TickTime::MillisecondTimestamp(); | 173 int64_t arrival_time_ms = rtc::Time64(); |
stefan-webrtc
2016/04/19 09:19:12
Is there a function with a better name? I'd prefer
nisse-webrtc
2016/04/19 12:19:25
There's another pending transition, I think. There
stefan-webrtc
2016/04/19 12:40:47
I'd prefer an int64_t TimeMilliseconds() and maybe
nisse-webrtc
2016/04/19 13:48:50
I think int64_t is enough, no need for templates.
| |
174 if (packet_time.timestamp >= 0) | 174 if (packet_time.timestamp >= 0) |
175 arrival_time_ms = (packet_time.timestamp + 500) / 1000; | 175 arrival_time_ms = (packet_time.timestamp + 500) / 1000; |
176 size_t payload_size = length - header.headerLength; | 176 size_t payload_size = length - header.headerLength; |
177 remote_bitrate_estimator_->IncomingPacket(arrival_time_ms, payload_size, | 177 remote_bitrate_estimator_->IncomingPacket(arrival_time_ms, payload_size, |
178 header, false); | 178 header, false); |
179 } | 179 } |
180 return true; | 180 return true; |
181 } | 181 } |
182 | 182 |
183 webrtc::AudioReceiveStream::Stats AudioReceiveStream::GetStats() const { | 183 webrtc::AudioReceiveStream::Stats AudioReceiveStream::GetStats() const { |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
240 | 240 |
241 VoiceEngine* AudioReceiveStream::voice_engine() const { | 241 VoiceEngine* AudioReceiveStream::voice_engine() const { |
242 internal::AudioState* audio_state = | 242 internal::AudioState* audio_state = |
243 static_cast<internal::AudioState*>(audio_state_.get()); | 243 static_cast<internal::AudioState*>(audio_state_.get()); |
244 VoiceEngine* voice_engine = audio_state->voice_engine(); | 244 VoiceEngine* voice_engine = audio_state->voice_engine(); |
245 RTC_DCHECK(voice_engine); | 245 RTC_DCHECK(voice_engine); |
246 return voice_engine; | 246 return voice_engine; |
247 } | 247 } |
248 } // namespace internal | 248 } // namespace internal |
249 } // namespace webrtc | 249 } // namespace webrtc |
OLD | NEW |