Go to the documentation of this file.
37 #define MAX_PAYLOAD_SIZE 4096
105 put_bits(&pb, 3, (uint32_t)((timestamp >> 30) & 0x07));
107 put_bits(&pb, 15, (uint32_t)((timestamp >> 15) & 0x7fff));
109 put_bits(&pb, 15, (uint32_t)((timestamp) & 0x7fff));
127 int only_for_stream_id)
130 int size,
i, private_stream_coded,
id;
142 if (
s->is_vcd && only_for_stream_id ==
VIDEO_ID) {
158 if (
s->is_vcd ||
s->is_dvd) {
169 if (
s->is_vcd && (only_for_stream_id & 0xe0) ==
AUDIO_ID) {
189 int P_STD_max_video = 0;
190 int P_STD_max_mpeg_audio = 0;
191 int P_STD_max_mpeg_PS1 = 0;
199 }
else if (
id >= 0xc0 &&
id <= 0xc7 &&
202 }
else if (
id == 0xe0 &&
212 put_bits(&pb, 13, P_STD_max_video / 1024);
215 if (P_STD_max_mpeg_audio == 0)
216 P_STD_max_mpeg_audio = 4096;
220 put_bits(&pb, 13, P_STD_max_mpeg_audio / 128);
226 put_bits(&pb, 13, P_STD_max_mpeg_PS1 / 128);
235 private_stream_coded = 0;
242 if (!
s->is_vcd || stream->
id == only_for_stream_id ||
243 only_for_stream_id == 0) {
247 if (private_stream_coded)
249 private_stream_coded = 1;
277 int buf_index,
i, private_stream_coded;
285 private_stream_coded = 0;
288 if (stream->
id < 0xc0) {
289 if (private_stream_coded)
291 private_stream_coded = 1;
301 int bitrate,
i, mpa_id, mpv_id, h264_id, mps_id, ac3_id, dts_id, lpcm_id, j;
307 s->packet_number = 0;
323 s->packet_size = 2048;
327 s->vcd_padding_bytes_written = 0;
328 s->vcd_padding_bitrate_num = 0;
360 "%s in MPEG-1 system streams is not widely supported, "
361 "consider using the vob or the dvd muxer "
362 "to force a MPEG-2 program stream.\n",
365 stream->
id = ac3_id++;
367 stream->
id = dts_id++;
369 stream->
id = lpcm_id++;
370 for (j = 0; j < 4; j++) {
378 for (sr = 0; sr < 4; sr++)
395 case 48000: freq = 0;
break;
396 case 96000: freq = 1;
break;
397 case 44100: freq = 2;
break;
398 case 32000: freq = 3;
break;
409 stream->
id = lpcm_id++;
419 av_log(
ctx,
AV_LOG_ERROR,
"Unsupported audio codec. Must be one of mp1, mp2, mp3, 16-bit pcm_dvd, pcm_s16be, ac3 or dts.\n");
422 stream->
id = mpa_id++;
432 stream->
id = h264_id++;
434 stream->
id = mpv_id++;
441 "VBV buffer size not set, using default size of 230KB\n"
442 "If you want the mpeg file to be compliant to some specification\n"
443 "Like DVD, VCD or others, make sure you set the correct buffer size\n");
454 stream->
id = mps_id++;
487 audio_bitrate += codec_rate;
489 video_bitrate += codec_rate;
492 if (
s->user_mux_rate) {
493 s->mux_rate = (
s->user_mux_rate + (8 * 50) - 1) / (8 * 50);
499 s->mux_rate = (
bitrate + (8 * 50) - 1) / (8 * 50);
500 if (
s->mux_rate >= (1<<22)) {
502 s->mux_rate = (1<<22) - 1;
507 int64_t overhead_rate;
527 overhead_rate = audio_bitrate * 2294LL * (2324 - 2279);
528 overhead_rate += video_bitrate * 2279LL * (2324 - 2294);
531 s->vcd_padding_bitrate_num = (2324LL * 75 * 8 -
bitrate) * 2279 * 2294 - overhead_rate;
532 #define VCD_PADDING_BITRATE_DEN (2279 * 2294)
535 if (
s->is_vcd ||
s->is_mpeg2)
537 s->pack_header_freq = 1;
540 s->pack_header_freq = 2 *
bitrate /
s->packet_size / 8;
543 if (
s->pack_header_freq == 0)
544 s->pack_header_freq = 1;
548 s->system_header_freq =
s->pack_header_freq * 40;
553 s->system_header_freq = 0x7fffffff;
555 s->system_header_freq =
s->pack_header_freq * 5;
568 avio_w8(pb, (
id << 4) | (((timestamp >> 30) & 0x07) << 1) | 1);
569 avio_wb16(pb, (uint16_t)((((timestamp >> 15) & 0x7fff) << 1) | 1));
570 avio_wb16(pb, (uint16_t)((((timestamp) & 0x7fff) << 1) | 1));
581 int64_t full_pad_bytes;
586 pad_bytes = (
int)(full_pad_bytes -
s->vcd_padding_bytes_written);
623 pkt_desc = pkt_desc->
next;
631 int64_t
pts, int64_t dts, int64_t scr,
int trailer_size)
636 int size, payload_size, startcode,
id, stuffing_size, header_len;
639 int zero_trail_bytes = 0;
640 int pad_packet_bytes = 0;
643 int general_pack = 0;
652 if ((
s->packet_number %
s->pack_header_freq) == 0 ||
s->last_scr != scr) {
667 }
else if (
s->is_dvd) {
669 int PES_bytes_to_fill =
s->packet_size -
size - 10;
673 PES_bytes_to_fill -= 5 + 5;
675 PES_bytes_to_fill -= 5;
699 scr +=
s->packet_size * 90000LL /
700 (
s->mux_rate * 50LL);
706 pad_packet_bytes = PES_bytes_to_fill -
711 if ((
s->packet_number %
s->system_header_freq) == 0) {
720 packet_size =
s->packet_size -
size;
722 if (
s->is_vcd && (
id & 0xe0) ==
AUDIO_ID)
725 zero_trail_bytes += 20;
728 (
s->is_svcd &&
s->packet_number == 0)) {
738 pad_packet_bytes = packet_size - zero_trail_bytes;
741 packet_size -= pad_packet_bytes + zero_trail_bytes;
743 if (packet_size > 0) {
766 payload_size = packet_size - header_len;
776 startcode = 0x100 +
id;
783 int timestamp_len = 0;
787 timestamp_len +=
s->is_mpeg2 ? 5 : 4;
790 header_len -= timestamp_len;
792 pad_packet_bytes += timestamp_len;
793 packet_size -= timestamp_len;
795 payload_size += timestamp_len;
797 stuffing_size += timestamp_len;
798 if (payload_size > trailer_size)
799 stuffing_size += payload_size - trailer_size;
803 if (pad_packet_bytes > 0 && pad_packet_bytes <= 7) {
804 packet_size += pad_packet_bytes;
805 payload_size += pad_packet_bytes;
806 if (stuffing_size < 0)
807 stuffing_size = pad_packet_bytes;
809 stuffing_size += pad_packet_bytes;
810 pad_packet_bytes = 0;
813 if (stuffing_size < 0)
818 stuffing_size += payload_size % stream->
lpcm_align;
821 if (stuffing_size > 16) {
822 pad_packet_bytes += stuffing_size;
823 packet_size -= stuffing_size;
824 payload_size -= stuffing_size;
858 if (pes_flags & 0x80)
860 if (pes_flags & 0x40)
863 if (pes_flags & 0x01) {
902 }
else if (
id >= 0x40) {
912 payload_size - stuffing_size,
920 if (pad_packet_bytes > 0)
935 return payload_size - stuffing_size;
950 s->vcd_padding_bytes_written +=
s->packet_size;
971 scr > pkt_desc->
dts) {
975 "buffer underflow st=%d bufi=%d size=%d\n",
995 int i, avail_space = 0, es_size, trailer_size;
997 int best_score = INT_MIN;
998 int ignore_constraints = 0;
999 int ignore_delay = 0;
1000 int64_t scr =
s->last_scr;
1015 if (
s->packet_size > avail_data && !
flush
1018 if (avail_data == 0)
1022 if (space < s->packet_size && !ignore_constraints)
1025 if (next_pkt && next_pkt->
dts - scr > max_delay && !ignore_delay)
1030 if (rel_space > best_score) {
1031 best_score = rel_space;
1033 avail_space =
space;
1038 int64_t best_dts = INT64_MAX;
1045 if (pkt_desc && pkt_desc->
dts < best_dts)
1046 best_dts = pkt_desc->
dts;
1050 if (best_dts < INT64_MAX) {
1052 scr / 90000.0, best_dts / 90000.0);
1054 if (scr >= best_dts + 1 && !ignore_constraints) {
1056 "packet too large, ignoring buffer limits to mux it\n");
1057 ignore_constraints = 1;
1059 scr =
FFMAX(best_dts + 1, scr);
1062 }
else if (has_premux &&
flush) {
1064 "delay too large, ignoring ...\n");
1066 ignore_constraints = 1;
1080 av_assert0(avail_space >=
s->packet_size || ignore_constraints);
1087 timestamp_packet = timestamp_packet->
next;
1090 if (timestamp_packet) {
1092 timestamp_packet->
dts / 90000.0,
1093 timestamp_packet->
pts / 90000.0,
1094 scr / 90000.0, best_i);
1096 timestamp_packet->
dts, scr, trailer_size);
1112 s->last_scr +=
s->packet_size * 90000LL / (
s->mux_rate * 50LL);
1118 s->last_scr +=
s->packet_size * 90000LL / (
s->mux_rate * 50LL);
1156 if (dts ==
AV_NOPTS_VALUE || (dts < preload && ctx->avoid_negative_ts) ||
s->is_dvd) {
1161 s->last_scr = dts - preload;
1198 pkt_desc->
dts = dts;
1267 #define OFFSET(x) offsetof(MpegMuxContext, x)
1268 #define E AV_OPT_FLAG_ENCODING_PARAM
1271 {
"preload",
"Initial demux-decode delay in microseconds.",
OFFSET(preload),
AV_OPT_TYPE_INT, { .i64 = 500000 }, 0, INT_MAX,
E },
1282 #if CONFIG_MPEG1SYSTEM_MUXER
1286 .mime_type =
"video/mpeg",
1287 .extensions =
"mpg,mpeg",
1299 #if CONFIG_MPEG1VCD_MUXER
1303 .mime_type =
"video/mpeg",
1315 #if CONFIG_MPEG2VOB_MUXER
1319 .mime_type =
"video/mpeg",
1320 .extensions =
"vob",
1333 #if CONFIG_MPEG2SVCD_MUXER
1337 .mime_type =
"video/mpeg",
1338 .extensions =
"vob",
1351 #if CONFIG_MPEG2DVD_MUXER
1355 .mime_type =
"video/mpeg",
1356 .extensions =
"dvd",
#define AV_LOG_WARNING
Something somehow does not look correct.
#define SYSTEM_HEADER_START_CODE
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
static void av_unused put_bits32(PutBitContext *s, uint32_t value)
Write exactly 32 bits into a bitstream.
enum AVMediaType codec_type
General type of the encoded data.
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated space
static int get_system_header_size(AVFormatContext *ctx)
#define VCD_PADDING_BITRATE_DEN
int av_fifo_generic_write(AVFifoBuffer *f, void *src, int size, int(*func)(void *, void *, int))
Feed data from a user-supplied callback to an AVFifoBuffer.
const AVOutputFormat ff_mpeg1vcd_muxer
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s.
static av_cold int mpeg_mux_init(AVFormatContext *ctx)
static int remove_decoded_packets(AVFormatContext *ctx, int64_t scr)
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
AVStream ** streams
A list of all streams in the file.
static void deinit(AVFormatContext *s)
static int flush_packet(AVFormatContext *ctx, int stream_index, int64_t pts, int64_t dts, int64_t scr, int trailer_size)
int av_fifo_generic_read(AVFifoBuffer *f, void *dest, int buf_size, void(*func)(void *, void *, int))
Feed data from an AVFifoBuffer to a user-supplied callback.
static int get_nb_frames(AVFormatContext *ctx, StreamInfo *stream, int len)
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
void avio_write_marker(AVIOContext *s, int64_t time, enum AVIODataMarkerType type)
Mark the written bytestream as a specific type.
static int output_packet(AVFormatContext *ctx, int flush)
const AVOutputFormat ff_mpeg2svcd_muxer
@ AV_CODEC_ID_MP3
preferred ID for decoding MPEG audio layer 1, 2 or 3
static int get_vcd_padding_size(AVFormatContext *ctx, int64_t pts)
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
PacketDesc * predecode_packet
#define av_assert0(cond)
assert() equivalent, that is always enabled.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
static const int lpcm_freq_tab[4]
This structure describes the bitrate properties of an encoded bitstream.
int av_fifo_realloc2(AVFifoBuffer *f, unsigned int new_size)
Resize an AVFifoBuffer.
AVCodecParameters * codecpar
Codec parameters associated with this stream.
#define LIBAVUTIL_VERSION_INT
Describe the class of an AVClass context structure.
static void flush(AVCodecContext *avctx)
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
static int write_trailer(AVFormatContext *s1)
const char * av_default_item_name(void *ptr)
Return the context name.
AVIOContext * pb
I/O context.
void avio_w8(AVIOContext *s, int b)
static void put_padding_packet(AVFormatContext *ctx, AVIOContext *pb, int packet_bytes)
void ffio_fill(AVIOContext *s, int b, int64_t count)
static void put_timestamp(AVIOContext *pb, int id, int64_t timestamp)
int sample_rate
Audio only.
unsigned int nb_streams
Number of elements in AVFormatContext.streams.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
static void put_vcd_padding_sector(AVFormatContext *ctx)
#define AV_NOPTS_VALUE
Undefined timestamp value.
static const AVClass mpeg_class
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
void avio_write(AVIOContext *s, const unsigned char *buf, int size)
void avio_wb32(AVIOContext *s, unsigned int val)
int flags
A combination of AV_PKT_FLAG values.
#define AV_LOG_INFO
Standard information.
static void write_packet(OutputFile *of, AVPacket *pkt, OutputStream *ost, int unqueue)
const char * avcodec_get_name(enum AVCodecID id)
Get the name of a codec.
PacketDesc * premux_packet
#define i(width, name, range_min, range_max)
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
static int mpeg_mux_end(AVFormatContext *ctx)
#define AV_TIME_BASE
Internal time base represented as integer.
int64_t max_bitrate
Maximum bitrate of the stream, in bits per second.
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
@ AV_PKT_DATA_CPB_PROPERTIES
This side data corresponds to the AVCPBProperties struct.
int64_t av_rescale(int64_t a, int64_t b, int64_t c)
Rescale a 64-bit integer with rounding to nearest.
int64_t vcd_padding_bytes_written
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
const struct AVOutputFormat * oformat
The output container format.
int64_t buffer_size
The size of the buffer to which the ratecontrol is applied, in bits.
uint8_t * av_stream_get_side_data(const AVStream *stream, enum AVPacketSideDataType type, size_t *size)
Get side information from stream.
const AVOutputFormat ff_mpeg2vob_muxer
const char * av_get_media_type_string(enum AVMediaType media_type)
Return a string describing the media_type enum, NULL if media_type is unknown.
static uint8_t * put_bits_ptr(PutBitContext *s)
Return the pointer to the byte where the bitstream writer will put the next bit.
the frame and frame reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFrame structures Several references can point to the same frame buffer
int bits_per_coded_sample
The number of bits per sample in the codedwords.
static int put_system_header(AVFormatContext *ctx, uint8_t *buf, int only_for_stream_id)
int av_fifo_size(const AVFifoBuffer *f)
Return the amount of data in bytes in the AVFifoBuffer, that is the amount of data you can read from ...
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros.
int64_t vcd_padding_bitrate_num
void av_fifo_freep(AVFifoBuffer **f)
Free an AVFifoBuffer and reset pointer to NULL.
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
This structure stores compressed data.
AVFifoBuffer * av_fifo_alloc(unsigned int size)
Initialize an AVFifoBuffer.
void avio_wb16(AVIOContext *s, unsigned int val)
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
static void write_header(FFV1Context *f)
@ AV_CODEC_ID_MPEG2VIDEO
preferred ID for MPEG-1/2 video decoding
static const AVOption options[]
void * priv_data
Format private data.
static void mpeg_mux_deinit(AVFormatContext *ctx)
static int mpeg_mux_write_packet(AVFormatContext *ctx, AVPacket *pkt)
const AVOutputFormat ff_mpeg2dvd_muxer
static int put_pack_header(AVFormatContext *ctx, uint8_t *buf, int64_t timestamp)
@ AVIO_DATA_MARKER_FLUSH_POINT
A point in the output bytestream where the underlying AVIOContext might flush the buffer depending on...