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

Side by Side Diff: chrome/renderer/media/cast_rtp_stream.cc

Issue 214663008: Cast: Clarify the unit of bitrate (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 9 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
« no previous file with comments | « chrome/renderer/media/cast_rtp_stream.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "chrome/renderer/media/cast_rtp_stream.h" 5 #include "chrome/renderer/media/cast_rtp_stream.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/debug/trace_event.h" 8 #include "base/debug/trace_event.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/memory/weak_ptr.h" 10 #include "base/memory/weak_ptr.h"
(...skipping 16 matching lines...) Expand all
27 #include "ui/gfx/geometry/size.h" 27 #include "ui/gfx/geometry/size.h"
28 28
29 using media::cast::AudioSenderConfig; 29 using media::cast::AudioSenderConfig;
30 using media::cast::VideoSenderConfig; 30 using media::cast::VideoSenderConfig;
31 31
32 namespace { 32 namespace {
33 33
34 const char kCodecNameOpus[] = "OPUS"; 34 const char kCodecNameOpus[] = "OPUS";
35 const char kCodecNameVp8[] = "VP8"; 35 const char kCodecNameVp8[] = "VP8";
36 36
37 // To convert from kilobits per second to bits to per second.
38 const int kBitrateMultiplier = 1000;
39
37 // This constant defines the number of sets of audio data to buffer 40 // This constant defines the number of sets of audio data to buffer
38 // in the FIFO. If input audio and output data have different resampling 41 // in the FIFO. If input audio and output data have different resampling
39 // rates then buffer is necessary to avoid audio glitches. 42 // rates then buffer is necessary to avoid audio glitches.
40 // See CastAudioSink::ResampleData() and CastAudioSink::OnSetFormat() 43 // See CastAudioSink::ResampleData() and CastAudioSink::OnSetFormat()
41 // for more defaults. 44 // for more defaults.
42 const int kBufferAudioData = 2; 45 const int kBufferAudioData = 2;
43 46
44 CastRtpPayloadParams DefaultOpusPayload() { 47 CastRtpPayloadParams DefaultOpusPayload() {
45 CastRtpPayloadParams payload; 48 CastRtpPayloadParams payload;
46 payload.ssrc = 1; 49 payload.ssrc = 1;
47 payload.feedback_ssrc = 1; 50 payload.feedback_ssrc = 1;
48 payload.payload_type = 127; 51 payload.payload_type = 127;
49 payload.codec_name = kCodecNameOpus; 52 payload.codec_name = kCodecNameOpus;
50 payload.clock_rate = 48000; 53 payload.clock_rate = 48000;
51 payload.channels = 2; 54 payload.channels = 2;
55 // The value is 0 which means VBR.
52 payload.min_bitrate = payload.max_bitrate = 56 payload.min_bitrate = payload.max_bitrate =
53 media::cast::kDefaultAudioEncoderBitrate; 57 media::cast::kDefaultAudioEncoderBitrate;
54 return payload; 58 return payload;
55 } 59 }
56 60
57 CastRtpPayloadParams DefaultVp8Payload() { 61 CastRtpPayloadParams DefaultVp8Payload() {
58 CastRtpPayloadParams payload; 62 CastRtpPayloadParams payload;
59 payload.ssrc = 11; 63 payload.ssrc = 11;
60 payload.feedback_ssrc = 12; 64 payload.feedback_ssrc = 12;
61 payload.payload_type = 96; 65 payload.payload_type = 96;
62 payload.codec_name = kCodecNameVp8; 66 payload.codec_name = kCodecNameVp8;
63 payload.clock_rate = 90000; 67 payload.clock_rate = 90000;
64 payload.width = 1280; 68 payload.width = 1280;
65 payload.height = 720; 69 payload.height = 720;
66 payload.min_bitrate = 50 * 1000; 70 payload.min_bitrate = 50;
67 payload.max_bitrate = 2000 * 1000; 71 payload.max_bitrate = 2000;
68 return payload; 72 return payload;
69 } 73 }
70 74
71 std::vector<CastRtpParams> SupportedAudioParams() { 75 std::vector<CastRtpParams> SupportedAudioParams() {
72 // TODO(hclam): Fill in more codecs here. 76 // TODO(hclam): Fill in more codecs here.
73 std::vector<CastRtpParams> supported_params; 77 std::vector<CastRtpParams> supported_params;
74 supported_params.push_back(CastRtpParams(DefaultOpusPayload())); 78 supported_params.push_back(CastRtpParams(DefaultOpusPayload()));
75 return supported_params; 79 return supported_params;
76 } 80 }
77 81
78 std::vector<CastRtpParams> SupportedVideoParams() { 82 std::vector<CastRtpParams> SupportedVideoParams() {
79 // TODO(hclam): Fill in H264 here. 83 // TODO(hclam): Fill in H264 here.
80 std::vector<CastRtpParams> supported_params; 84 std::vector<CastRtpParams> supported_params;
81 supported_params.push_back(CastRtpParams(DefaultVp8Payload())); 85 supported_params.push_back(CastRtpParams(DefaultVp8Payload()));
82 return supported_params; 86 return supported_params;
83 } 87 }
84 88
85 bool ToAudioSenderConfig(const CastRtpParams& params, 89 bool ToAudioSenderConfig(const CastRtpParams& params,
86 AudioSenderConfig* config) { 90 AudioSenderConfig* config) {
87 config->sender_ssrc = params.payload.ssrc; 91 config->sender_ssrc = params.payload.ssrc;
88 config->incoming_feedback_ssrc = params.payload.feedback_ssrc; 92 config->incoming_feedback_ssrc = params.payload.feedback_ssrc;
89 config->rtp_config.payload_type = params.payload.payload_type; 93 config->rtp_config.payload_type = params.payload.payload_type;
90 config->use_external_encoder = false; 94 config->use_external_encoder = false;
91 config->frequency = params.payload.clock_rate; 95 config->frequency = params.payload.clock_rate;
92 config->channels = params.payload.channels; 96 config->channels = params.payload.channels;
93 config->bitrate = params.payload.max_bitrate; 97 config->bitrate = params.payload.max_bitrate * kBitrateMultiplier;
94 config->codec = media::cast::transport::kPcm16; 98 config->codec = media::cast::transport::kPcm16;
95 if (params.payload.codec_name == kCodecNameOpus) 99 if (params.payload.codec_name == kCodecNameOpus)
96 config->codec = media::cast::transport::kOpus; 100 config->codec = media::cast::transport::kOpus;
97 else 101 else
98 return false; 102 return false;
99 return true; 103 return true;
100 } 104 }
101 105
102 bool ToVideoSenderConfig(const CastRtpParams& params, 106 bool ToVideoSenderConfig(const CastRtpParams& params,
103 VideoSenderConfig* config) { 107 VideoSenderConfig* config) {
104 config->sender_ssrc = params.payload.ssrc; 108 config->sender_ssrc = params.payload.ssrc;
105 config->incoming_feedback_ssrc = params.payload.feedback_ssrc; 109 config->incoming_feedback_ssrc = params.payload.feedback_ssrc;
106 config->rtp_config.payload_type = params.payload.payload_type; 110 config->rtp_config.payload_type = params.payload.payload_type;
107 config->use_external_encoder = false; 111 config->use_external_encoder = false;
108 config->width = params.payload.width; 112 config->width = params.payload.width;
109 config->height = params.payload.height; 113 config->height = params.payload.height;
110 config->min_bitrate = config->start_bitrate = params.payload.min_bitrate; 114 config->min_bitrate = config->start_bitrate =
111 config->max_bitrate = params.payload.max_bitrate; 115 params.payload.min_bitrate * kBitrateMultiplier;
116 config->max_bitrate = params.payload.max_bitrate * kBitrateMultiplier;
112 if (params.payload.codec_name == kCodecNameVp8) 117 if (params.payload.codec_name == kCodecNameVp8)
113 config->codec = media::cast::transport::kVp8; 118 config->codec = media::cast::transport::kVp8;
114 else 119 else
115 return false; 120 return false;
116 return true; 121 return true;
117 } 122 }
118 123
119 } // namespace 124 } // namespace
120 125
121 // This class receives MediaStreamTrack events and video frames from a 126 // This class receives MediaStreamTrack events and video frames from a
(...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after
444 } 449 }
445 450
446 void CastRtpStream::DidEncounterError(const std::string& message) { 451 void CastRtpStream::DidEncounterError(const std::string& message) {
447 // Save the WeakPtr first because the error callback might delete this object. 452 // Save the WeakPtr first because the error callback might delete this object.
448 base::WeakPtr<CastRtpStream> ptr = weak_factory_.GetWeakPtr(); 453 base::WeakPtr<CastRtpStream> ptr = weak_factory_.GetWeakPtr();
449 error_callback_.Run(message); 454 error_callback_.Run(message);
450 content::RenderThread::Get()->GetMessageLoop()->PostTask( 455 content::RenderThread::Get()->GetMessageLoop()->PostTask(
451 FROM_HERE, 456 FROM_HERE,
452 base::Bind(&CastRtpStream::Stop, ptr)); 457 base::Bind(&CastRtpStream::Stop, ptr));
453 } 458 }
OLDNEW
« no previous file with comments | « chrome/renderer/media/cast_rtp_stream.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698