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

Unified Diff: chromecast/common/media/cma_param_traits.cc

Issue 1490613005: media config: expand is_encrypted to a struct. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years 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/common/media/cma_param_traits.cc
diff --git a/chromecast/common/media/cma_param_traits.cc b/chromecast/common/media/cma_param_traits.cc
index 2ae4fd917487465a2611330c5a6c6c10607cac1c..2cfc7f76b8a2161afa2cd99dc05270ccd99480f6 100644
--- a/chromecast/common/media/cma_param_traits.cc
+++ b/chromecast/common/media/cma_param_traits.cc
@@ -10,6 +10,7 @@
#include "content/public/common/common_param_traits.h"
#include "ipc/ipc_message_macros.h"
#include "media/base/audio_decoder_config.h"
+#include "media/base/encryption_scheme.h"
#include "media/base/video_decoder_config.h"
#include "ui/gfx/ipc/gfx_param_traits.h"
@@ -24,16 +25,26 @@ IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::VideoCodecProfile,
media::VIDEO_CODEC_PROFILE_MIN,
media::VIDEO_CODEC_PROFILE_MAX)
IPC_ENUM_TRAITS_MAX_VALUE(media::VideoPixelFormat, media::PIXEL_FORMAT_MAX)
+IPC_ENUM_TRAITS_MAX_VALUE(media::CipherMode, media::kCipherModeMax);
yucliu1 2015/12/10 00:12:19 This line should be in cma_param_traits_macros.h I
dougsteed 2015/12/14 21:19:01 Done.
namespace IPC {
+template <>
+struct ParamTraits<media::EncryptionScheme::PatternSpec> {
+ typedef media::EncryptionScheme::PatternSpec param_type;
+ static void Write(Message* m, const param_type& p);
+ static bool Read(const Message* m, base::PickleIterator* iter, param_type* r);
+ static void Log(const param_type& p, std::string* l);
+};
+
+
void ParamTraits<media::AudioDecoderConfig>::Write(
Message* m, const media::AudioDecoderConfig& p) {
WriteParam(m, p.codec());
WriteParam(m, p.sample_format());
WriteParam(m, p.channel_layout());
WriteParam(m, p.samples_per_second());
- WriteParam(m, p.is_encrypted());
+ WriteParam(m, p.encryption_scheme());
WriteParam(m, p.extra_data());
}
@@ -45,15 +56,17 @@ bool ParamTraits<media::AudioDecoderConfig>::Read(
media::SampleFormat sample_format;
media::ChannelLayout channel_layout;
int samples_per_second;
- bool is_encrypted;
+ media::EncryptionScheme encryption_scheme;
std::vector<uint8> extra_data;
if (!ReadParam(m, iter, &codec) || !ReadParam(m, iter, &sample_format) ||
!ReadParam(m, iter, &channel_layout) ||
!ReadParam(m, iter, &samples_per_second) ||
- !ReadParam(m, iter, &is_encrypted) || !ReadParam(m, iter, &extra_data))
+ !ReadParam(m, iter, &encryption_scheme) ||
+ !ReadParam(m, iter, &extra_data))
return false;
*r = media::AudioDecoderConfig(codec, sample_format, channel_layout,
- samples_per_second, extra_data, is_encrypted);
+ samples_per_second, extra_data,
+ encryption_scheme);
return true;
}
@@ -71,7 +84,7 @@ void ParamTraits<media::VideoDecoderConfig>::Write(
WriteParam(m, p.coded_size());
WriteParam(m, p.visible_rect());
WriteParam(m, p.natural_size());
- WriteParam(m, p.is_encrypted());
+ WriteParam(m, p.encryption_scheme());
WriteParam(m, p.extra_data());
}
@@ -86,17 +99,18 @@ bool ParamTraits<media::VideoDecoderConfig>::Read(
gfx::Size coded_size;
gfx::Rect visible_rect;
gfx::Size natural_size;
- bool is_encrypted;
+ media::EncryptionScheme encryption_scheme;
std::vector<uint8> extra_data;
if (!ReadParam(m, iter, &codec) || !ReadParam(m, iter, &profile) ||
!ReadParam(m, iter, &format) || !ReadParam(m, iter, &color_space) ||
!ReadParam(m, iter, &coded_size) || !ReadParam(m, iter, &visible_rect) ||
!ReadParam(m, iter, &natural_size) ||
- !ReadParam(m, iter, &is_encrypted) || !ReadParam(m, iter, &extra_data))
+ !ReadParam(m, iter, &encryption_scheme) ||
+ !ReadParam(m, iter, &extra_data))
return false;
*r = media::VideoDecoderConfig(codec, profile, format, color_space,
coded_size, visible_rect, natural_size,
- extra_data, is_encrypted);
+ extra_data, encryption_scheme);
return true;
}
@@ -105,4 +119,48 @@ void ParamTraits<media::VideoDecoderConfig>::Log(
l->append(base::StringPrintf("<VideoDecoderConfig>"));
}
+void ParamTraits<media::EncryptionScheme>::Write(
+ Message* m, const param_type& p) {
+ WriteParam(m, p.is_encrypted());
+ WriteParam(m, p.mode());
+ WriteParam(m, p.pattern());
+}
+
+bool ParamTraits<media::EncryptionScheme>::Read(
+ const Message* m, base::PickleIterator* iter, param_type* r) {
+ bool is_encrypted;
+ media::CipherMode mode;
+ media::EncryptionScheme::PatternSpec pattern;
+ if (!ReadParam(m, iter, &is_encrypted) || !ReadParam(m, iter, &mode) ||
+ !ReadParam(m, iter, &pattern))
+ return false;
+ *r = media::EncryptionScheme(is_encrypted, mode, pattern);
+ return true;
+}
+
+void ParamTraits<media::EncryptionScheme>::Log(
+ const param_type& p, std::string* l) {
+ l->append(base::StringPrintf("<EncryptionScheme>"));
+}
+
+void ParamTraits<media::EncryptionScheme::PatternSpec>::Write(
+ Message* m, const param_type& p) {
+ WriteParam(m, p.encrypt_blocks());
+ WriteParam(m, p.skip_blocks());
+}
+
+bool ParamTraits<media::EncryptionScheme::PatternSpec>::Read(
+ const Message* m, base::PickleIterator* iter, param_type* r) {
+ uint32_t encrypt_blocks, skip_blocks;
+ if (!ReadParam(m, iter, &encrypt_blocks) || !ReadParam(m, iter, &skip_blocks))
+ return false;
+ *r = media::EncryptionScheme::PatternSpec(encrypt_blocks, skip_blocks);
+ return true;
+}
+
+void ParamTraits<media::EncryptionScheme::PatternSpec>::Log(
+ const param_type& p, std::string* l) {
+ l->append(base::StringPrintf("<PatternSpec>"));
+}
+
} // namespace IPC

Powered by Google App Engine
This is Rietveld 408576698