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 f27043db3f96f2aeb1b54339db860c2577f00cad..7ad8895a116dfc4927b35da9a5f55bc023903190 100644 |
--- a/chromecast/common/media/cma_param_traits.cc |
+++ b/chromecast/common/media/cma_param_traits.cc |
@@ -12,6 +12,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" |
@@ -29,6 +30,16 @@ IPC_ENUM_TRAITS_MAX_VALUE(media::VideoPixelFormat, media::PIXEL_FORMAT_MAX) |
namespace IPC { |
+template <> |
+struct ParamTraits<media::EncryptionScheme::PatternSpec> { |
+ typedef media::EncryptionScheme::PatternSpec param_type; |
+ static void Write(base::Pickle* m, const param_type& p); |
+ static bool Read(const base::Pickle* m, base::PickleIterator* iter, |
+ param_type* r); |
+ static void Log(const param_type& p, std::string* l); |
+}; |
+ |
+ |
void ParamTraits<media::AudioDecoderConfig>::Write( |
base::Pickle* m, |
const media::AudioDecoderConfig& p) { |
@@ -36,7 +47,7 @@ void ParamTraits<media::AudioDecoderConfig>::Write( |
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()); |
} |
@@ -48,15 +59,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_t> 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; |
} |
@@ -75,7 +88,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()); |
} |
@@ -90,17 +103,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_t> 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; |
} |
@@ -109,4 +123,45 @@ void ParamTraits<media::VideoDecoderConfig>::Log( |
l->append(base::StringPrintf("<VideoDecoderConfig>")); |
} |
+void ParamTraits<media::EncryptionScheme>::Write( |
+ base::Pickle* m, const param_type& p) { |
+ WriteParam(m, p.mode()); |
+ WriteParam(m, p.pattern()); |
+} |
+ |
+bool ParamTraits<media::EncryptionScheme>::Read( |
+ const base::Pickle* m, base::PickleIterator* iter, param_type* r) { |
+ media::EncryptionScheme::CipherMode mode; |
+ media::EncryptionScheme::PatternSpec pattern; |
+ if (!ReadParam(m, iter, &mode) || !ReadParam(m, iter, &pattern)) |
+ return false; |
+ *r = media::EncryptionScheme(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( |
+ base::Pickle* m, const param_type& p) { |
+ WriteParam(m, p.encrypt_blocks()); |
+ WriteParam(m, p.skip_blocks()); |
+} |
+ |
+bool ParamTraits<media::EncryptionScheme::PatternSpec>::Read( |
+ const base::Pickle* 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 |