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

Unified Diff: chromecast/media/cma/ipc_streamer/audio_decoder_config_marshaller.cc

Issue 557333003: Audio/video data streaming over shared memory. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address CR comments from patch set #1. Created 6 years, 3 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
Index: chromecast/media/cma/ipc_streamer/audio_decoder_config_marshaller.cc
diff --git a/chromecast/media/cma/ipc_streamer/audio_decoder_config_marshaller.cc b/chromecast/media/cma/ipc_streamer/audio_decoder_config_marshaller.cc
new file mode 100644
index 0000000000000000000000000000000000000000..d595bdaac3de361915c3a1dc1554605dde61c2ca
--- /dev/null
+++ b/chromecast/media/cma/ipc_streamer/audio_decoder_config_marshaller.cc
@@ -0,0 +1,70 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chromecast/media/cma/ipc_streamer/audio_decoder_config_marshaller.h"
+
+#include "base/basictypes.h"
+#include "base/logging.h"
+#include "chromecast/media/cma/ipc/media_message.h"
+#include "media/base/audio_decoder_config.h"
+
+namespace chromecast {
+namespace media {
+
+namespace {
+const size_t kMaxExtraDataSize = 16 * 1024;
+}
+
+// static
+void AudioDecoderConfigMarshaller::Write(
+ const ::media::AudioDecoderConfig& config, MediaMessage* msg) {
+ CHECK(msg->WritePod(config.codec()));
+ CHECK(msg->WritePod(config.channel_layout()));
+ CHECK(msg->WritePod(config.samples_per_second()));
+ CHECK(msg->WritePod(config.sample_format()));
+ CHECK(msg->WritePod(config.is_encrypted()));
+ CHECK(msg->WritePod(config.extra_data_size()));
+ if (config.extra_data_size() > 0)
+ CHECK(msg->WriteBuffer(config.extra_data(), config.extra_data_size()));
+}
+
+// static
+::media::AudioDecoderConfig AudioDecoderConfigMarshaller::Read(
+ MediaMessage* msg) {
+ ::media::AudioCodec codec;
+ ::media::SampleFormat sample_format;
+ ::media::ChannelLayout channel_layout;
+ int samples_per_second;
+ bool is_encrypted;
+ size_t extra_data_size;
+ scoped_ptr<uint8[]> extra_data;
+
+ CHECK(msg->ReadPod(&codec));
+ CHECK(msg->ReadPod(&channel_layout));
+ CHECK(msg->ReadPod(&samples_per_second));
+ CHECK(msg->ReadPod(&sample_format));
+ CHECK(msg->ReadPod(&is_encrypted));
+ CHECK(msg->ReadPod(&extra_data_size));
+
+ CHECK_GE(codec, ::media::kUnknownAudioCodec);
+ CHECK_LE(codec, ::media::kAudioCodecMax);
+ CHECK_GE(channel_layout, ::media::CHANNEL_LAYOUT_NONE);
+ CHECK_LE(channel_layout, ::media::CHANNEL_LAYOUT_MAX);
+ CHECK_GE(sample_format, ::media::kUnknownSampleFormat);
+ CHECK_LE(sample_format, ::media::kSampleFormatMax);
+ CHECK_LT(extra_data_size, kMaxExtraDataSize);
+ if (extra_data_size > 0) {
+ extra_data.reset(new uint8[extra_data_size]);
+ CHECK(msg->ReadBuffer(extra_data.get(), extra_data_size));
+ }
+
+ return ::media::AudioDecoderConfig(
+ codec, sample_format,
+ channel_layout, samples_per_second,
+ extra_data.get(), extra_data_size,
+ is_encrypted);
+}
+
+} // namespace media
+} // namespace chromecast

Powered by Google App Engine
This is Rietveld 408576698