aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/mpeg.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2004-02-01 13:06:46 +0000
committerMichael Niedermayer <michaelni@gmx.at>2004-02-01 13:06:46 +0000
commit4aa533be0335877db329e588621a67e5f924a313 (patch)
tree2a1a838b6527de47aa9645e816ec1a5d7ef8ec18 /libavformat/mpeg.c
parent0a87c409cc73a1e9934b156d3a789c30b27dde27 (diff)
downloadffmpeg-4aa533be0335877db329e588621a67e5f924a313.tar.gz
Patch for MPEG-2 VOB headers by (Jimmy Blair <blueskyjb at verizon dot net>)
Originally committed as revision 2740 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/mpeg.c')
-rw-r--r--libavformat/mpeg.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/libavformat/mpeg.c b/libavformat/mpeg.c
index 07d6b928e5..4362e1b1a6 100644
--- a/libavformat/mpeg.c
+++ b/libavformat/mpeg.c
@@ -104,12 +104,12 @@ static int put_pack_header(AVFormatContext *ctx,
if (s->is_mpeg2) {
/* clock extension */
put_bits(&pb, 9, 0);
- put_bits(&pb, 1, 1);
}
put_bits(&pb, 1, 1);
put_bits(&pb, 22, s->mux_rate);
put_bits(&pb, 1, 1);
if (s->is_mpeg2) {
+ put_bits(&pb, 1, 1);
put_bits(&pb, 5, 0x1f); /* reserved */
put_bits(&pb, 3, 0); /* stuffing length */
}
@@ -439,9 +439,10 @@ static void flush_packet(AVFormatContext *ctx, int stream_index,
put_be32(&ctx->pb, startcode);
put_be16(&ctx->pb, packet_size);
- /* stuffing */
- for(i=0;i<stuffing_size;i++)
- put_byte(&ctx->pb, 0xff);
+
+ if (!s->is_mpeg2)
+ for(i=0;i<stuffing_size;i++)
+ put_byte(&ctx->pb, 0xff);
if (s->is_mpeg2) {
put_byte(&ctx->pb, 0x80); /* mpeg2 id */
@@ -449,17 +450,17 @@ static void flush_packet(AVFormatContext *ctx, int stream_index,
if (pts != AV_NOPTS_VALUE) {
if (dts != pts) {
put_byte(&ctx->pb, 0xc0); /* flags */
- put_byte(&ctx->pb, header_len - 3);
+ put_byte(&ctx->pb, header_len - 3 + stuffing_size);
put_timestamp(&ctx->pb, 0x03, pts);
put_timestamp(&ctx->pb, 0x01, dts);
} else {
put_byte(&ctx->pb, 0x80); /* flags */
- put_byte(&ctx->pb, header_len - 3);
+ put_byte(&ctx->pb, header_len - 3 + stuffing_size);
put_timestamp(&ctx->pb, 0x02, pts);
}
} else {
put_byte(&ctx->pb, 0x00); /* flags */
- put_byte(&ctx->pb, header_len - 3);
+ put_byte(&ctx->pb, header_len - 3 + stuffing_size);
}
} else {
if (pts != AV_NOPTS_VALUE) {
@@ -490,6 +491,10 @@ static void flush_packet(AVFormatContext *ctx, int stream_index,
}
}
+ if (s->is_mpeg2)
+ for(i=0;i<stuffing_size;i++)
+ put_byte(&ctx->pb, 0xff);
+
/* output data */
put_buffer(&ctx->pb, stream->buffer, payload_size - stuffing_size);
put_flush_packet(&ctx->pb);