Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(79)

Side by Side Diff: media/cast/net/cast_transport_sender_impl.cc

Issue 567853002: Cast: Make pacing controllable by the extension (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: forgot to fix test files Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « media/cast/net/cast_transport_sender_impl.h ('k') | media/cast/net/pacing/paced_sender.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "media/cast/net/cast_transport_sender_impl.h" 5 #include "media/cast/net/cast_transport_sender_impl.h"
6 6
7 #include "base/single_thread_task_runner.h" 7 #include "base/single_thread_task_runner.h"
8 #include "base/values.h" 8 #include "base/values.h"
9 #include "media/cast/net/cast_transport_config.h" 9 #include "media/cast/net/cast_transport_config.h"
10 #include "media/cast/net/cast_transport_defines.h" 10 #include "media/cast/net/cast_transport_defines.h"
11 #include "media/cast/net/udp_transport.h" 11 #include "media/cast/net/udp_transport.h"
12 #include "net/base/net_util.h" 12 #include "net/base/net_util.h"
13 13
14 namespace media { 14 namespace media {
15 namespace cast { 15 namespace cast {
16 16
17 namespace {
18 int LookupOptionWithDefault(const base::DictionaryValue& options,
19 const std::string& path,
20 int default_value) {
21 int ret;
22 if (options.GetInteger(path, &ret)) {
23 return ret;
24 } else {
25 return default_value;
26 }
27 };
28
29 } // namespace
30
17 scoped_ptr<CastTransportSender> CastTransportSender::Create( 31 scoped_ptr<CastTransportSender> CastTransportSender::Create(
18 net::NetLog* net_log, 32 net::NetLog* net_log,
19 base::TickClock* clock, 33 base::TickClock* clock,
20 const net::IPEndPoint& remote_end_point, 34 const net::IPEndPoint& remote_end_point,
21 scoped_ptr<base::DictionaryValue> options, 35 scoped_ptr<base::DictionaryValue> options,
22 const CastTransportStatusCallback& status_callback, 36 const CastTransportStatusCallback& status_callback,
23 const BulkRawEventsCallback& raw_events_callback, 37 const BulkRawEventsCallback& raw_events_callback,
24 base::TimeDelta raw_events_callback_interval, 38 base::TimeDelta raw_events_callback_interval,
25 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner) { 39 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner) {
26 return scoped_ptr<CastTransportSender>( 40 return scoped_ptr<CastTransportSender>(
(...skipping 24 matching lines...) Expand all
51 PacketSender* external_transport) 65 PacketSender* external_transport)
52 : clock_(clock), 66 : clock_(clock),
53 status_callback_(status_callback), 67 status_callback_(status_callback),
54 transport_task_runner_(transport_task_runner), 68 transport_task_runner_(transport_task_runner),
55 transport_(external_transport ? NULL 69 transport_(external_transport ? NULL
56 : new UdpTransport(net_log, 70 : new UdpTransport(net_log,
57 transport_task_runner, 71 transport_task_runner,
58 net::IPEndPoint(), 72 net::IPEndPoint(),
59 remote_end_point, 73 remote_end_point,
60 status_callback)), 74 status_callback)),
61 pacer_(clock, 75 pacer_(LookupOptionWithDefault(*options.get(),
76 "pacer_target_burst_size",
77 kTargetBurstSize),
78 LookupOptionWithDefault(*options.get(),
79 "pacer_max_burst_size",
80 kMaxBurstSize),
81 clock,
62 &logging_, 82 &logging_,
63 external_transport ? external_transport : transport_.get(), 83 external_transport ? external_transport : transport_.get(),
64 transport_task_runner), 84 transport_task_runner),
65 raw_events_callback_(raw_events_callback), 85 raw_events_callback_(raw_events_callback),
66 raw_events_callback_interval_(raw_events_callback_interval), 86 raw_events_callback_interval_(raw_events_callback_interval),
67 last_byte_acked_for_audio_(0), 87 last_byte_acked_for_audio_(0),
68 weak_factory_(this) { 88 weak_factory_(this) {
69 DCHECK(clock_); 89 DCHECK(clock_);
70 if (!raw_events_callback_.is_null()) { 90 if (!raw_events_callback_.is_null()) {
71 DCHECK(raw_events_callback_interval > base::TimeDelta()); 91 DCHECK(raw_events_callback_interval > base::TimeDelta());
(...skipping 291 matching lines...) Expand 10 before | Expand all | Expand 10 after
363 // 2. Specifies a deduplication window. For video this would be the most 383 // 2. Specifies a deduplication window. For video this would be the most
364 // recent RTT. For audio there is no deduplication. 384 // recent RTT. For audio there is no deduplication.
365 ResendPackets(ssrc, 385 ResendPackets(ssrc,
366 cast_message.missing_frames_and_packets, 386 cast_message.missing_frames_and_packets,
367 true, 387 true,
368 dedup_info); 388 dedup_info);
369 } 389 }
370 390
371 } // namespace cast 391 } // namespace cast
372 } // namespace media 392 } // namespace media
OLDNEW
« no previous file with comments | « media/cast/net/cast_transport_sender_impl.h ('k') | media/cast/net/pacing/paced_sender.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698