diff options
| author | jhurst <jhurst@cinecert.com> | 2020-10-08 09:31:16 -0700 |
|---|---|---|
| committer | jhurst <jhurst@cinecert.com> | 2020-10-08 09:31:16 -0700 |
| commit | f8b52f9e183b3d20e050a8760f5e8caed35b2e9d (patch) | |
| tree | cc9b459d6b4218541ec2be06472642a970e7f919 /src/h__Writer.cpp | |
| parent | 25416a414301ddf79f499373c279740a519a27b1 (diff) | |
| parent | d417531ed59434ecaee487adfdf54646408479bf (diff) | |
Merge branch 'master' into sha1_builtin
Diffstat (limited to 'src/h__Writer.cpp')
| -rwxr-xr-x | src/h__Writer.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/src/h__Writer.cpp b/src/h__Writer.cpp index fc7f060..0c56b4c 100755 --- a/src/h__Writer.cpp +++ b/src/h__Writer.cpp @@ -374,6 +374,15 @@ ASDCP::Write_EKLV_Packet(Kumu::FileWriter& File, const ASDCP::Dictionary& Dict, byte_t overhead[128]; Kumu::MemIOWriter Overhead(overhead, 128); + // We declare HMACOverhead and its buffer in the outer scope, even though it is not used on + // unencrypted content: the reason is that File.Writev(const byte_t* buf, ui32_t buf_len) doesn't + // write data right away but saves a pointer on the buffer. And we write all the buffers at the end + // when calling File.writev(). + // Declaring the buffer variable in an inner scope means the buffer will go out of scope + // before the data it contains has been actually written, which means its content could be + // overwritten/get corrupted. + byte_t hmoverhead[512]; + Kumu::MemIOWriter HMACOverhead(hmoverhead, 512); if ( FrameBuf.Size() == 0 ) { @@ -455,9 +464,6 @@ ASDCP::Write_EKLV_Packet(Kumu::FileWriter& File, const ASDCP::Dictionary& Dict, { StreamOffset += CtFrameBuf.Size(); - byte_t hmoverhead[512]; - Kumu::MemIOWriter HMACOverhead(hmoverhead, 512); - // write the HMAC if ( Info.UsesHMAC ) { |
