OLD | NEW |
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/transport/cast_transport_sender_impl.h" | 5 #include "media/cast/transport/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 "media/cast/transport/cast_transport_config.h" | 8 #include "media/cast/transport/cast_transport_config.h" |
9 #include "media/cast/transport/cast_transport_defines.h" | 9 #include "media/cast/transport/cast_transport_defines.h" |
10 | 10 |
11 namespace media { | 11 namespace media { |
12 namespace cast { | 12 namespace cast { |
13 namespace transport { | 13 namespace transport { |
14 | 14 |
15 scoped_ptr<CastTransportSender> CastTransportSender::Create( | 15 scoped_ptr<CastTransportSender> CastTransportSender::Create( |
16 net::NetLog* net_log, | 16 net::NetLog* net_log, |
17 base::TickClock* clock, | 17 base::TickClock* clock, |
18 const net::IPEndPoint& local_end_point, | 18 const net::IPEndPoint& local_end_point, |
19 const net::IPEndPoint& remote_end_point, | 19 const net::IPEndPoint& remote_end_point, |
| 20 const CastLoggingConfig& logging_config, |
20 const CastTransportStatusCallback& status_callback, | 21 const CastTransportStatusCallback& status_callback, |
| 22 const BulkRawEventsCallback& raw_events_callback, |
| 23 base::TimeDelta raw_events_callback_interval, |
21 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner) { | 24 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner) { |
22 return scoped_ptr<CastTransportSender>( | 25 return scoped_ptr<CastTransportSender>( |
23 new CastTransportSenderImpl(net_log, | 26 new CastTransportSenderImpl(net_log, |
24 clock, | 27 clock, |
25 local_end_point, | 28 local_end_point, |
26 remote_end_point, | 29 remote_end_point, |
| 30 logging_config, |
27 status_callback, | 31 status_callback, |
| 32 raw_events_callback, |
| 33 raw_events_callback_interval, |
28 transport_task_runner.get(), | 34 transport_task_runner.get(), |
29 NULL)); | 35 NULL)); |
30 } | 36 } |
31 | 37 |
32 CastTransportSenderImpl::CastTransportSenderImpl( | 38 CastTransportSenderImpl::CastTransportSenderImpl( |
33 net::NetLog* net_log, | 39 net::NetLog* net_log, |
34 base::TickClock* clock, | 40 base::TickClock* clock, |
35 const net::IPEndPoint& local_end_point, | 41 const net::IPEndPoint& local_end_point, |
36 const net::IPEndPoint& remote_end_point, | 42 const net::IPEndPoint& remote_end_point, |
| 43 const CastLoggingConfig& logging_config, |
37 const CastTransportStatusCallback& status_callback, | 44 const CastTransportStatusCallback& status_callback, |
| 45 const BulkRawEventsCallback& raw_events_callback, |
| 46 base::TimeDelta raw_events_callback_interval, |
38 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner, | 47 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner, |
39 PacketSender* external_transport) | 48 PacketSender* external_transport) |
40 : clock_(clock), | 49 : clock_(clock), |
41 status_callback_(status_callback), | 50 status_callback_(status_callback), |
42 transport_task_runner_(transport_task_runner), | 51 transport_task_runner_(transport_task_runner), |
43 transport_(external_transport ? NULL | 52 transport_(external_transport ? NULL |
44 : new UdpTransport(net_log, | 53 : new UdpTransport(net_log, |
45 transport_task_runner, | 54 transport_task_runner, |
46 local_end_point, | 55 local_end_point, |
47 remote_end_point, | 56 remote_end_point, |
48 status_callback)), | 57 status_callback)), |
| 58 logging_(transport_task_runner, logging_config), |
49 pacer_(clock, | 59 pacer_(clock, |
| 60 &logging_, |
50 external_transport ? external_transport : transport_.get(), | 61 external_transport ? external_transport : transport_.get(), |
51 transport_task_runner), | 62 transport_task_runner), |
52 rtcp_builder_(&pacer_) {} | 63 rtcp_builder_(&pacer_), |
| 64 raw_events_callback_(raw_events_callback) { |
| 65 if (!raw_events_callback_.is_null()) { |
| 66 DCHECK(logging_config.enable_raw_data_collection); |
| 67 DCHECK(raw_events_callback_interval > base::TimeDelta()); |
| 68 event_subscriber_.reset(new SimpleEventSubscriber); |
| 69 logging_.AddRawEventSubscriber(event_subscriber_.get()); |
| 70 raw_events_timer_.Start(FROM_HERE, |
| 71 raw_events_callback_interval, |
| 72 this, |
| 73 &CastTransportSenderImpl::SendRawEvents); |
| 74 } |
| 75 } |
53 | 76 |
54 CastTransportSenderImpl::~CastTransportSenderImpl() {} | 77 CastTransportSenderImpl::~CastTransportSenderImpl() { |
| 78 if (event_subscriber_.get()) |
| 79 logging_.RemoveRawEventSubscriber(event_subscriber_.get()); |
| 80 } |
55 | 81 |
56 void CastTransportSenderImpl::InitializeAudio( | 82 void CastTransportSenderImpl::InitializeAudio( |
57 const CastTransportAudioConfig& config) { | 83 const CastTransportAudioConfig& config) { |
| 84 pacer_.InitializeAudio(config); |
58 audio_sender_.reset(new TransportAudioSender( | 85 audio_sender_.reset(new TransportAudioSender( |
59 config, clock_, transport_task_runner_, &pacer_)); | 86 config, clock_, &logging_, transport_task_runner_, &pacer_)); |
60 if (audio_sender_->initialized()) | 87 if (audio_sender_->initialized()) |
61 status_callback_.Run(TRANSPORT_AUDIO_INITIALIZED); | 88 status_callback_.Run(TRANSPORT_AUDIO_INITIALIZED); |
62 else | 89 else |
63 status_callback_.Run(TRANSPORT_AUDIO_UNINITIALIZED); | 90 status_callback_.Run(TRANSPORT_AUDIO_UNINITIALIZED); |
64 } | 91 } |
65 | 92 |
66 void CastTransportSenderImpl::InitializeVideo( | 93 void CastTransportSenderImpl::InitializeVideo( |
67 const CastTransportVideoConfig& config) { | 94 const CastTransportVideoConfig& config) { |
| 95 pacer_.InitializeVideo(config); |
68 video_sender_.reset(new TransportVideoSender( | 96 video_sender_.reset(new TransportVideoSender( |
69 config, clock_, transport_task_runner_, &pacer_)); | 97 config, clock_, &logging_, transport_task_runner_, &pacer_)); |
70 if (video_sender_->initialized()) | 98 if (video_sender_->initialized()) |
71 status_callback_.Run(TRANSPORT_VIDEO_INITIALIZED); | 99 status_callback_.Run(TRANSPORT_VIDEO_INITIALIZED); |
72 else | 100 else |
73 status_callback_.Run(TRANSPORT_VIDEO_UNINITIALIZED); | 101 status_callback_.Run(TRANSPORT_VIDEO_UNINITIALIZED); |
74 } | 102 } |
75 | 103 |
76 void CastTransportSenderImpl::SetPacketReceiver( | 104 void CastTransportSenderImpl::SetPacketReceiver( |
77 const PacketReceiverCallback& packet_receiver) { | 105 const PacketReceiverCallback& packet_receiver) { |
78 transport_->StartReceiving(packet_receiver); | 106 transport_->StartReceiving(packet_receiver); |
79 } | 107 } |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
120 DCHECK(audio_sender_) << "Audio sender uninitialized"; | 148 DCHECK(audio_sender_) << "Audio sender uninitialized"; |
121 audio_sender_->SubscribeAudioRtpStatsCallback(callback); | 149 audio_sender_->SubscribeAudioRtpStatsCallback(callback); |
122 } | 150 } |
123 | 151 |
124 void CastTransportSenderImpl::SubscribeVideoRtpStatsCallback( | 152 void CastTransportSenderImpl::SubscribeVideoRtpStatsCallback( |
125 const CastTransportRtpStatistics& callback) { | 153 const CastTransportRtpStatistics& callback) { |
126 DCHECK(video_sender_) << "Audio sender uninitialized"; | 154 DCHECK(video_sender_) << "Audio sender uninitialized"; |
127 video_sender_->SubscribeVideoRtpStatsCallback(callback); | 155 video_sender_->SubscribeVideoRtpStatsCallback(callback); |
128 } | 156 } |
129 | 157 |
| 158 void CastTransportSenderImpl::SendRawEvents() { |
| 159 DCHECK(event_subscriber_.get()); |
| 160 DCHECK(!raw_events_callback_.is_null()); |
| 161 std::vector<PacketEvent> packet_events; |
| 162 event_subscriber_->GetPacketEventsAndReset(&packet_events); |
| 163 raw_events_callback_.Run(packet_events); |
| 164 } |
| 165 |
130 } // namespace transport | 166 } // namespace transport |
131 } // namespace cast | 167 } // namespace cast |
132 } // namespace media | 168 } // namespace media |
OLD | NEW |