3 * Copyright (c) 2000, 2001, 2002 Fabrice Bellard
5 * This file is part of FFmpeg.
7 * FFmpeg is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * FFmpeg is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with FFmpeg; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 #include "libavutil/fifo.h"
23 #include "libavutil/log.h"
24 #include "libavutil/mathematics.h"
25 #include "libavutil/opt.h"
26 #include "libavcodec/put_bits.h"
31 #define MAX_PAYLOAD_SIZE 4096
36 typedef struct PacketDesc {
42 struct PacketDesc *next;
48 int max_buffer_size; /* in bytes */
50 PacketDesc *predecode_packet;
51 PacketDesc *premux_packet;
52 PacketDesc **next_packet;
54 uint8_t lpcm_header[3];
58 int64_t vobu_start_pts;
63 int packet_size; /* required packet size */
65 int pack_header_freq; /* frequency (in packets^-1) at which we send pack headers */
66 int system_header_freq;
67 int system_header_size;
68 int mux_rate; /* bitrate in units of 50 bytes/s */
76 int64_t last_scr; /* current system clock */
78 double vcd_padding_bitrate; //FIXME floats
79 int64_t vcd_padding_bytes_written;
84 extern AVOutputFormat ff_mpeg1vcd_muxer;
85 extern AVOutputFormat ff_mpeg2dvd_muxer;
86 extern AVOutputFormat ff_mpeg2svcd_muxer;
87 extern AVOutputFormat ff_mpeg2vob_muxer;
89 static int put_pack_header(AVFormatContext *ctx,
90 uint8_t *buf, int64_t timestamp)
92 MpegMuxContext *s = ctx->priv_data;
95 init_put_bits(&pb, buf, 128);
97 put_bits32(&pb, PACK_START_CODE);
99 put_bits(&pb, 2, 0x1);
101 put_bits(&pb, 4, 0x2);
103 put_bits(&pb, 3, (uint32_t)((timestamp >> 30) & 0x07));
105 put_bits(&pb, 15, (uint32_t)((timestamp >> 15) & 0x7fff));
107 put_bits(&pb, 15, (uint32_t)((timestamp ) & 0x7fff));
110 /* clock extension */
114 put_bits(&pb, 22, s->mux_rate);
118 put_bits(&pb, 5, 0x1f); /* reserved */
119 put_bits(&pb, 3, 0); /* stuffing length */
122 return put_bits_ptr(&pb) - pb.buf;
125 static int put_system_header(AVFormatContext *ctx, uint8_t *buf,int only_for_stream_id)
127 MpegMuxContext *s = ctx->priv_data;
128 int size, i, private_stream_coded, id;
131 init_put_bits(&pb, buf, 128);
133 put_bits32(&pb, SYSTEM_HEADER_START_CODE);
134 put_bits(&pb, 16, 0);
137 put_bits(&pb, 22, s->mux_rate); /* maximum bit rate of the multiplexed stream */
138 put_bits(&pb, 1, 1); /* marker */
139 if (s->is_vcd && only_for_stream_id==VIDEO_ID) {
140 /* This header applies only to the video stream (see VCD standard p. IV-7)*/
143 put_bits(&pb, 6, s->audio_bound);
146 /* see VCD standard, p. IV-7*/
150 put_bits(&pb, 1, 0); /* variable bitrate*/
151 put_bits(&pb, 1, 0); /* non constrainted bit stream */
154 if (s->is_vcd || s->is_dvd) {
155 /* see VCD standard p IV-7 */
156 put_bits(&pb, 1, 1); /* audio locked */
157 put_bits(&pb, 1, 1); /* video locked */
159 put_bits(&pb, 1, 0); /* audio locked */
160 put_bits(&pb, 1, 0); /* video locked */
163 put_bits(&pb, 1, 1); /* marker */
165 if (s->is_vcd && (only_for_stream_id & 0xe0) == AUDIO_ID) {
166 /* This header applies only to the audio stream (see VCD standard p. IV-7)*/
169 put_bits(&pb, 5, s->video_bound);
172 put_bits(&pb, 1, 0); /* packet_rate_restriction_flag */
173 put_bits(&pb, 7, 0x7f); /* reserved byte */
175 put_bits(&pb, 8, 0xff); /* reserved byte */
177 /* DVD-Video Stream_bound entries
178 id (0xB9) video, maximum P-STD for stream 0xE0. (P-STD_buffer_bound_scale = 1)
179 id (0xB8) audio, maximum P-STD for any MPEG audio (0xC0 to 0xC7) streams. If there are none set to 4096 (32x128). (P-STD_buffer_bound_scale = 0)
180 id (0xBD) private stream 1 (audio other than MPEG and subpictures). (P-STD_buffer_bound_scale = 1)
181 id (0xBF) private stream 2, NAV packs, set to 2x1024. */
184 int P_STD_max_video = 0;
185 int P_STD_max_mpeg_audio = 0;
186 int P_STD_max_mpeg_PS1 = 0;
188 for(i=0;i<ctx->nb_streams;i++) {
189 StreamInfo *stream = ctx->streams[i]->priv_data;
192 if (id == 0xbd && stream->max_buffer_size > P_STD_max_mpeg_PS1) {
193 P_STD_max_mpeg_PS1 = stream->max_buffer_size;
194 } else if (id >= 0xc0 && id <= 0xc7 && stream->max_buffer_size > P_STD_max_mpeg_audio) {
195 P_STD_max_mpeg_audio = stream->max_buffer_size;
196 } else if (id == 0xe0 && stream->max_buffer_size > P_STD_max_video) {
197 P_STD_max_video = stream->max_buffer_size;
202 put_bits(&pb, 8, 0xb9); /* stream ID */
205 put_bits(&pb, 13, P_STD_max_video / 1024);
208 if (P_STD_max_mpeg_audio == 0)
209 P_STD_max_mpeg_audio = 4096;
210 put_bits(&pb, 8, 0xb8); /* stream ID */
213 put_bits(&pb, 13, P_STD_max_mpeg_audio / 128);
215 /* private stream 1 */
216 put_bits(&pb, 8, 0xbd); /* stream ID */
219 put_bits(&pb, 13, P_STD_max_mpeg_PS1 / 128);
221 /* private stream 2 */
222 put_bits(&pb, 8, 0xbf); /* stream ID */
225 put_bits(&pb, 13, 2);
228 /* audio stream info */
229 private_stream_coded = 0;
230 for(i=0;i<ctx->nb_streams;i++) {
231 StreamInfo *stream = ctx->streams[i]->priv_data;
234 /* For VCDs, only include the stream info for the stream
235 that the pack which contains this system belongs to.
236 (see VCD standard p. IV-7) */
237 if ( !s->is_vcd || stream->id==only_for_stream_id
238 || only_for_stream_id==0) {
242 /* special case for private streams (AC-3 uses that) */
243 if (private_stream_coded)
245 private_stream_coded = 1;
248 put_bits(&pb, 8, id); /* stream ID */
253 put_bits(&pb, 13, stream->max_buffer_size / 128);
257 put_bits(&pb, 13, stream->max_buffer_size / 1024);
264 size = put_bits_ptr(&pb) - pb.buf;
265 /* patch packet size */
266 buf[4] = (size - 6) >> 8;
267 buf[5] = (size - 6) & 0xff;
272 static int get_system_header_size(AVFormatContext *ctx)
274 int buf_index, i, private_stream_coded;
276 MpegMuxContext *s = ctx->priv_data;
279 return 18; // DVD-Video system headers are 18 bytes fixed length.
282 private_stream_coded = 0;
283 for(i=0;i<ctx->nb_streams;i++) {
284 stream = ctx->streams[i]->priv_data;
285 if (stream->id < 0xc0) {
286 if (private_stream_coded)
288 private_stream_coded = 1;
295 static int mpeg_mux_init(AVFormatContext *ctx)
297 MpegMuxContext *s = ctx->priv_data;
298 int bitrate, i, mpa_id, mpv_id, mps_id, ac3_id, dts_id, lpcm_id, j;
304 s->packet_number = 0;
305 s->is_vcd = (CONFIG_MPEG1VCD_MUXER && ctx->oformat == &ff_mpeg1vcd_muxer);
306 s->is_svcd = (CONFIG_MPEG2SVCD_MUXER && ctx->oformat == &ff_mpeg2svcd_muxer);
307 s->is_mpeg2 = ((CONFIG_MPEG2VOB_MUXER && ctx->oformat == &ff_mpeg2vob_muxer) ||
308 (CONFIG_MPEG2DVD_MUXER && ctx->oformat == &ff_mpeg2dvd_muxer) ||
309 (CONFIG_MPEG2SVCD_MUXER && ctx->oformat == &ff_mpeg2svcd_muxer));
310 s->is_dvd = (CONFIG_MPEG2DVD_MUXER && ctx->oformat == &ff_mpeg2dvd_muxer);
312 if(ctx->packet_size) {
313 if (ctx->packet_size < 20 || ctx->packet_size > (1 << 23) + 10) {
314 av_log(ctx, AV_LOG_ERROR, "Invalid packet size %d\n",
318 s->packet_size = ctx->packet_size;
320 s->packet_size = 2048;
322 s->vcd_padding_bytes_written = 0;
323 s->vcd_padding_bitrate=0;
333 for(i=0;i<ctx->nb_streams;i++) {
334 st = ctx->streams[i];
335 stream = av_mallocz(sizeof(StreamInfo));
338 st->priv_data = stream;
340 avpriv_set_pts_info(st, 64, 1, 90000);
342 switch(st->codec->codec_type) {
343 case AVMEDIA_TYPE_AUDIO:
344 if (st->codec->codec_id == CODEC_ID_AC3) {
345 stream->id = ac3_id++;
346 } else if (st->codec->codec_id == CODEC_ID_DTS) {
347 stream->id = dts_id++;
348 } else if (st->codec->codec_id == CODEC_ID_PCM_S16BE) {
349 stream->id = lpcm_id++;
350 for(j = 0; j < 4; j++) {
351 if (lpcm_freq_tab[j] == st->codec->sample_rate)
356 if (st->codec->channels > 8)
358 stream->lpcm_header[0] = 0x0c;
359 stream->lpcm_header[1] = (st->codec->channels - 1) | (j << 4);
360 stream->lpcm_header[2] = 0x80;
361 stream->lpcm_align = st->codec->channels * 2;
363 stream->id = mpa_id++;
366 /* This value HAS to be used for VCD (see VCD standard, p. IV-7).
367 Right now it is also used for everything else.*/
368 stream->max_buffer_size = 4 * 1024;
371 case AVMEDIA_TYPE_VIDEO:
372 stream->id = mpv_id++;
373 if (st->codec->rc_buffer_size)
374 stream->max_buffer_size = 6*1024 + st->codec->rc_buffer_size/8;
376 av_log(ctx, AV_LOG_WARNING, "VBV buffer size not set, muxing may fail\n");
377 stream->max_buffer_size = 230*1024; //FIXME this is probably too small as default
380 /* see VCD standard, p. IV-7*/
381 stream->max_buffer_size = 46 * 1024;
383 /* This value HAS to be used for SVCD (see SVCD standard, p. 26 V.2.3.2).
384 Right now it is also used for everything else.*/
385 stream->max_buffer_size = 230 * 1024;
389 case AVMEDIA_TYPE_SUBTITLE:
390 stream->id = mps_id++;
391 stream->max_buffer_size = 16 * 1024;
396 stream->fifo= av_fifo_alloc(16);
403 for(i=0;i<ctx->nb_streams;i++) {
405 st = ctx->streams[i];
406 stream = (StreamInfo*) st->priv_data;
408 if(st->codec->rc_max_rate || stream->id==VIDEO_ID)
409 codec_rate= st->codec->rc_max_rate;
411 codec_rate= st->codec->bit_rate;
414 codec_rate= (1<<21)*8*50/ctx->nb_streams;
416 bitrate += codec_rate;
418 if ((stream->id & 0xe0) == AUDIO_ID)
419 audio_bitrate += codec_rate;
420 else if (stream->id==VIDEO_ID)
421 video_bitrate += codec_rate;
425 /* we increase slightly the bitrate to take into account the
426 headers. XXX: compute it exactly */
427 bitrate += bitrate / 20;
429 s->mux_rate = (bitrate + (8 * 50) - 1) / (8 * 50);
433 double overhead_rate;
435 /* The VCD standard mandates that the mux_rate field is 3528
436 (see standard p. IV-6).
437 The value is actually "wrong", i.e. if you calculate
438 it using the normal formula and the 75 sectors per second transfer
439 rate you get a different value because the real pack size is 2324,
440 not 2352. But the standard explicitly specifies that the mux_rate
441 field in the header must have this value.*/
442 // s->mux_rate=2352 * 75 / 50; /* = 3528*/
444 /* The VCD standard states that the muxed stream must be
445 exactly 75 packs / second (the data rate of a single speed cdrom).
446 Since the video bitrate (probably 1150000 bits/sec) will be below
447 the theoretical maximum we have to add some padding packets
448 to make up for the lower data rate.
449 (cf. VCD standard p. IV-6 )*/
451 /* Add the header overhead to the data rate.
452 2279 data bytes per audio pack, 2294 data bytes per video pack*/
453 overhead_rate = ((audio_bitrate / 8.0) / 2279) * (2324 - 2279);
454 overhead_rate += ((video_bitrate / 8.0) / 2294) * (2324 - 2294);
457 /* Add padding so that the full bitrate is 2324*75 bytes/sec */
458 s->vcd_padding_bitrate = 2324 * 75 * 8 - (bitrate + overhead_rate);
461 if (s->is_vcd || s->is_mpeg2)
463 s->pack_header_freq = 1;
465 /* every 2 seconds */
466 s->pack_header_freq = 2 * bitrate / s->packet_size / 8;
468 /* the above seems to make pack_header_freq zero sometimes */
469 if (s->pack_header_freq == 0)
470 s->pack_header_freq = 1;
473 /* every 200 packets. Need to look at the spec. */
474 s->system_header_freq = s->pack_header_freq * 40;
476 /* the standard mandates that there are only two system headers
477 in the whole file: one in the first packet of each stream.
478 (see standard p. IV-7 and IV-8) */
479 s->system_header_freq = 0x7fffffff;
481 s->system_header_freq = s->pack_header_freq * 5;
483 for(i=0;i<ctx->nb_streams;i++) {
484 stream = ctx->streams[i]->priv_data;
485 stream->packet_number = 0;
487 s->system_header_size = get_system_header_size(ctx);
491 for(i=0;i<ctx->nb_streams;i++) {
492 av_free(ctx->streams[i]->priv_data);
494 return AVERROR(ENOMEM);
497 static inline void put_timestamp(AVIOContext *pb, int id, int64_t timestamp)
501 (((timestamp >> 30) & 0x07) << 1) |
503 avio_wb16(pb, (uint16_t)((((timestamp >> 15) & 0x7fff) << 1) | 1));
504 avio_wb16(pb, (uint16_t)((((timestamp ) & 0x7fff) << 1) | 1));
508 /* return the number of padding bytes that should be inserted into
509 the multiplexed stream.*/
510 static int get_vcd_padding_size(AVFormatContext *ctx, int64_t pts)
512 MpegMuxContext *s = ctx->priv_data;
515 if (s->vcd_padding_bitrate > 0 && pts!=AV_NOPTS_VALUE)
517 int64_t full_pad_bytes;
519 full_pad_bytes = (int64_t)((s->vcd_padding_bitrate * (pts / 90000.0)) / 8.0); //FIXME this is wrong
520 pad_bytes = (int) (full_pad_bytes - s->vcd_padding_bytes_written);
523 /* might happen if we have already padded to a later timestamp. This
524 can occur if another stream has already advanced further.*/
532 #if 0 /* unused, remove? */
533 /* return the exact available payload size for the next packet for
534 stream 'stream_index'. 'pts' and 'dts' are only used to know if
535 timestamps are needed in the packet header. */
536 static int get_packet_payload_size(AVFormatContext *ctx, int stream_index,
537 int64_t pts, int64_t dts)
539 MpegMuxContext *s = ctx->priv_data;
543 stream = ctx->streams[stream_index]->priv_data;
546 if (((s->packet_number % s->pack_header_freq) == 0)) {
547 /* pack header size */
554 /* there is exactly one system header for each stream in a VCD MPEG,
555 One in the very first video packet and one in the very first
556 audio packet (see VCD standard p. IV-7 and IV-8).*/
558 if (stream->packet_number==0)
559 /* The system headers refer only to the stream they occur in,
560 so they have a constant size.*/
564 if ((s->packet_number % s->system_header_freq) == 0)
565 buf_index += s->system_header_size;
569 if ((s->is_vcd && stream->packet_number==0)
570 || (s->is_svcd && s->packet_number==0))
571 /* the first pack of each stream contains only the pack header,
572 the system header and some padding (see VCD standard p. IV-6)
573 Add the padding size, so that the actual payload becomes 0.*/
574 buf_index += s->packet_size - buf_index;
576 /* packet header size */
580 if (stream->packet_number==0)
581 buf_index += 3; /* PES extension */
582 buf_index += 1; /* obligatory stuffing byte */
584 if (pts != AV_NOPTS_VALUE) {
595 if (stream->id < 0xc0) {
596 /* AC-3/LPCM private data header */
598 if (stream->id >= 0xa0) {
601 /* NOTE: we round the payload size to an integer number of
603 n = (s->packet_size - buf_index) % stream->lpcm_align;
605 buf_index += (stream->lpcm_align - n);
609 if (s->is_vcd && (stream->id & 0xe0) == AUDIO_ID)
610 /* The VCD standard demands that 20 zero bytes follow
611 each audio packet (see standard p. IV-8).*/
614 return s->packet_size - buf_index;
618 /* Write an MPEG padding packet header. */
619 static void put_padding_packet(AVFormatContext *ctx, AVIOContext *pb,int packet_bytes)
621 MpegMuxContext *s = ctx->priv_data;
624 avio_wb32(pb, PADDING_STREAM);
625 avio_wb16(pb, packet_bytes - 6);
632 for(i=0;i<packet_bytes;i++)
636 static int get_nb_frames(AVFormatContext *ctx, StreamInfo *stream, int len){
638 PacketDesc *pkt_desc= stream->premux_packet;
641 if(pkt_desc->size == pkt_desc->unwritten_size)
643 len -= pkt_desc->unwritten_size;
644 pkt_desc= pkt_desc->next;
650 /* flush the packet on stream stream_index */
651 static int flush_packet(AVFormatContext *ctx, int stream_index,
652 int64_t pts, int64_t dts, int64_t scr, int trailer_size)
654 MpegMuxContext *s = ctx->priv_data;
655 StreamInfo *stream = ctx->streams[stream_index]->priv_data;
657 int size, payload_size, startcode, id, stuffing_size, i, header_len;
660 int zero_trail_bytes = 0;
661 int pad_packet_bytes = 0;
663 int general_pack = 0; /*"general" pack without data specific to one stream?*/
668 av_dlog(ctx, "packet ID=%2x PTS=%0.3f\n", id, pts / 90000.0);
672 if ((s->packet_number % s->pack_header_freq) == 0 || s->last_scr != scr) {
673 /* output pack and systems header if needed */
674 size = put_pack_header(ctx, buf_ptr, scr);
679 /* there is exactly one system header for each stream in a VCD MPEG,
680 One in the very first video packet and one in the very first
681 audio packet (see VCD standard p. IV-7 and IV-8).*/
683 if (stream->packet_number==0) {
684 size = put_system_header(ctx, buf_ptr, id);
687 } else if (s->is_dvd) {
688 if (stream->align_iframe || s->packet_number == 0){
689 int PES_bytes_to_fill = s->packet_size - size - 10;
691 if (pts != AV_NOPTS_VALUE) {
693 PES_bytes_to_fill -= 5 + 5;
695 PES_bytes_to_fill -= 5;
698 if (stream->bytes_to_iframe == 0 || s->packet_number == 0) {
699 size = put_system_header(ctx, buf_ptr, 0);
701 size = buf_ptr - buffer;
702 avio_write(ctx->pb, buffer, size);
704 avio_wb32(ctx->pb, PRIVATE_STREAM_2);
705 avio_wb16(ctx->pb, 0x03d4); // length
706 avio_w8(ctx->pb, 0x00); // substream ID, 00=PCI
707 for (i = 0; i < 979; i++)
708 avio_w8(ctx->pb, 0x00);
710 avio_wb32(ctx->pb, PRIVATE_STREAM_2);
711 avio_wb16(ctx->pb, 0x03fa); // length
712 avio_w8(ctx->pb, 0x01); // substream ID, 01=DSI
713 for (i = 0; i < 1017; i++)
714 avio_w8(ctx->pb, 0x00);
716 memset(buffer, 0, 128);
719 stream->align_iframe = 0;
720 scr += s->packet_size*90000LL / (s->mux_rate*50LL); //FIXME rounding and first few bytes of each packet
721 size = put_pack_header(ctx, buf_ptr, scr);
725 } else if (stream->bytes_to_iframe < PES_bytes_to_fill) {
726 pad_packet_bytes = PES_bytes_to_fill - stream->bytes_to_iframe;
730 if ((s->packet_number % s->system_header_freq) == 0) {
731 size = put_system_header(ctx, buf_ptr, 0);
736 size = buf_ptr - buffer;
737 avio_write(ctx->pb, buffer, size);
739 packet_size = s->packet_size - size;
741 if (s->is_vcd && (id & 0xe0) == AUDIO_ID)
742 /* The VCD standard demands that 20 zero bytes follow
743 each audio pack (see standard p. IV-8).*/
744 zero_trail_bytes += 20;
746 if ((s->is_vcd && stream->packet_number==0)
747 || (s->is_svcd && s->packet_number==0)) {
748 /* for VCD the first pack of each stream contains only the pack header,
749 the system header and lots of padding (see VCD standard p. IV-6).
750 In the case of an audio pack, 20 zero bytes are also added at
752 /* For SVCD we fill the very first pack to increase compatibility with
753 some DVD players. Not mandated by the standard.*/
755 general_pack = 1; /* the system header refers to both streams and no stream data*/
756 pad_packet_bytes = packet_size - zero_trail_bytes;
759 packet_size -= pad_packet_bytes + zero_trail_bytes;
761 if (packet_size > 0) {
763 /* packet header size */
769 if (stream->packet_number==0)
770 header_len += 3; /* PES extension */
771 header_len += 1; /* obligatory stuffing byte */
775 if (pts != AV_NOPTS_VALUE) {
785 payload_size = packet_size - header_len;
787 startcode = PRIVATE_STREAM_1;
795 startcode = 0x100 + id;
798 stuffing_size = payload_size - av_fifo_size(stream->fifo);
800 // first byte does not fit -> reset pts/dts + stuffing
801 if(payload_size <= trailer_size && pts != AV_NOPTS_VALUE){
805 if(pts != AV_NOPTS_VALUE)
806 timestamp_len += s->is_mpeg2 ? 5 : 4;
807 pts=dts= AV_NOPTS_VALUE;
808 header_len -= timestamp_len;
809 if (s->is_dvd && stream->align_iframe) {
810 pad_packet_bytes += timestamp_len;
811 packet_size -= timestamp_len;
813 payload_size += timestamp_len;
815 stuffing_size += timestamp_len;
816 if(payload_size > trailer_size)
817 stuffing_size += payload_size - trailer_size;
820 if (pad_packet_bytes > 0 && pad_packet_bytes <= 7) { // can't use padding, so use stuffing
821 packet_size += pad_packet_bytes;
822 payload_size += pad_packet_bytes; // undo the previous adjustment
823 if (stuffing_size < 0) {
824 stuffing_size = pad_packet_bytes;
826 stuffing_size += pad_packet_bytes;
828 pad_packet_bytes = 0;
831 if (stuffing_size < 0)
833 if (stuffing_size > 16) { /*<=16 for MPEG-1, <=32 for MPEG-2*/
834 pad_packet_bytes += stuffing_size;
835 packet_size -= stuffing_size;
836 payload_size -= stuffing_size;
840 nb_frames= get_nb_frames(ctx, stream, payload_size - stuffing_size);
842 avio_wb32(ctx->pb, startcode);
844 avio_wb16(ctx->pb, packet_size);
847 for(i=0;i<stuffing_size;i++)
848 avio_w8(ctx->pb, 0xff);
851 avio_w8(ctx->pb, 0x80); /* mpeg2 id */
855 if (pts != AV_NOPTS_VALUE) {
861 /* Both the MPEG-2 and the SVCD standards demand that the
862 P-STD_buffer_size field be included in the first packet of
863 every stream. (see SVCD standard p. 26 V.2.3.1 and V.2.3.2
864 and MPEG-2 standard 2.7.7) */
865 if (stream->packet_number == 0)
868 avio_w8(ctx->pb, pes_flags); /* flags */
869 avio_w8(ctx->pb, header_len - 3 + stuffing_size);
871 if (pes_flags & 0x80) /*write pts*/
872 put_timestamp(ctx->pb, (pes_flags & 0x40) ? 0x03 : 0x02, pts);
873 if (pes_flags & 0x40) /*write dts*/
874 put_timestamp(ctx->pb, 0x01, dts);
876 if (pes_flags & 0x01) { /*write pes extension*/
877 avio_w8(ctx->pb, 0x10); /* flags */
879 /* P-STD buffer info */
880 if ((id & 0xe0) == AUDIO_ID)
881 avio_wb16(ctx->pb, 0x4000 | stream->max_buffer_size/ 128);
883 avio_wb16(ctx->pb, 0x6000 | stream->max_buffer_size/1024);
887 if (pts != AV_NOPTS_VALUE) {
889 put_timestamp(ctx->pb, 0x03, pts);
890 put_timestamp(ctx->pb, 0x01, dts);
892 put_timestamp(ctx->pb, 0x02, pts);
895 avio_w8(ctx->pb, 0x0f);
900 /* special stuffing byte that is always written
901 to prevent accidental generation of start codes. */
902 avio_w8(ctx->pb, 0xff);
904 for(i=0;i<stuffing_size;i++)
905 avio_w8(ctx->pb, 0xff);
908 if (startcode == PRIVATE_STREAM_1) {
909 avio_w8(ctx->pb, id);
911 /* LPCM (XXX: check nb_frames) */
913 avio_wb16(ctx->pb, 4); /* skip 3 header bytes */
914 avio_w8(ctx->pb, stream->lpcm_header[0]);
915 avio_w8(ctx->pb, stream->lpcm_header[1]);
916 avio_w8(ctx->pb, stream->lpcm_header[2]);
917 } else if (id >= 0x40) {
919 avio_w8(ctx->pb, nb_frames);
920 avio_wb16(ctx->pb, trailer_size+1);
925 assert(payload_size - stuffing_size <= av_fifo_size(stream->fifo));
926 av_fifo_generic_read(stream->fifo, ctx->pb, payload_size - stuffing_size, (void*)avio_write);
927 stream->bytes_to_iframe -= payload_size - stuffing_size;
933 if (pad_packet_bytes > 0)
934 put_padding_packet(ctx,ctx->pb, pad_packet_bytes);
936 for(i=0;i<zero_trail_bytes;i++)
937 avio_w8(ctx->pb, 0x00);
943 /* only increase the stream packet number if this pack actually contains
944 something that is specific to this stream! I.e. a dedicated header
947 stream->packet_number++;
949 return payload_size - stuffing_size;
952 static void put_vcd_padding_sector(AVFormatContext *ctx)
954 /* There are two ways to do this padding: writing a sector/pack
955 of 0 values, or writing an MPEG padding pack. Both seem to
956 work with most decoders, BUT the VCD standard only allows a 0-sector
957 (see standard p. IV-4, IV-5).
958 So a 0-sector it is...*/
960 MpegMuxContext *s = ctx->priv_data;
963 for(i=0;i<s->packet_size;i++)
966 s->vcd_padding_bytes_written += s->packet_size;
970 /* increasing the packet number is correct. The SCR of the following packs
971 is calculated from the packet_number and it has to include the padding
972 sector (it represents the sector index, not the MPEG pack index)
973 (see VCD standard p. IV-6)*/
977 #if 0 /* unused, remove? */
978 static int64_t get_vcd_scr(AVFormatContext *ctx,int stream_index,int64_t pts)
980 MpegMuxContext *s = ctx->priv_data;
983 /* Since the data delivery rate is constant, SCR is computed
984 using the formula C + i * 1200 where C is the start constant
985 and i is the pack index.
986 It is recommended that SCR 0 is at the beginning of the VCD front
987 margin (a sequence of empty Form 2 sectors on the CD).
988 It is recommended that the front margin is 30 sectors long, so
989 we use C = 30*1200 = 36000
990 (Note that even if the front margin is not 30 sectors the file
991 will still be correct according to the standard. It just won't have
992 the "recommended" value).*/
993 scr = 36000 + s->packet_number * 1200;
999 static int remove_decoded_packets(AVFormatContext *ctx, int64_t scr){
1000 // MpegMuxContext *s = ctx->priv_data;
1003 for(i=0; i<ctx->nb_streams; i++){
1004 AVStream *st = ctx->streams[i];
1005 StreamInfo *stream = st->priv_data;
1006 PacketDesc *pkt_desc;
1008 while((pkt_desc= stream->predecode_packet)
1009 && scr > pkt_desc->dts){ //FIXME > vs >=
1010 if(stream->buffer_index < pkt_desc->size ||
1011 stream->predecode_packet == stream->premux_packet){
1012 av_log(ctx, AV_LOG_ERROR,
1013 "buffer underflow i=%d bufi=%d size=%d\n",
1014 i, stream->buffer_index, pkt_desc->size);
1017 stream->buffer_index -= pkt_desc->size;
1019 stream->predecode_packet= pkt_desc->next;
1020 av_freep(&pkt_desc);
1027 static int output_packet(AVFormatContext *ctx, int flush){
1028 MpegMuxContext *s = ctx->priv_data;
1031 int i, avail_space=0, es_size, trailer_size;
1033 int best_score= INT_MIN;
1034 int ignore_constraints=0;
1035 int64_t scr= s->last_scr;
1036 PacketDesc *timestamp_packet;
1037 const int64_t max_delay= av_rescale(ctx->max_delay, 90000, AV_TIME_BASE);
1040 for(i=0; i<ctx->nb_streams; i++){
1041 AVStream *st = ctx->streams[i];
1042 StreamInfo *stream = st->priv_data;
1043 const int avail_data= av_fifo_size(stream->fifo);
1044 const int space= stream->max_buffer_size - stream->buffer_index;
1045 int rel_space= 1024LL*space / stream->max_buffer_size;
1046 PacketDesc *next_pkt= stream->premux_packet;
1048 /* for subtitle, a single PES packet must be generated,
1049 so we flush after every single subtitle packet */
1050 if(s->packet_size > avail_data && !flush
1051 && st->codec->codec_type != AVMEDIA_TYPE_SUBTITLE)
1055 assert(avail_data>0);
1057 if(space < s->packet_size && !ignore_constraints)
1060 if(next_pkt && next_pkt->dts - scr > max_delay)
1063 if(rel_space > best_score){
1064 best_score= rel_space;
1071 int64_t best_dts= INT64_MAX;
1073 for(i=0; i<ctx->nb_streams; i++){
1074 AVStream *st = ctx->streams[i];
1075 StreamInfo *stream = st->priv_data;
1076 PacketDesc *pkt_desc= stream->predecode_packet;
1077 if(pkt_desc && pkt_desc->dts < best_dts)
1078 best_dts= pkt_desc->dts;
1081 av_dlog(ctx, "bumping scr, scr:%f, dts:%f\n",
1082 scr / 90000.0, best_dts / 90000.0);
1083 if(best_dts == INT64_MAX)
1086 if(scr >= best_dts+1 && !ignore_constraints){
1087 av_log(ctx, AV_LOG_ERROR, "packet too large, ignoring buffer limits to mux it\n");
1088 ignore_constraints= 1;
1090 scr= FFMAX(best_dts+1, scr);
1091 if(remove_decoded_packets(ctx, scr) < 0)
1096 assert(best_i >= 0);
1098 st = ctx->streams[best_i];
1099 stream = st->priv_data;
1101 assert(av_fifo_size(stream->fifo) > 0);
1103 assert(avail_space >= s->packet_size || ignore_constraints);
1105 timestamp_packet= stream->premux_packet;
1106 if(timestamp_packet->unwritten_size == timestamp_packet->size){
1109 trailer_size= timestamp_packet->unwritten_size;
1110 timestamp_packet= timestamp_packet->next;
1113 if(timestamp_packet){
1114 //av_log(ctx, AV_LOG_DEBUG, "dts:%f pts:%f scr:%f stream:%d\n", timestamp_packet->dts/90000.0, timestamp_packet->pts/90000.0, scr/90000.0, best_i);
1115 es_size= flush_packet(ctx, best_i, timestamp_packet->pts, timestamp_packet->dts, scr, trailer_size);
1117 assert(av_fifo_size(stream->fifo) == trailer_size);
1118 es_size= flush_packet(ctx, best_i, AV_NOPTS_VALUE, AV_NOPTS_VALUE, scr, trailer_size);
1122 /* Write one or more padding sectors, if necessary, to reach
1123 the constant overall bitrate.*/
1126 while((vcd_pad_bytes = get_vcd_padding_size(ctx,stream->premux_packet->pts) ) >= s->packet_size){ //FIXME pts cannot be correct here
1127 put_vcd_padding_sector(ctx);
1128 s->last_scr += s->packet_size*90000LL / (s->mux_rate*50LL); //FIXME rounding and first few bytes of each packet
1132 stream->buffer_index += es_size;
1133 s->last_scr += s->packet_size*90000LL / (s->mux_rate*50LL); //FIXME rounding and first few bytes of each packet
1135 while(stream->premux_packet && stream->premux_packet->unwritten_size <= es_size){
1136 es_size -= stream->premux_packet->unwritten_size;
1137 stream->premux_packet= stream->premux_packet->next;
1140 stream->premux_packet->unwritten_size -= es_size;
1142 if(remove_decoded_packets(ctx, s->last_scr) < 0)
1148 static int mpeg_mux_write_packet(AVFormatContext *ctx, AVPacket *pkt)
1150 MpegMuxContext *s = ctx->priv_data;
1151 int stream_index= pkt->stream_index;
1152 int size= pkt->size;
1153 uint8_t *buf= pkt->data;
1154 AVStream *st = ctx->streams[stream_index];
1155 StreamInfo *stream = st->priv_data;
1157 PacketDesc *pkt_desc;
1159 const int is_iframe = st->codec->codec_type == AVMEDIA_TYPE_VIDEO && (pkt->flags & AV_PKT_FLAG_KEY);
1161 preload = av_rescale(s->preload, 90000, AV_TIME_BASE);
1166 if(pts != AV_NOPTS_VALUE) pts += 2*preload;
1167 if(dts != AV_NOPTS_VALUE){
1169 s->last_scr= dts + preload;
1173 //av_log(ctx, AV_LOG_DEBUG, "dts:%f pts:%f flags:%d stream:%d nopts:%d\n", dts/90000.0, pts/90000.0, pkt->flags, pkt->stream_index, pts != AV_NOPTS_VALUE);
1174 if (!stream->premux_packet)
1175 stream->next_packet = &stream->premux_packet;
1176 *stream->next_packet=
1177 pkt_desc= av_mallocz(sizeof(PacketDesc));
1180 pkt_desc->unwritten_size=
1181 pkt_desc->size= size;
1182 if(!stream->predecode_packet)
1183 stream->predecode_packet= pkt_desc;
1184 stream->next_packet= &pkt_desc->next;
1186 if (av_fifo_realloc2(stream->fifo, av_fifo_size(stream->fifo) + size) < 0)
1190 if (is_iframe && (s->packet_number == 0 || (pts - stream->vobu_start_pts >= 36000))) { // min VOBU length 0.4 seconds (mpucoder)
1191 stream->bytes_to_iframe = av_fifo_size(stream->fifo);
1192 stream->align_iframe = 1;
1193 stream->vobu_start_pts = pts;
1197 av_fifo_generic_write(stream->fifo, buf, size, NULL);
1200 int ret= output_packet(ctx, 0);
1206 static int mpeg_mux_end(AVFormatContext *ctx)
1208 // MpegMuxContext *s = ctx->priv_data;
1213 int ret= output_packet(ctx, 1);
1220 /* End header according to MPEG1 systems standard. We do not write
1221 it as it is usually not needed by decoders and because it
1222 complicates MPEG stream concatenation. */
1223 //avio_wb32(ctx->pb, ISO_11172_END_CODE);
1224 //avio_flush(ctx->pb);
1226 for(i=0;i<ctx->nb_streams;i++) {
1227 stream = ctx->streams[i]->priv_data;
1229 assert(av_fifo_size(stream->fifo) == 0);
1230 av_fifo_free(stream->fifo);
1235 #define OFFSET(x) offsetof(MpegMuxContext, x)
1236 #define E AV_OPT_FLAG_ENCODING_PARAM
1237 static const AVOption options[] = {
1238 { "muxrate", NULL, OFFSET(mux_rate), AV_OPT_TYPE_INT, {0}, 0, INT_MAX, E },
1239 { "preload", "Initial demux-decode delay in microseconds.", OFFSET(preload), AV_OPT_TYPE_INT, {500000}, 0, INT_MAX, E},
1243 #define MPEGENC_CLASS(flavor)\
1244 static const AVClass flavor ## _class = {\
1245 .class_name = #flavor " muxer",\
1246 .item_name = av_default_item_name,\
1247 .version = LIBAVUTIL_VERSION_INT,\
1251 #if CONFIG_MPEG1SYSTEM_MUXER
1253 AVOutputFormat ff_mpeg1system_muxer = {
1255 .long_name = NULL_IF_CONFIG_SMALL("MPEG-1 System format"),
1256 .mime_type = "video/mpeg",
1257 .extensions = "mpg,mpeg",
1258 .priv_data_size = sizeof(MpegMuxContext),
1259 .audio_codec = CODEC_ID_MP2,
1260 .video_codec = CODEC_ID_MPEG1VIDEO,
1261 .write_header = mpeg_mux_init,
1262 .write_packet = mpeg_mux_write_packet,
1263 .write_trailer = mpeg_mux_end,
1264 .priv_class = &mpeg_class,
1267 #if CONFIG_MPEG1VCD_MUXER
1269 AVOutputFormat ff_mpeg1vcd_muxer = {
1271 .long_name = NULL_IF_CONFIG_SMALL("MPEG-1 System format (VCD)"),
1272 .mime_type = "video/mpeg",
1273 .priv_data_size = sizeof(MpegMuxContext),
1274 .audio_codec = CODEC_ID_MP2,
1275 .video_codec = CODEC_ID_MPEG1VIDEO,
1276 .write_header = mpeg_mux_init,
1277 .write_packet = mpeg_mux_write_packet,
1278 .write_trailer = mpeg_mux_end,
1279 .priv_class = &vcd_class,
1282 #if CONFIG_MPEG2VOB_MUXER
1284 AVOutputFormat ff_mpeg2vob_muxer = {
1286 .long_name = NULL_IF_CONFIG_SMALL("MPEG-2 PS format (VOB)"),
1287 .mime_type = "video/mpeg",
1288 .extensions = "vob",
1289 .priv_data_size = sizeof(MpegMuxContext),
1290 .audio_codec = CODEC_ID_MP2,
1291 .video_codec = CODEC_ID_MPEG2VIDEO,
1292 .write_header = mpeg_mux_init,
1293 .write_packet = mpeg_mux_write_packet,
1294 .write_trailer = mpeg_mux_end,
1295 .priv_class = &vob_class,
1299 /* Same as mpeg2vob_mux except that the pack size is 2324 */
1300 #if CONFIG_MPEG2SVCD_MUXER
1302 AVOutputFormat ff_mpeg2svcd_muxer = {
1304 .long_name = NULL_IF_CONFIG_SMALL("MPEG-2 PS format (VOB)"),
1305 .mime_type = "video/mpeg",
1306 .extensions = "vob",
1307 .priv_data_size = sizeof(MpegMuxContext),
1308 .audio_codec = CODEC_ID_MP2,
1309 .video_codec = CODEC_ID_MPEG2VIDEO,
1310 .write_header = mpeg_mux_init,
1311 .write_packet = mpeg_mux_write_packet,
1312 .write_trailer = mpeg_mux_end,
1313 .priv_class = &svcd_class,
1317 /* Same as mpeg2vob_mux except the 'is_dvd' flag is set to produce NAV pkts */
1318 #if CONFIG_MPEG2DVD_MUXER
1320 AVOutputFormat ff_mpeg2dvd_muxer = {
1322 .long_name = NULL_IF_CONFIG_SMALL("MPEG-2 PS format (DVD VOB)"),
1323 .mime_type = "video/mpeg",
1324 .extensions = "dvd",
1325 .priv_data_size = sizeof(MpegMuxContext),
1326 .audio_codec = CODEC_ID_MP2,
1327 .video_codec = CODEC_ID_MPEG2VIDEO,
1328 .write_header = mpeg_mux_init,
1329 .write_packet = mpeg_mux_write_packet,
1330 .write_trailer = mpeg_mux_end,
1331 .priv_class = &dvd_class,