summaryrefslogtreecommitdiffstats
path: root/media/cast/receiver
diff options
context:
space:
mode:
Diffstat (limited to 'media/cast/receiver')
-rw-r--r--media/cast/receiver/cast_receiver_impl.cc28
-rw-r--r--media/cast/receiver/cast_receiver_impl.h9
-rw-r--r--media/cast/receiver/frame_receiver.cc37
-rw-r--r--media/cast/receiver/frame_receiver.h9
-rw-r--r--media/cast/receiver/frame_receiver_unittest.cc17
5 files changed, 43 insertions, 57 deletions
diff --git a/media/cast/receiver/cast_receiver_impl.cc b/media/cast/receiver/cast_receiver_impl.cc
index 8265211..32b2c8c 100644
--- a/media/cast/receiver/cast_receiver_impl.cc
+++ b/media/cast/receiver/cast_receiver_impl.cc
@@ -20,25 +20,19 @@ scoped_ptr<CastReceiver> CastReceiver::Create(
scoped_refptr<CastEnvironment> cast_environment,
const FrameReceiverConfig& audio_config,
const FrameReceiverConfig& video_config,
- PacketSender* const packet_sender) {
+ CastTransportSender* const transport) {
return scoped_ptr<CastReceiver>(new CastReceiverImpl(
- cast_environment, audio_config, video_config, packet_sender));
+ cast_environment, audio_config, video_config, transport));
}
CastReceiverImpl::CastReceiverImpl(
scoped_refptr<CastEnvironment> cast_environment,
const FrameReceiverConfig& audio_config,
const FrameReceiverConfig& video_config,
- PacketSender* const packet_sender)
+ CastTransportSender* const transport)
: cast_environment_(cast_environment),
- pacer_(kTargetBurstSize,
- kMaxBurstSize,
- cast_environment->Clock(),
- cast_environment->Logging(),
- packet_sender,
- cast_environment->GetTaskRunner(CastEnvironment::MAIN)),
- audio_receiver_(cast_environment, audio_config, AUDIO_EVENT, &pacer_),
- video_receiver_(cast_environment, video_config, VIDEO_EVENT, &pacer_),
+ audio_receiver_(cast_environment, audio_config, AUDIO_EVENT, transport),
+ video_receiver_(cast_environment, video_config, VIDEO_EVENT, transport),
ssrc_of_audio_sender_(audio_config.incoming_ssrc),
ssrc_of_video_sender_(video_config.incoming_ssrc),
num_audio_channels_(audio_config.channels),
@@ -48,14 +42,14 @@ CastReceiverImpl::CastReceiverImpl(
CastReceiverImpl::~CastReceiverImpl() {}
-void CastReceiverImpl::DispatchReceivedPacket(scoped_ptr<Packet> packet) {
+void CastReceiverImpl::ReceivePacket(scoped_ptr<Packet> packet) {
const uint8_t* const data = &packet->front();
const size_t length = packet->size();
uint32 ssrc_of_sender;
if (Rtcp::IsRtcpPacket(data, length)) {
ssrc_of_sender = Rtcp::GetSsrcOfSender(data, length);
- } else if (!FrameReceiver::ParseSenderSsrc(data, length, &ssrc_of_sender)) {
+ } else if (!RtpParser::ParseSsrc(data, length, &ssrc_of_sender)) {
VLOG(1) << "Invalid RTP packet.";
return;
}
@@ -78,14 +72,6 @@ void CastReceiverImpl::DispatchReceivedPacket(scoped_ptr<Packet> packet) {
base::Passed(&packet)));
}
-PacketReceiverCallback CastReceiverImpl::packet_receiver() {
- return base::Bind(&CastReceiverImpl::DispatchReceivedPacket,
- // TODO(miu): This code structure is dangerous, since the
- // callback could be stored and then invoked after
- // destruction of |this|.
- base::Unretained(this));
-}
-
void CastReceiverImpl::RequestDecodedAudioFrame(
const AudioFrameDecodedCallback& callback) {
DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN));
diff --git a/media/cast/receiver/cast_receiver_impl.h b/media/cast/receiver/cast_receiver_impl.h
index 5431393..bc1bf67 100644
--- a/media/cast/receiver/cast_receiver_impl.h
+++ b/media/cast/receiver/cast_receiver_impl.h
@@ -27,12 +27,12 @@ class CastReceiverImpl : public CastReceiver {
CastReceiverImpl(scoped_refptr<CastEnvironment> cast_environment,
const FrameReceiverConfig& audio_config,
const FrameReceiverConfig& video_config,
- PacketSender* const packet_sender);
+ CastTransportSender* const transport);
~CastReceiverImpl() override;
// CastReceiver implementation.
- PacketReceiverCallback packet_receiver() override;
+ void ReceivePacket(scoped_ptr<Packet> packet) override;
void RequestDecodedAudioFrame(
const AudioFrameDecodedCallback& callback) override;
void RequestEncodedAudioFrame(
@@ -43,10 +43,6 @@ class CastReceiverImpl : public CastReceiver {
const ReceiveEncodedFrameCallback& callback) override;
private:
- // Forwards |packet| to a specific RTP frame receiver, or drops it if SSRC
- // does not map to one of the receivers.
- void DispatchReceivedPacket(scoped_ptr<Packet> packet);
-
// Feeds an EncodedFrame into |audio_decoder_|. RequestDecodedAudioFrame()
// uses this as a callback for RequestEncodedAudioFrame().
void DecodeEncodedAudioFrame(
@@ -88,7 +84,6 @@ class CastReceiverImpl : public CastReceiver {
bool is_continuous);
const scoped_refptr<CastEnvironment> cast_environment_;
- PacedSender pacer_;
FrameReceiver audio_receiver_;
FrameReceiver video_receiver_;
diff --git a/media/cast/receiver/frame_receiver.cc b/media/cast/receiver/frame_receiver.cc
index 561e19f..c1155d0 100644
--- a/media/cast/receiver/frame_receiver.cc
+++ b/media/cast/receiver/frame_receiver.cc
@@ -23,8 +23,9 @@ FrameReceiver::FrameReceiver(
const scoped_refptr<CastEnvironment>& cast_environment,
const FrameReceiverConfig& config,
EventMediaType event_media_type,
- PacedPacketSender* const packet_sender)
+ CastTransportSender* const transport)
: cast_environment_(cast_environment),
+ transport_(transport),
packet_parser_(config.incoming_ssrc, config.rtp_payload_type),
stats_(cast_environment->Clock()),
event_media_type_(event_media_type),
@@ -44,13 +45,14 @@ FrameReceiver::FrameReceiver(
RtcpRttCallback(),
RtcpLogMessageCallback(),
cast_environment_->Clock(),
- packet_sender,
+ NULL,
config.feedback_ssrc,
config.incoming_ssrc),
is_waiting_for_consecutive_frame_(false),
lip_sync_drift_(ClockDriftSmoother::GetDefaultTimeConstant()),
rtcp_interval_(base::TimeDelta::FromMilliseconds(config.rtcp_interval)),
weak_factory_(this) {
+ transport_->AddValidSsrc(config.incoming_ssrc);
DCHECK_GT(config.rtp_max_delay_ms, 0);
DCHECK_GT(config.max_frame_rate, 0);
decryptor_.Initialize(config.aes_key, config.aes_iv_mask);
@@ -100,15 +102,6 @@ bool FrameReceiver::ProcessPacket(scoped_ptr<Packet> packet) {
return true;
}
-// static
-bool FrameReceiver::ParseSenderSsrc(const uint8* packet,
- size_t length,
- uint32* ssrc) {
- base::BigEndianReader big_endian_reader(
- reinterpret_cast<const char*>(packet), length);
- return big_endian_reader.Skip(8) && big_endian_reader.ReadU32(ssrc);
-}
-
void FrameReceiver::ProcessParsedPacket(const RtpCastHeader& rtp_header,
const uint8* payload_data,
size_t payload_size) {
@@ -177,10 +170,15 @@ void FrameReceiver::CastFeedback(const RtcpCastMessage& cast_message) {
now, FRAME_ACK_SENT, event_media_type_,
rtp_timestamp, cast_message.ack_frame_id);
- ReceiverRtcpEventSubscriber::RtcpEventMultiMap rtcp_events;
- event_subscriber_.GetRtcpEventsAndReset(&rtcp_events);
- rtcp_.SendRtcpFromRtpReceiver(&cast_message, target_playout_delay_,
- &rtcp_events, NULL);
+ ReceiverRtcpEventSubscriber::RtcpEvents rtcp_events;
+ event_subscriber_.GetRtcpEventsWithRedundancy(&rtcp_events);
+ transport_->SendRtcpFromRtpReceiver(rtcp_.GetLocalSsrc(),
+ rtcp_.GetRemoteSsrc(),
+ rtcp_.ConvertToNTPAndSave(now),
+ &cast_message,
+ target_playout_delay_,
+ &rtcp_events,
+ NULL);
}
void FrameReceiver::EmitAvailableEncodedFrames() {
@@ -336,8 +334,15 @@ void FrameReceiver::ScheduleNextRtcpReport() {
void FrameReceiver::SendNextRtcpReport() {
DCHECK(cast_environment_->CurrentlyOn(CastEnvironment::MAIN));
+ const base::TimeTicks now = cast_environment_->Clock()->NowTicks();
RtpReceiverStatistics stats = stats_.GetStatistics();
- rtcp_.SendRtcpFromRtpReceiver(NULL, base::TimeDelta(), NULL, &stats);
+ transport_->SendRtcpFromRtpReceiver(rtcp_.GetLocalSsrc(),
+ rtcp_.GetRemoteSsrc(),
+ rtcp_.ConvertToNTPAndSave(now),
+ NULL,
+ base::TimeDelta(),
+ NULL,
+ &stats);
ScheduleNextRtcpReport();
}
diff --git a/media/cast/receiver/frame_receiver.h b/media/cast/receiver/frame_receiver.h
index 4d673f3..382b798 100644
--- a/media/cast/receiver/frame_receiver.h
+++ b/media/cast/receiver/frame_receiver.h
@@ -50,7 +50,7 @@ class FrameReceiver : public RtpPayloadFeedback,
FrameReceiver(const scoped_refptr<CastEnvironment>& cast_environment,
const FrameReceiverConfig& config,
EventMediaType event_media_type,
- PacedPacketSender* const packet_sender);
+ CastTransportSender* const transport);
~FrameReceiver() override;
@@ -64,10 +64,6 @@ class FrameReceiver : public RtpPayloadFeedback,
// out-of-order. Returns true if the parsing of the packet succeeded.
bool ProcessPacket(scoped_ptr<Packet> packet);
- // TODO(miu): This is the wrong place for this, but the (de)serialization
- // implementation needs to be consolidated first.
- static bool ParseSenderSsrc(const uint8* packet, size_t length, uint32* ssrc);
-
protected:
friend class FrameReceiverTest; // Invokes ProcessParsedPacket().
@@ -115,6 +111,9 @@ class FrameReceiver : public RtpPayloadFeedback,
const scoped_refptr<CastEnvironment> cast_environment_;
+ // Transport used to send data back.
+ CastTransportSender* const transport_;
+
// Deserializes a packet into a RtpHeader + payload bytes.
RtpParser packet_parser_;
diff --git a/media/cast/receiver/frame_receiver_unittest.cc b/media/cast/receiver/frame_receiver_unittest.cc
index 24e1a0b..42bc4e3 100644
--- a/media/cast/receiver/frame_receiver_unittest.cc
+++ b/media/cast/receiver/frame_receiver_unittest.cc
@@ -12,7 +12,8 @@
#include "media/cast/cast_defines.h"
#include "media/cast/cast_environment.h"
#include "media/cast/logging/simple_event_subscriber.h"
-#include "media/cast/net/pacing/mock_paced_packet_sender.h"
+#include "media/cast/net/cast_transport_sender_impl.h"
+#include "media/cast/net/mock_cast_transport_sender.h"
#include "media/cast/net/rtcp/test_rtcp_packet_builder.h"
#include "media/cast/receiver/frame_receiver.h"
#include "media/cast/test/fake_single_thread_task_runner.h"
@@ -136,7 +137,7 @@ class FrameReceiverTest : public ::testing::Test {
RtpCastHeader rtp_header_;
base::SimpleTestTickClock* testing_clock_; // Owned by CastEnvironment.
base::TimeTicks start_time_;
- MockPacedPacketSender mock_transport_;
+ MockCastTransportSender mock_transport_;
scoped_refptr<test::FakeSingleThreadTaskRunner> task_runner_;
scoped_refptr<CastEnvironment> cast_environment_;
FakeFrameClient frame_client_;
@@ -171,8 +172,8 @@ TEST_F(FrameReceiverTest, ReceivesOneFrame) {
SimpleEventSubscriber event_subscriber;
cast_environment_->Logging()->AddRawEventSubscriber(&event_subscriber);
- EXPECT_CALL(mock_transport_, SendRtcpPacket(_, _))
- .WillRepeatedly(testing::Return(true));
+ EXPECT_CALL(mock_transport_, SendRtcpFromRtpReceiver(_, _, _, _, _, _, _))
+ .WillRepeatedly(testing::Return());
FeedLipSyncInfoIntoReceiver();
task_runner_->RunTasks();
@@ -212,8 +213,8 @@ TEST_F(FrameReceiverTest, ReceivesFramesSkippingWhenAppropriate) {
SimpleEventSubscriber event_subscriber;
cast_environment_->Logging()->AddRawEventSubscriber(&event_subscriber);
- EXPECT_CALL(mock_transport_, SendRtcpPacket(_, _))
- .WillRepeatedly(testing::Return(true));
+ EXPECT_CALL(mock_transport_, SendRtcpFromRtpReceiver(_, _, _, _, _, _, _))
+ .WillRepeatedly(testing::Return());
const uint32 rtp_advance_per_frame =
config_.frequency / config_.max_frame_rate;
@@ -315,8 +316,8 @@ TEST_F(FrameReceiverTest, ReceivesFramesRefusingToSkipAny) {
SimpleEventSubscriber event_subscriber;
cast_environment_->Logging()->AddRawEventSubscriber(&event_subscriber);
- EXPECT_CALL(mock_transport_, SendRtcpPacket(_, _))
- .WillRepeatedly(testing::Return(true));
+ EXPECT_CALL(mock_transport_, SendRtcpFromRtpReceiver(_, _, _, _, _, _, _))
+ .WillRepeatedly(testing::Return());
const uint32 rtp_advance_per_frame =
config_.frequency / config_.max_frame_rate;