| // Copyright 2016 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. |
| |
| #ifndef MEDIA_BASE_SUBSAMPLE_ENTRY_H_ |
| #define MEDIA_BASE_SUBSAMPLE_ENTRY_H_ |
| |
| #include <stddef.h> |
| #include <stdint.h> |
| |
| #include <vector> |
| |
| #include "media/base/media_export.h" |
| |
| namespace media { |
| |
| // The Common Encryption spec provides for subsample encryption, where portions |
| // of a sample are set in cleartext. A SubsampleEntry specifies the number of |
| // clear and encrypted bytes in each subsample. For decryption, all of the |
| // encrypted bytes in a sample should be considered a single logical stream, |
| // regardless of how they are divided into subsamples, and the clear bytes |
| // should not be considered as part of decryption. This is logically equivalent |
| // to concatenating all 'cypher_bytes' portions of subsamples, decrypting that |
| // result, and then copying each byte from the decrypted block over the |
| // position of the corresponding encrypted byte. |
| struct SubsampleEntry { |
| SubsampleEntry() : clear_bytes(0), cypher_bytes(0) {} |
| SubsampleEntry(uint32_t clear_bytes, uint32_t cypher_bytes) |
| : clear_bytes(clear_bytes), cypher_bytes(cypher_bytes) {} |
| uint32_t clear_bytes; |
| uint32_t cypher_bytes; |
| }; |
| |
| // Verifies that |subsamples| correctly specifies a buffer of length |
| // |input_size|. Returns false if the total of bytes specified in |subsamples| |
| // does not match |input_size|. |
| MEDIA_EXPORT bool VerifySubsamplesMatchSize( |
| const std::vector<SubsampleEntry>& subsamples, |
| size_t input_size); |
| |
| } // namespace media |
| |
| #endif // MEDIA_BASE_SUBSAMPLE_ENTRY_H_ |