| 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/receiver/cast_receiver_impl.h" | 5 #include "media/cast/receiver/cast_receiver_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/debug/trace_event.h" | 10 #include "base/debug/trace_event.h" |
| 11 #include "base/logging.h" | 11 #include "base/logging.h" |
| 12 #include "base/message_loop/message_loop.h" | 12 #include "base/message_loop/message_loop.h" |
| 13 #include "media/cast/receiver/audio_decoder.h" | 13 #include "media/cast/receiver/audio_decoder.h" |
| 14 #include "media/cast/receiver/video_decoder.h" | 14 #include "media/cast/receiver/video_decoder.h" |
| 15 | 15 |
| 16 namespace media { | 16 namespace media { |
| 17 namespace cast { | 17 namespace cast { |
| 18 | 18 |
| 19 scoped_ptr<CastReceiver> CastReceiver::Create( | 19 scoped_ptr<CastReceiver> CastReceiver::Create( |
| 20 scoped_refptr<CastEnvironment> cast_environment, | 20 scoped_refptr<CastEnvironment> cast_environment, |
| 21 const FrameReceiverConfig& audio_config, | 21 const FrameReceiverConfig& audio_config, |
| 22 const FrameReceiverConfig& video_config, | 22 const FrameReceiverConfig& video_config, |
| 23 PacketSender* const packet_sender) { | 23 CastTransportSender* const transport) { |
| 24 return scoped_ptr<CastReceiver>(new CastReceiverImpl( | 24 return scoped_ptr<CastReceiver>(new CastReceiverImpl( |
| 25 cast_environment, audio_config, video_config, packet_sender)); | 25 cast_environment, audio_config, video_config, transport)); |
| 26 } | 26 } |
| 27 | 27 |
| 28 CastReceiverImpl::CastReceiverImpl( | 28 CastReceiverImpl::CastReceiverImpl( |
| 29 scoped_refptr<CastEnvironment> cast_environment, | 29 scoped_refptr<CastEnvironment> cast_environment, |
| 30 const FrameReceiverConfig& audio_config, | 30 const FrameReceiverConfig& audio_config, |
| 31 const FrameReceiverConfig& video_config, | 31 const FrameReceiverConfig& video_config, |
| 32 PacketSender* const packet_sender) | 32 CastTransportSender* const transport) |
| 33 : cast_environment_(cast_environment), | 33 : cast_environment_(cast_environment), |
| 34 pacer_(kTargetBurstSize, | 34 audio_receiver_(cast_environment, audio_config, AUDIO_EVENT, transport), |
| 35 kMaxBurstSize, | 35 video_receiver_(cast_environment, video_config, VIDEO_EVENT, transport), |
| 36 cast_environment->Clock(), | |
| 37 cast_environment->Logging(), | |
| 38 packet_sender, | |
| 39 cast_environment->GetTaskRunner(CastEnvironment::MAIN)), | |
| 40 audio_receiver_(cast_environment, audio_config, AUDIO_EVENT, &pacer_), | |
| 41 video_receiver_(cast_environment, video_config, VIDEO_EVENT, &pacer_), | |
| 42 ssrc_of_audio_sender_(audio_config.incoming_ssrc), | 36 ssrc_of_audio_sender_(audio_config.incoming_ssrc), |
| 43 ssrc_of_video_sender_(video_config.incoming_ssrc), | 37 ssrc_of_video_sender_(video_config.incoming_ssrc), |
| 44 num_audio_channels_(audio_config.channels), | 38 num_audio_channels_(audio_config.channels), |
| 45 audio_sampling_rate_(audio_config.frequency), | 39 audio_sampling_rate_(audio_config.frequency), |
| 46 audio_codec_(audio_config.codec), | 40 audio_codec_(audio_config.codec), |
| 47 video_codec_(video_config.codec) {} | 41 video_codec_(video_config.codec) {} |
| 48 | 42 |
| 49 CastReceiverImpl::~CastReceiverImpl() {} | 43 CastReceiverImpl::~CastReceiverImpl() {} |
| 50 | 44 |
| 51 void CastReceiverImpl::DispatchReceivedPacket(scoped_ptr<Packet> packet) { | 45 void CastReceiverImpl::ReceivePacket(scoped_ptr<Packet> packet) { |
| 52 const uint8_t* const data = &packet->front(); | 46 const uint8_t* const data = &packet->front(); |
| 53 const size_t length = packet->size(); | 47 const size_t length = packet->size(); |
| 54 | 48 |
| 55 uint32 ssrc_of_sender; | 49 uint32 ssrc_of_sender; |
| 56 if (Rtcp::IsRtcpPacket(data, length)) { | 50 if (Rtcp::IsRtcpPacket(data, length)) { |
| 57 ssrc_of_sender = Rtcp::GetSsrcOfSender(data, length); | 51 ssrc_of_sender = Rtcp::GetSsrcOfSender(data, length); |
| 58 } else if (!FrameReceiver::ParseSenderSsrc(data, length, &ssrc_of_sender)) { | 52 } else if (!RtpParser::ParseSsrc(data, length, &ssrc_of_sender)) { |
| 59 VLOG(1) << "Invalid RTP packet."; | 53 VLOG(1) << "Invalid RTP packet."; |
| 60 return; | 54 return; |
| 61 } | 55 } |
| 62 | 56 |
| 63 base::WeakPtr<FrameReceiver> target; | 57 base::WeakPtr<FrameReceiver> target; |
| 64 if (ssrc_of_sender == ssrc_of_video_sender_) { | 58 if (ssrc_of_sender == ssrc_of_video_sender_) { |
| 65 target = video_receiver_.AsWeakPtr(); | 59 target = video_receiver_.AsWeakPtr(); |
| 66 } else if (ssrc_of_sender == ssrc_of_audio_sender_) { | 60 } else if (ssrc_of_sender == ssrc_of_audio_sender_) { |
| 67 target = audio_receiver_.AsWeakPtr(); | 61 target = audio_receiver_.AsWeakPtr(); |
| 68 } else { | 62 } else { |
| 69 VLOG(1) << "Dropping packet with a non matching sender SSRC: " | 63 VLOG(1) << "Dropping packet with a non matching sender SSRC: " |
| 70 << ssrc_of_sender; | 64 << ssrc_of_sender; |
| 71 return; | 65 return; |
| 72 } | 66 } |
| 73 cast_environment_->PostTask( | 67 cast_environment_->PostTask( |
| 74 CastEnvironment::MAIN, | 68 CastEnvironment::MAIN, |
| 75 FROM_HERE, | 69 FROM_HERE, |
| 76 base::Bind(base::IgnoreResult(&FrameReceiver::ProcessPacket), | 70 base::Bind(base::IgnoreResult(&FrameReceiver::ProcessPacket), |
| 77 target, | 71 target, |
| 78 base::Passed(&packet))); | 72 base::Passed(&packet))); |
| 79 } | 73 } |
| 80 | 74 |
| 81 PacketReceiverCallback CastReceiverImpl::packet_receiver() { | |
| 82 return base::Bind(&CastReceiverImpl::DispatchReceivedPacket, | |
| 83 // TODO(miu): This code structure is dangerous, since the | |
| 84 // callback could be stored and then invoked after | |
| 85 // destruction of |this|. | |
| 86 base::Unretained(this)); | |
| 87 } | |
| 88 | |
| 89 void CastReceiverImpl::RequestDecodedAudioFrame( | 75 void CastReceiverImpl::RequestDecodedAudioFrame( |
| 90 const AudioFrameDecodedCallback& callback) { | 76 const AudioFrameDecodedCallback& callback) { |
| 91 DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN)); | 77 DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN)); |
| 92 DCHECK(!callback.is_null()); | 78 DCHECK(!callback.is_null()); |
| 93 audio_receiver_.RequestEncodedFrame(base::Bind( | 79 audio_receiver_.RequestEncodedFrame(base::Bind( |
| 94 &CastReceiverImpl::DecodeEncodedAudioFrame, | 80 &CastReceiverImpl::DecodeEncodedAudioFrame, |
| 95 // Note: Use of Unretained is safe since this Closure is guaranteed to be | 81 // Note: Use of Unretained is safe since this Closure is guaranteed to be |
| 96 // invoked or discarded by |audio_receiver_| before destruction of |this|. | 82 // invoked or discarded by |audio_receiver_| before destruction of |this|. |
| 97 base::Unretained(this), | 83 base::Unretained(this), |
| 98 callback)); | 84 callback)); |
| (...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 225 TRACE_EVENT_INSTANT1( | 211 TRACE_EVENT_INSTANT1( |
| 226 "cast_perf_test", "FrameDecoded", | 212 "cast_perf_test", "FrameDecoded", |
| 227 TRACE_EVENT_SCOPE_THREAD, | 213 TRACE_EVENT_SCOPE_THREAD, |
| 228 "rtp_timestamp", rtp_timestamp); | 214 "rtp_timestamp", rtp_timestamp); |
| 229 } | 215 } |
| 230 callback.Run(video_frame, playout_time, is_continuous); | 216 callback.Run(video_frame, playout_time, is_continuous); |
| 231 } | 217 } |
| 232 | 218 |
| 233 } // namespace cast | 219 } // namespace cast |
| 234 } // namespace media | 220 } // namespace media |
| OLD | NEW |