summaryrefslogtreecommitdiff
path: root/libavformat/mxfenc.c
diff options
context:
space:
mode:
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>2009-02-13 05:33:11 +0000
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>2009-02-13 05:33:11 +0000
commitbaaf7b1be1d459abd0810ae3a01fc4c4fa930459 (patch)
tree55364a724467602975e0e8e84be90050580e1b73 /libavformat/mxfenc.c
parentecc3a139b8858553e4ec8b3f4dd04510c6c94b03 (diff)
encode klv fill item length in fixed ber 4 bytes
Originally committed as revision 17199 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/mxfenc.c')
-rw-r--r--libavformat/mxfenc.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/libavformat/mxfenc.c b/libavformat/mxfenc.c
index 833f53aefb..d551609031 100644
--- a/libavformat/mxfenc.c
+++ b/libavformat/mxfenc.c
@@ -289,6 +289,12 @@ static int klv_encode_ber_length(ByteIOContext *pb, uint64_t len)
return 0;
}
+static void klv_encode_ber4_length(ByteIOContext *pb, int len)
+{
+ put_byte(pb, 0x80 + 3);
+ put_be24(pb, len);
+}
+
/*
* Get essence container ul index
*/
@@ -928,7 +934,7 @@ static int mxf_write_header_metadata_sets(AVFormatContext *s)
static unsigned klv_fill_size(uint64_t size)
{
unsigned pad = KAG_SIZE - (size & (KAG_SIZE-1));
- if (pad < 17) // smallest fill item possible
+ if (pad < 20) // smallest fill item possible
return pad + KAG_SIZE;
else
return pad & (KAG_SIZE-1);
@@ -1061,11 +1067,8 @@ static void mxf_write_klv_fill(AVFormatContext *s)
unsigned pad = klv_fill_size(url_ftell(s->pb));
if (pad) {
put_buffer(s->pb, klv_fill_key, 16);
- pad -= 16;
- pad -= klv_ber_length(pad);
- klv_encode_ber_length(s->pb, pad);
- for (; pad > 7; pad -= 8)
- put_be64(s->pb, 0);
+ pad -= 16 + 4;
+ klv_encode_ber4_length(s->pb, pad);
for (; pad; pad--)
put_byte(s->pb, 0);
assert(!(url_ftell(s->pb) & (KAG_SIZE-1)));