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

Unified Diff: chromecast/media/cma/decoder/cast_audio_decoder_linux.cc

Issue 1900233006: [Chromecast] Remove command-line switch to change the number of mixer output channels (Closed) Base URL: https://chromium.googlesource.com/chromium/src@master
Patch Set: Created 4 years, 8 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 | « chromecast/media/cma/decoder/BUILD.gn ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chromecast/media/cma/decoder/cast_audio_decoder_linux.cc
diff --git a/chromecast/media/cma/decoder/cast_audio_decoder_linux.cc b/chromecast/media/cma/decoder/cast_audio_decoder_linux.cc
index 756eabd6e85f57ae615a8a57606625dec302a847..b5b2e24c8e349b0ece360064008bf4dde04ca023 100644
--- a/chromecast/media/cma/decoder/cast_audio_decoder_linux.cc
+++ b/chromecast/media/cma/decoder/cast_audio_decoder_linux.cc
@@ -11,13 +11,10 @@
#include <vector>
#include "base/bind.h"
-#include "base/command_line.h"
#include "base/location.h"
#include "base/logging.h"
#include "base/macros.h"
#include "base/single_thread_task_runner.h"
-#include "base/strings/string_number_conversions.h"
-#include "chromecast/base/chromecast_switches.h"
#include "chromecast/media/cma/base/decoder_buffer_adapter.h"
#include "chromecast/media/cma/base/decoder_buffer_base.h"
#include "chromecast/media/cma/base/decoder_config_adapter.h"
@@ -50,8 +47,7 @@ const uint8_t kFakeOpusExtraData[19] = {
0, // offset 18, stereo mapping
};
-const int kStereoOutputChannelCount = 2;
-const int kLayout71OutputChannelCount = 8;
+const int kOutputChannelCount = 2; // Always output stereo audio.
const int kMaxChannelInput = 2;
class CastAudioDecoderImpl : public CastAudioDecoder {
@@ -65,20 +61,7 @@ class CastAudioDecoderImpl : public CastAudioDecoder {
output_format_(output_format),
initialized_(false),
decode_pending_(false),
- weak_factory_(this) {
- if (base::CommandLine::InitializedForCurrentProcess() &&
- base::CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kAlsaNumOutputChannels)) {
- base::StringToInt(
- base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII(
- switches::kAlsaNumOutputChannels),
- &num_output_channels_);
- } else {
- num_output_channels_ = kStereoOutputChannelCount;
- }
- DCHECK(num_output_channels_ == kStereoOutputChannelCount ||
- num_output_channels_ == kLayout71OutputChannelCount);
- }
+ weak_factory_(this) {}
~CastAudioDecoderImpl() override {}
@@ -86,24 +69,12 @@ class CastAudioDecoderImpl : public CastAudioDecoder {
DCHECK(!initialized_);
DCHECK_LE(config_.channel_number, kMaxChannelInput);
config_ = config;
-
if (config_.channel_number == 1) {
// If the input is mono, create a ChannelMixer to convert mono to stereo.
// TODO(kmackay) Support other channel format conversions?
mixer_.reset(new ::media::ChannelMixer(::media::CHANNEL_LAYOUT_MONO,
::media::CHANNEL_LAYOUT_STEREO));
}
- if (num_output_channels_ == kLayout71OutputChannelCount) {
- // If there are 8 output channel, create a Channel Mixer to convert
- // stereo to CHANNEL_LAYOUT_7_1.
- // TODO(tianyuwang): This is a hack for 8 channel test USB speaker.
- // Channel mixer from MONO TO LAYOUT 7_1 doesn't work with the current
- // test USB speaker. As a result, we need to convert MONO channel
- // to STEREO first then convert it to LAYOUT_7_1.
- mixer_7_1_.reset(new ::media::ChannelMixer(::media::CHANNEL_LAYOUT_STEREO,
- ::media::CHANNEL_LAYOUT_7_1));
- }
-
base::WeakPtr<CastAudioDecoderImpl> self = weak_factory_.GetWeakPtr();
if (config.codec == media::kCodecOpus) {
// Insert fake extradata to make OpusAudioDecoder work with v2mirroring.
@@ -240,28 +211,19 @@ class CastAudioDecoderImpl : public CastAudioDecoder {
if (mixer_) {
// Convert to stereo if necessary.
std::unique_ptr<::media::AudioBus> converted_to_stereo =
- ::media::AudioBus::Create(kStereoOutputChannelCount, num_frames);
+ ::media::AudioBus::Create(kOutputChannelCount, num_frames);
mixer_->Transform(decoded.get(), converted_to_stereo.get());
decoded.swap(converted_to_stereo);
}
- // TODO(tianyuwang): Remove this hack for 7_1 USB test speaker.
- if (mixer_7_1_) {
- // Convert to layout 7_1 if necessary.
- std::unique_ptr<::media::AudioBus> converted_to_7_1 =
- ::media::AudioBus::Create(num_output_channels_, num_frames);
- mixer_7_1_->Transform(decoded.get(), converted_to_7_1.get());
- decoded.swap(converted_to_7_1);
- }
-
// Convert to the desired output format.
return FinishConversion(decoded.get());
}
scoped_refptr<media::DecoderBufferBase> FinishConversion(
::media::AudioBus* bus) {
- DCHECK_EQ(num_output_channels_, bus->channels());
- int size = bus->frames() * num_output_channels_ *
+ DCHECK_EQ(kOutputChannelCount, bus->channels());
+ int size = bus->frames() * kOutputChannelCount *
OutputFormatSizeInBytes(output_format_);
scoped_refptr<::media::DecoderBuffer> result(
new ::media::DecoderBuffer(size));
@@ -295,9 +257,7 @@ class CastAudioDecoderImpl : public CastAudioDecoder {
std::unique_ptr<::media::AudioDecoder> decoder_;
std::queue<DecodeBufferCallbackPair> decode_queue_;
bool initialized_;
- int num_output_channels_;
std::unique_ptr<::media::ChannelMixer> mixer_;
- std::unique_ptr<::media::ChannelMixer> mixer_7_1_;
bool decode_pending_;
std::vector<scoped_refptr<::media::AudioBuffer>> decoded_chunks_;
base::WeakPtrFactory<CastAudioDecoderImpl> weak_factory_;
« no previous file with comments | « chromecast/media/cma/decoder/BUILD.gn ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698