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

Unified Diff: media/cast/transport/rtp_sender/rtp_sender.cc

Issue 174183003: Cast:Transport: Dividing A/V Initialization pipeline (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fixing errors and yet another rebase Created 6 years, 10 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/cast/transport/rtp_sender/rtp_sender.h ('k') | media/cast/transport/transport_audio_sender.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/cast/transport/rtp_sender/rtp_sender.cc
diff --git a/media/cast/transport/rtp_sender/rtp_sender.cc b/media/cast/transport/rtp_sender/rtp_sender.cc
index 91122de3900a6756bc8f2be4f86f963a3aa31bea..b08c5418db414d2aece673b3b4365fe3bc4b8e0a 100644
--- a/media/cast/transport/rtp_sender/rtp_sender.cc
+++ b/media/cast/transport/rtp_sender/rtp_sender.cc
@@ -20,53 +20,55 @@ static const int kStatsCallbackIntervalMs = 33;
RtpSender::RtpSender(
base::TickClock* clock,
- const CastTransportConfig& config,
- bool is_audio,
- const scoped_refptr<base::TaskRunner>& transport_task_runner,
+ const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner,
PacedSender* const transport)
- : config_(),
+ : clock_(clock),
transport_(transport),
stats_callback_(),
- transport_task_runner_(transport_task_runner) {
- // Store generic cast config and create packetizer config.
- if (is_audio) {
- storage_.reset(
- new PacketStorage(clock, config.audio_rtp_config.history_ms));
- config_.audio = true;
- config_.ssrc = config.audio_ssrc;
- config_.payload_type = config.audio_rtp_config.payload_type;
- config_.frequency = config.audio_frequency;
- config_.audio_codec = config.audio_codec;
- } else {
- storage_.reset(
- new PacketStorage(clock, config.audio_rtp_config.history_ms));
- config_.audio = false;
- config_.ssrc = config.video_ssrc;
- config_.payload_type = config.video_rtp_config.payload_type;
- config_.frequency = kVideoFrequency;
- config_.video_codec = config.video_codec;
- }
- // Randomly set start values.
+ transport_task_runner_(transport_task_runner),
+ weak_factory_(this) {
+ // Randomly set sequence number start value.
config_.sequence_number = base::RandInt(0, 65535);
- packetizer_.reset(
- new RtpPacketizer(transport, storage_.get(), config_));
}
RtpSender::~RtpSender() {}
+void RtpSender::InitializeAudio(const CastTransportAudioConfig& config) {
+ storage_.reset(new PacketStorage(clock_, config.base.rtp_config.history_ms));
+ config_.audio = true;
+ config_.ssrc = config.base.ssrc;
+ config_.payload_type = config.base.rtp_config.payload_type;
+ config_.frequency = config.frequency;
+ config_.audio_codec = config.codec;
+ packetizer_.reset(new RtpPacketizer(transport_, storage_.get(), config_));
+}
+
+void RtpSender::InitializeVideo(const CastTransportVideoConfig& config) {
+ storage_.reset(new PacketStorage(clock_, config.base.rtp_config.history_ms));
+ config_.audio = false;
+ config_.ssrc = config.base.ssrc;
+ config_.payload_type = config.base.rtp_config.payload_type;
+ config_.frequency = kVideoFrequency;
+ config_.video_codec = config.codec;
+ packetizer_.reset(new RtpPacketizer(transport_, storage_.get(), config_));
+}
+
void RtpSender::IncomingEncodedVideoFrame(const EncodedVideoFrame* video_frame,
const base::TimeTicks& capture_time) {
+ DCHECK(packetizer_);
packetizer_->IncomingEncodedVideoFrame(video_frame, capture_time);
}
void RtpSender::IncomingEncodedAudioFrame(
const EncodedAudioFrame* audio_frame,
const base::TimeTicks& recorded_time) {
+ DCHECK(packetizer_);
packetizer_->IncomingEncodedAudioFrame(audio_frame, recorded_time);
}
void RtpSender::ResendPackets(
const MissingFramesAndPacketsMap& missing_frames_and_packets) {
+ DCHECK(storage_);
// Iterate over all frames in the list.
for (MissingFramesAndPacketsMap::const_iterator it =
missing_frames_and_packets.begin();
@@ -133,7 +135,7 @@ void RtpSender::SubscribeRtpStatsCallback(
void RtpSender::ScheduleNextStatsReport() {
transport_task_runner_->PostDelayedTask(
FROM_HERE,
- base::Bind(&RtpSender::RtpStatistics, base::AsWeakPtr(this)),
+ base::Bind(&RtpSender::RtpStatistics, weak_factory_.GetWeakPtr()),
base::TimeDelta::FromMilliseconds(kStatsCallbackIntervalMs));
}
« no previous file with comments | « media/cast/transport/rtp_sender/rtp_sender.h ('k') | media/cast/transport/transport_audio_sender.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698