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

Side by Side Diff: media/cast/transport/transport_audio_sender.cc

Issue 174183003: Cast:Transport: Dividing A/V Initialization pipeline (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Responding to review 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/transport_audio_sender.h" 5 #include "media/cast/transport/transport_audio_sender.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/message_loop/message_loop.h" 9 #include "base/message_loop/message_loop.h"
10 #include "media/cast/transport/rtp_sender/rtp_sender.h" 10 #include "media/cast/transport/rtp_sender/rtp_sender.h"
11 11
12 namespace media { 12 namespace media {
13 namespace cast { 13 namespace cast {
14 namespace transport { 14 namespace transport {
15 15
16 TransportAudioSender::TransportAudioSender( 16 TransportAudioSender::TransportAudioSender(
17 const CastTransportConfig& config, 17 const CastTransportAudioConfig& config,
18 base::TickClock* clock, 18 base::TickClock* clock,
19 const scoped_refptr<base::TaskRunner>& transport_task_runner, 19 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner,
20 PacedSender* const paced_packet_sender) 20 PacedSender* const paced_packet_sender)
21 : rtp_sender_(clock, 21 : rtp_sender_(clock, transport_task_runner, paced_packet_sender),
22 config,
23 true,
24 transport_task_runner,
25 paced_packet_sender),
26 encryptor_() { 22 encryptor_() {
27 initialized_ = encryptor_.Initialize(config.aes_key, config.aes_iv_mask); 23 rtp_sender_.InitializeAudio(config);
24 initialized_ =
25 encryptor_.Initialize(config.base.aes_key, config.base.aes_iv_mask);
28 } 26 }
29 27
30 TransportAudioSender::~TransportAudioSender() {} 28 TransportAudioSender::~TransportAudioSender() {}
31 29
32 void TransportAudioSender::InsertCodedAudioFrame( 30 void TransportAudioSender::InsertCodedAudioFrame(
33 const EncodedAudioFrame* audio_frame, 31 const EncodedAudioFrame* audio_frame,
34 const base::TimeTicks& recorded_time) { 32 const base::TimeTicks& recorded_time) {
35 if (encryptor_.initialized()) { 33 if (encryptor_.initialized()) {
36 EncodedAudioFrame encrypted_frame; 34 EncodedAudioFrame encrypted_frame;
37 if (!EncryptAudioFrame(*audio_frame, &encrypted_frame)) { 35 if (!EncryptAudioFrame(*audio_frame, &encrypted_frame)) {
38 return; 36 return;
39 } 37 }
40 rtp_sender_.IncomingEncodedAudioFrame(&encrypted_frame, recorded_time); 38 rtp_sender_.IncomingEncodedAudioFrame(&encrypted_frame, recorded_time);
41 } else { 39 } else {
42 rtp_sender_.IncomingEncodedAudioFrame(audio_frame, recorded_time); 40 rtp_sender_.IncomingEncodedAudioFrame(audio_frame, recorded_time);
43 } 41 }
44 } 42 }
45 43
46 bool TransportAudioSender::EncryptAudioFrame( 44 bool TransportAudioSender::EncryptAudioFrame(
47 const EncodedAudioFrame& audio_frame, 45 const EncodedAudioFrame& audio_frame,
48 EncodedAudioFrame* encrypted_frame) { 46 EncodedAudioFrame* encrypted_frame) {
49 if (!encryptor_.Encrypt( 47 if (!encryptor_.Encrypt(
50 audio_frame.frame_id, audio_frame.data, &encrypted_frame->data)) 48 audio_frame.frame_id, audio_frame.data, &encrypted_frame->data))
51 return false; 49 return false;
52 50
53 encrypted_frame->codec = audio_frame.codec; 51 encrypted_frame->codec = audio_frame.codec;
54 encrypted_frame->frame_id = audio_frame.frame_id; 52 encrypted_frame->frame_id = audio_frame.frame_id;
55 encrypted_frame->rtp_timestamp = audio_frame.rtp_timestamp; 53 encrypted_frame->rtp_timestamp = audio_frame.rtp_timestamp;
56 return true; 54 return true;
57 } 55 }
58 56
59 void TransportAudioSender::ResendPackets( 57 void TransportAudioSender::ResendPackets(
60 const MissingFramesAndPacketsMap& missing_frames_and_packets) { 58 const MissingFramesAndPacketsMap& missing_frames_and_packets) {
61 rtp_sender_.ResendPackets(missing_frames_and_packets); 59 rtp_sender_.ResendPackets(missing_frames_and_packets);
62 } 60 }
63 61
64 void TransportAudioSender::SubscribeAudioRtpStatsCallback( 62 void TransportAudioSender::SubscribeAudioRtpStatsCallback(
65 const CastTransportRtpStatistics& callback) { 63 const CastTransportRtpStatistics& callback) {
66 rtp_sender_.SubscribeRtpStatsCallback(callback); 64 rtp_sender_.SubscribeRtpStatsCallback(callback);
67 } 65 }
68 66
69 } // namespace transport 67 } // namespace transport
70 } // namespace cast 68 } // namespace cast
71 } // namespace media 69 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698