aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/matroskaenc.c
diff options
context:
space:
mode:
authorDavid Conrad <lessen42@gmail.com>2007-09-05 00:23:00 +0000
committerDavid Conrad <lessen42@gmail.com>2007-09-05 00:23:00 +0000
commit98186e416d47772735377bffe0c1d97f24d02149 (patch)
tree884d64c4ef419731886c1ea800cd2ab9ae5dee2c /libavformat/matroskaenc.c
parent6d50a935c9d9b27214da22db4ef44da28151bf93 (diff)
downloadffmpeg-98186e416d47772735377bffe0c1d97f24d02149.tar.gz
Start a new cluster every 5 MB or 5 seconds
Originally committed as revision 10306 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/matroskaenc.c')
-rw-r--r--libavformat/matroskaenc.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/libavformat/matroskaenc.c b/libavformat/matroskaenc.c
index e13be953b2..e6e51d8b13 100644
--- a/libavformat/matroskaenc.c
+++ b/libavformat/matroskaenc.c
@@ -27,6 +27,7 @@
typedef struct MatroskaMuxContext {
offset_t segment;
offset_t cluster;
+ uint64_t cluster_pts;
} MatroskaMuxContext;
static void put_ebml_id(ByteIOContext *pb, unsigned int id)
@@ -249,18 +250,28 @@ static int mkv_write_header(AVFormatContext *s)
mkv->cluster = start_ebml_master(pb, MATROSKA_ID_CLUSTER);
put_ebml_uint(pb, MATROSKA_ID_CLUSTERTIMECODE, 0);
+ mkv->cluster_pts = 0;
return 0;
}
static int mkv_write_packet(AVFormatContext *s, AVPacket *pkt)
{
+ MatroskaMuxContext *mkv = s->priv_data;
ByteIOContext *pb = &s->pb;
offset_t block;
+ // start a new cluster every 5 MB or 5 sec
+ if (url_ftell(pb) > mkv->cluster + 5*1024*1024 || pkt->pts > mkv->cluster_pts + 5000) {
+ end_ebml_master(pb, mkv->cluster);
+ mkv->cluster = start_ebml_master(pb, MATROSKA_ID_CLUSTER);
+ put_ebml_uint(pb, MATROSKA_ID_CLUSTERTIMECODE, pkt->pts);
+ mkv->cluster_pts = pkt->pts;
+ }
+
block = start_ebml_master(pb, MATROSKA_ID_SIMPLEBLOCK);
put_byte(pb, 0x80 | pkt->stream_index); // this assumes stream_index is less than 127
- put_be16(pb, pkt->pts);
+ put_be16(pb, pkt->pts - mkv->cluster_pts);
put_byte(pb, !!(pkt->flags & PKT_FLAG_KEY));
put_buffer(pb, pkt->data, pkt->size);
end_ebml_master(pb, block);