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 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
179 process_thread_->DeRegisterModule(bitrate_controller_.get()); | 179 process_thread_->DeRegisterModule(bitrate_controller_.get()); |
180 process_thread_->DeRegisterModule(call_stats_.get()); | 180 process_thread_->DeRegisterModule(call_stats_.get()); |
181 process_thread_->DeRegisterModule(remote_bitrate_estimator_.get()); | 181 process_thread_->DeRegisterModule(remote_bitrate_estimator_.get()); |
182 call_stats_->DeregisterStatsObserver(remote_bitrate_estimator_.get()); | 182 call_stats_->DeregisterStatsObserver(remote_bitrate_estimator_.get()); |
183 RTC_DCHECK(channel_map_.empty()); | 183 RTC_DCHECK(channel_map_.empty()); |
184 RTC_DCHECK(!remb_->InUse()); | 184 RTC_DCHECK(!remb_->InUse()); |
185 RTC_DCHECK(vie_encoder_map_.empty()); | 185 RTC_DCHECK(vie_encoder_map_.empty()); |
186 } | 186 } |
187 | 187 |
188 bool ChannelGroup::CreateSendChannel(int channel_id, | 188 bool ChannelGroup::CreateSendChannel(int channel_id, |
189 int engine_id, | |
190 Transport* transport, | 189 Transport* transport, |
191 int number_of_cores, | 190 int number_of_cores, |
192 const std::vector<uint32_t>& ssrcs) { | 191 const std::vector<uint32_t>& ssrcs) { |
193 RTC_DCHECK(!ssrcs.empty()); | 192 RTC_DCHECK(!ssrcs.empty()); |
194 rtc::scoped_ptr<ViEEncoder> vie_encoder( | 193 rtc::scoped_ptr<ViEEncoder> vie_encoder( |
195 new ViEEncoder(channel_id, number_of_cores, *process_thread_, | 194 new ViEEncoder(channel_id, number_of_cores, *process_thread_, |
196 pacer_.get(), bitrate_allocator_.get())); | 195 pacer_.get(), bitrate_allocator_.get())); |
197 if (!vie_encoder->Init()) { | 196 if (!vie_encoder->Init()) { |
198 return false; | 197 return false; |
199 } | 198 } |
200 ViEEncoder* encoder = vie_encoder.get(); | 199 ViEEncoder* encoder = vie_encoder.get(); |
201 if (!CreateChannel(channel_id, engine_id, transport, number_of_cores, | 200 if (!CreateChannel(channel_id, transport, number_of_cores, |
202 vie_encoder.release(), ssrcs.size(), true)) { | 201 vie_encoder.release(), ssrcs.size(), true)) { |
203 return false; | 202 return false; |
204 } | 203 } |
205 ViEChannel* channel = channel_map_[channel_id]; | 204 ViEChannel* channel = channel_map_[channel_id]; |
206 // Connect the encoder with the send packet router, to enable sending. | 205 // Connect the encoder with the send packet router, to enable sending. |
207 encoder->StartThreadsAndSetSharedMembers(channel->send_payload_router(), | 206 encoder->StartThreadsAndSetSharedMembers(channel->send_payload_router(), |
208 channel->vcm_protection_callback()); | 207 channel->vcm_protection_callback()); |
209 | 208 |
210 encoder_state_feedback_->AddEncoder(ssrcs, encoder); | 209 encoder_state_feedback_->AddEncoder(ssrcs, encoder); |
211 std::vector<uint32_t> first_ssrc(1, ssrcs[0]); | 210 std::vector<uint32_t> first_ssrc(1, ssrcs[0]); |
212 encoder->SetSsrcs(first_ssrc); | 211 encoder->SetSsrcs(first_ssrc); |
213 return true; | 212 return true; |
214 } | 213 } |
215 | 214 |
216 bool ChannelGroup::CreateReceiveChannel(int channel_id, | 215 bool ChannelGroup::CreateReceiveChannel(int channel_id, |
217 int engine_id, | |
218 Transport* transport, | 216 Transport* transport, |
219 int number_of_cores) { | 217 int number_of_cores) { |
220 return CreateChannel(channel_id, engine_id, transport, number_of_cores, | 218 return CreateChannel(channel_id, transport, number_of_cores, |
221 nullptr, 1, false); | 219 nullptr, 1, false); |
222 } | 220 } |
223 | 221 |
224 bool ChannelGroup::CreateChannel(int channel_id, | 222 bool ChannelGroup::CreateChannel(int channel_id, |
225 int engine_id, | |
226 Transport* transport, | 223 Transport* transport, |
227 int number_of_cores, | 224 int number_of_cores, |
228 ViEEncoder* vie_encoder, | 225 ViEEncoder* vie_encoder, |
229 size_t max_rtp_streams, | 226 size_t max_rtp_streams, |
230 bool sender) { | 227 bool sender) { |
231 rtc::scoped_ptr<ViEChannel> channel(new ViEChannel( | 228 rtc::scoped_ptr<ViEChannel> channel(new ViEChannel( |
232 channel_id, engine_id, number_of_cores, transport, process_thread_, | 229 number_of_cores, transport, process_thread_, |
233 encoder_state_feedback_->GetRtcpIntraFrameObserver(), | 230 encoder_state_feedback_->GetRtcpIntraFrameObserver(), |
234 bitrate_controller_->CreateRtcpBandwidthObserver(), nullptr, | 231 bitrate_controller_->CreateRtcpBandwidthObserver(), nullptr, |
235 remote_bitrate_estimator_.get(), call_stats_->rtcp_rtt_stats(), | 232 remote_bitrate_estimator_.get(), call_stats_->rtcp_rtt_stats(), |
236 pacer_.get(), packet_router_.get(), max_rtp_streams, sender)); | 233 pacer_.get(), packet_router_.get(), max_rtp_streams, sender)); |
237 if (channel->Init() != 0) { | 234 if (channel->Init() != 0) { |
238 return false; | 235 return false; |
239 } | 236 } |
240 | 237 |
241 // Register the channel to receive stats updates. | 238 // Register the channel to receive stats updates. |
242 call_stats_->RegisterStatsObserver(channel->GetStatsObserver()); | 239 call_stats_->RegisterStatsObserver(channel->GetStatsObserver()); |
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
363 rtc::CritScope lock(&encoder_map_crit_); | 360 rtc::CritScope lock(&encoder_map_crit_); |
364 for (const auto& encoder : vie_encoder_map_) | 361 for (const auto& encoder : vie_encoder_map_) |
365 pad_up_to_bitrate_bps += encoder.second->GetPaddingNeededBps(); | 362 pad_up_to_bitrate_bps += encoder.second->GetPaddingNeededBps(); |
366 } | 363 } |
367 pacer_->UpdateBitrate( | 364 pacer_->UpdateBitrate( |
368 target_bitrate_bps / 1000, | 365 target_bitrate_bps / 1000, |
369 PacedSender::kDefaultPaceMultiplier * target_bitrate_bps / 1000, | 366 PacedSender::kDefaultPaceMultiplier * target_bitrate_bps / 1000, |
370 pad_up_to_bitrate_bps / 1000); | 367 pad_up_to_bitrate_bps / 1000); |
371 } | 368 } |
372 } // namespace webrtc | 369 } // namespace webrtc |
OLD | NEW |