OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2012 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 |
(...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
240 | 240 |
241 int target_rate_kbps_; | 241 int target_rate_kbps_; |
242 int bytes_remaining_; | 242 int bytes_remaining_; |
243 }; | 243 }; |
244 } // namespace paced_sender | 244 } // namespace paced_sender |
245 | 245 |
246 const int64_t PacedSender::kMaxQueueLengthMs = 2000; | 246 const int64_t PacedSender::kMaxQueueLengthMs = 2000; |
247 const float PacedSender::kDefaultPaceMultiplier = 2.5f; | 247 const float PacedSender::kDefaultPaceMultiplier = 2.5f; |
248 | 248 |
249 PacedSender::PacedSender(Clock* clock, PacketSender* packet_sender) | 249 PacedSender::PacedSender(Clock* clock, PacketSender* packet_sender) |
250 : PacedSender(clock, packet_sender, nullptr) {} | |
251 | |
252 PacedSender::PacedSender(Clock* clock, | |
253 PacketSender* packet_sender, | |
254 ProbeClusterCreatedObserver* cluster_created_observer) | |
250 : clock_(clock), | 255 : clock_(clock), |
251 packet_sender_(packet_sender), | 256 packet_sender_(packet_sender), |
252 alr_detector_(new AlrDetector()), | 257 alr_detector_(new AlrDetector()), |
253 critsect_(CriticalSectionWrapper::CreateCriticalSection()), | 258 critsect_(CriticalSectionWrapper::CreateCriticalSection()), |
254 paused_(false), | 259 paused_(false), |
255 media_budget_(new paced_sender::IntervalBudget(0)), | 260 media_budget_(new paced_sender::IntervalBudget(0)), |
256 padding_budget_(new paced_sender::IntervalBudget(0)), | 261 padding_budget_(new paced_sender::IntervalBudget(0)), |
257 prober_(new BitrateProber()), | 262 prober_(new BitrateProber(cluster_created_observer)), |
nisse-webrtc
2017/01/10 16:04:41
If this thing is owned by the PacedSender, which i
philipel
2017/01/11 09:03:33
I can't see how we could avoid using a callback in
| |
258 estimated_bitrate_bps_(0), | 263 estimated_bitrate_bps_(0), |
259 min_send_bitrate_kbps_(0u), | 264 min_send_bitrate_kbps_(0u), |
260 max_padding_bitrate_kbps_(0u), | 265 max_padding_bitrate_kbps_(0u), |
261 pacing_bitrate_kbps_(0), | 266 pacing_bitrate_kbps_(0), |
262 time_last_update_us_(clock->TimeInMicroseconds()), | 267 time_last_update_us_(clock->TimeInMicroseconds()), |
263 packets_(new paced_sender::PacketQueue(clock)), | 268 packets_(new paced_sender::PacketQueue(clock)), |
264 packet_counter_(0) { | 269 packet_counter_(0) { |
265 UpdateBudgetWithElapsedTime(kMinPacketLimitMs); | 270 UpdateBudgetWithElapsedTime(kMinPacketLimitMs); |
266 } | 271 } |
267 | 272 |
(...skipping 233 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
501 void PacedSender::UpdateBudgetWithElapsedTime(int64_t delta_time_ms) { | 506 void PacedSender::UpdateBudgetWithElapsedTime(int64_t delta_time_ms) { |
502 media_budget_->IncreaseBudget(delta_time_ms); | 507 media_budget_->IncreaseBudget(delta_time_ms); |
503 padding_budget_->IncreaseBudget(delta_time_ms); | 508 padding_budget_->IncreaseBudget(delta_time_ms); |
504 } | 509 } |
505 | 510 |
506 void PacedSender::UpdateBudgetWithBytesSent(size_t bytes_sent) { | 511 void PacedSender::UpdateBudgetWithBytesSent(size_t bytes_sent) { |
507 media_budget_->UseBudget(bytes_sent); | 512 media_budget_->UseBudget(bytes_sent); |
508 padding_budget_->UseBudget(bytes_sent); | 513 padding_budget_->UseBudget(bytes_sent); |
509 } | 514 } |
510 } // namespace webrtc | 515 } // namespace webrtc |
OLD | NEW |