40 #define VALIDATE_INDEX_TS_THRESH 2500
67 d[3] < 5 && d[5] == 0 &&
70 int is_live = !memcmp(d + offset + 40,
"NGINX RTMP", 10);
115 switch (flv_codecid) {
118 codec_id = bits_per_coded_sample == 8
125 return codec_id == acodec->
codec_id;
127 codec_id = bits_per_coded_sample == 8
130 return codec_id == acodec->
codec_id;
157 switch (flv_codecid) {
221 switch (flv_codecid) {
240 int flv_codecid,
int read)
243 switch (flv_codecid) {
289 if (length >= buffsize) {
305 unsigned int timeslen = 0, fileposlen = 0, i;
307 int64_t *times =
NULL;
308 int64_t *filepositions =
NULL;
322 int64_t **current_array;
323 unsigned int arraylen;
334 current_array = ×
338 current_array = &filepositions;
339 fileposlen = arraylen;
345 if (!(*current_array =
av_mallocz(
sizeof(**current_array) * arraylen))) {
350 for (i = 0; i < arraylen &&
avio_tell(ioc) < max_pos - 1; i++) {
355 if (times && filepositions) {
363 if (timeslen == fileposlen && fileposlen>1 && max_pos <= filepositions[0]) {
364 for (i = 0; i < fileposlen; i++) {
414 if ((vstream || astream) && key &&
451 unsigned int arraylen, i;
454 for (i = 0; i < arraylen &&
avio_tell(ioc) < max_pos - 1; i++)
469 acodec = astream ? astream->
codec :
NULL;
470 vcodec = vstream ? vstream->
codec :
NULL;
476 if (!strcmp(key,
"duration"))
478 else if (!strcmp(key,
"videodatarate") && vcodec &&
479 0 <= (
int)(num_val * 1024.0))
480 vcodec->
bit_rate = num_val * 1024.0;
481 else if (!strcmp(key,
"audiodatarate") && acodec &&
482 0 <= (
int)(num_val * 1024.0))
483 acodec->
bit_rate = num_val * 1024.0;
484 else if (!strcmp(key,
"datastream")) {
490 if (!strcmp(key,
"videocodecid") && vcodec) {
492 }
else if (!strcmp(key,
"audiocodecid") && acodec) {
495 }
else if (!strcmp(key,
"audiosamplerate") && acodec) {
497 }
else if (!strcmp(key,
"audiosamplesize") && acodec) {
499 }
else if (!strcmp(key,
"stereo") && acodec) {
504 }
else if (!strcmp(key,
"width") && vcodec) {
505 vcodec->
width = num_val;
506 }
else if (!strcmp(key,
"height") && vcodec) {
514 ((!acodec && !strcmp(key,
"audiocodecid")) ||
515 (!vcodec && !strcmp(key,
"videocodecid"))))
518 if (!strcmp(key,
"duration") ||
519 !strcmp(key,
"filesize") ||
520 !strcmp(key,
"width") ||
521 !strcmp(key,
"height") ||
522 !strcmp(key,
"videodatarate") ||
523 !strcmp(key,
"framerate") ||
524 !strcmp(key,
"videocodecid") ||
525 !strcmp(key,
"audiodatarate") ||
526 !strcmp(key,
"audiosamplerate") ||
527 !strcmp(key,
"audiosamplesize") ||
528 !strcmp(key,
"stereo") ||
529 !strcmp(key,
"audiocodecid") ||
530 !strcmp(key,
"datastream"))
535 av_strlcpy(str_val, num_val > 0 ?
"true" :
"false",
539 snprintf(str_val,
sizeof(str_val),
"%.f", num_val);
548 #define TYPE_ONTEXTDATA 1
549 #define TYPE_ONCAPTION 2
550 #define TYPE_ONCAPTIONINFO 3
551 #define TYPE_UNKNOWN 9
556 AVStream *stream, *astream, *vstream;
575 if (!strcmp(buffer,
"onTextData"))
578 if (!strcmp(buffer,
"onCaption"))
581 if (!strcmp(buffer,
"onCaptionInfo"))
584 if (strcmp(buffer,
"onMetaData") && strcmp(buffer,
"onCuePoint")) {
669 "Found invalid index entries, clearing the index.\n");
683 int nb = -1, ret, parse_name = 1;
723 int64_t dts, int64_t next)
743 while (array || (ret =
amf_get_string(pb, buf,
sizeof(buf))) > 0) {
795 int64_t next, pos, meta_pos;
816 if (pos == validate_pos) {
824 }
else if (pos > validate_pos) {
847 if (size > 13 + 1 + 4) {
851 if (type == 0 && dts == 0 || type < 0 || type ==
TYPE_UNKNOWN) {
863 "Skipping flv packet: type %d, size %d, flags %d.\n",
934 else if (fsize >= 8 && fsize - 8 >= size) {
945 int bits_per_coded_sample;
991 "Negative cts, previous timestamps might be wrong.\n");
993 }
else if (
FFABS(dts - pts) > 1000*60*15) {
995 "invalid timestamps %"PRId64
" %"PRId64
"\n", dts, pts);
1079 int64_t ts,
int flags)
1086 #define OFFSET(x) offsetof(FLVContext, x)
1087 #define VD AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_DECODING_PARAM
1089 {
"flv_metadata",
"Allocate streams according to the onMetaData array",
OFFSET(trust_metadata),
AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1,
VD },
1109 .extensions =
"flv",
1110 .priv_class = &flv_class,
1129 .extensions =
"flv",
1130 .priv_class = &live_flv_class,
discard all frames except keyframes
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
int64_t avio_size(AVIOContext *s)
Get the filesize.
int av_add_index_entry(AVStream *st, int64_t pos, int64_t timestamp, int size, int distance, int flags)
Add an index entry into a sorted list.
#define AV_LOG_WARNING
Something somehow does not look correct.
#define LIBAVUTIL_VERSION_INT
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
int index
stream index in AVFormatContext
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
struct FLVContext::@164 validate_index[2]
enum AVMediaType codec_type
int event_flags
Flags for the user to detect events happening on the file.
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
#define AV_CH_LAYOUT_STEREO
unsigned int avio_rb16(AVIOContext *s)
int ctx_flags
Flags signalling stream properties.
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
void void avpriv_request_sample(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
static av_always_inline double av_int2double(uint64_t i)
Reinterpret a 64-bit integer as a double.
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
unsigned int avio_rb32(AVIOContext *s)
int wrong_dts
wrong dts due to negative cts
enum AVStreamParseType need_parsing
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_RB32
AVStream ** streams
A list of all streams in the file.
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
int flags
Flags modifying the (de)muxer behaviour.
#define AVERROR_EOF
End of file.
static av_cold int read_close(AVFormatContext *ctx)
uint64_t avio_rb64(AVIOContext *s)
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext.
int trust_metadata
configure streams according onMetaData
int bits_per_coded_sample
bits per sample/pixel from the demuxer (needed for huffyuv).
enum AVCodecID video_codec_id
Forced video codec_id.
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
AVDictionary * metadata
Metadata that applies to the whole file.
discard all bidirectional frames
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
preferred ID for decoding MPEG audio layer 1, 2 or 3
static const uint8_t offset[127][2]
uint8_t * new_extradata[FLV_STREAM_TYPE_NB]
size_t av_strlcpy(char *dst, const char *src, size_t size)
Copy the string src to dst, but no more than size - 1 bytes, and null-terminate dst.
int flags
A combination of AV_PKT_FLAG values.
uint64_t channel_layout
Audio channel layout.
int avio_r8(AVIOContext *s)
AVCodecContext * codec
Codec context associated with this stream.
int buf_size
Size of buf except extra allocated bytes.
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
unsigned int nb_streams
Number of elements in AVFormatContext.streams.
int seekable
A combination of AVIO_SEEKABLE_ flags or 0 when the stream is not seekable.
int bit_rate
the average bitrate
audio channel layout utility functions
unsigned int avio_rb24(AVIOContext *s)
#define AV_TIME_BASE
Internal time base represented as integer.
enum AVCodecID audio_codec_id
Forced audio codec_id.
int width
picture width / height.
int new_extradata_size[FLV_STREAM_TYPE_NB]
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
static int read_header(FFV1Context *f)
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
enum AVMediaType codec_type
int sample_rate
samples per second
AVIOContext * pb
I/O context.
main external API structure.
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A').
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
Describe the class of an AVClass context structure.
This structure contains the data a format has to probe a file.
static int64_t pts
Global timestamp for the audio frames.
int64_t start_time
Position of the first frame of the component, in AV_TIME_BASE fractional seconds. ...
static const int32_t max_pos[4]
Size of the MP-MLQ fixed excitation codebooks.
int avpriv_mpeg4audio_get_config(MPEG4AudioConfig *c, const uint8_t *buf, int bit_size, int sync_extension)
Parse MPEG-4 systems extradata to retrieve audio configuration.
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
int64_t avio_seek_time(AVIOContext *h, int stream_index, int64_t timestamp, int flags)
Seek to a given timestamp relative to some component stream.
int eof_reached
true if eof reached
int channels
number of audio channels
void * priv_data
Format private data.
uint8_t pi<< 24) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_U8, uint8_t,(*(constuint8_t *) pi-0x80)*(1.0f/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_U8, uint8_t,(*(constuint8_t *) pi-0x80)*(1.0/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S16, int16_t,(*(constint16_t *) pi >>8)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S16, int16_t,*(constint16_t *) pi *(1.0f/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S16, int16_t,*(constint16_t *) pi *(1.0/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S32, int32_t,(*(constint32_t *) pi >>24)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S32, int32_t,*(constint32_t *) pi *(1.0f/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S32, int32_t,*(constint32_t *) pi *(1.0/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_FLT, float, av_clip_uint8(lrintf(*(constfloat *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_FLT, float, av_clip_int16(lrintf(*(constfloat *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_FLT, float, av_clipl_int32(llrintf(*(constfloat *) pi *(1U<< 31)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_DBL, double, av_clip_uint8(lrint(*(constdouble *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_DBL, double, av_clip_int16(lrint(*(constdouble *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_DBL, double, av_clipl_int32(llrint(*(constdouble *) pi *(1U<< 31))))#defineSET_CONV_FUNC_GROUP(ofmt, ifmt) staticvoidset_generic_function(AudioConvert *ac){}voidff_audio_convert_free(AudioConvert **ac){if(!*ac) return;ff_dither_free(&(*ac) ->dc);av_freep(ac);}AudioConvert *ff_audio_convert_alloc(AVAudioResampleContext *avr, enumAVSampleFormatout_fmt, enumAVSampleFormatin_fmt, intchannels, intsample_rate, intapply_map){AudioConvert *ac;intin_planar, out_planar;ac=av_mallocz(sizeof(*ac));if(!ac) returnNULL;ac->avr=avr;ac->out_fmt=out_fmt;ac->in_fmt=in_fmt;ac->channels=channels;ac->apply_map=apply_map;if(avr->dither_method!=AV_RESAMPLE_DITHER_NONE &&av_get_packed_sample_fmt(out_fmt)==AV_SAMPLE_FMT_S16 &&av_get_bytes_per_sample(in_fmt)>2){ac->dc=ff_dither_alloc(avr, out_fmt, in_fmt, channels, sample_rate, apply_map);if(!ac->dc){av_free(ac);returnNULL;}returnac;}in_planar=ff_sample_fmt_is_planar(in_fmt, channels);out_planar=ff_sample_fmt_is_planar(out_fmt, channels);if(in_planar==out_planar){ac->func_type=CONV_FUNC_TYPE_FLAT;ac->planes=in_planar?ac->channels:1;}elseif(in_planar) ac->func_type=CONV_FUNC_TYPE_INTERLEAVE;elseac->func_type=CONV_FUNC_TYPE_DEINTERLEAVE;set_generic_function(ac);if(ARCH_AARCH64) ff_audio_convert_init_aarch64(ac);if(ARCH_ARM) ff_audio_convert_init_arm(ac);if(ARCH_X86) ff_audio_convert_init_x86(ac);returnac;}intff_audio_convert(AudioConvert *ac, AudioData *out, AudioData *in){intuse_generic=1;intlen=in->nb_samples;intp;if(ac->dc){av_log(ac->avr, AV_LOG_TRACE,"%dsamples-audio_convert:%sto%s(dithered)\n", len, av_get_sample_fmt_name(ac->in_fmt), av_get_sample_fmt_name(ac->out_fmt));returnff_convert_dither(ac-> out
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed...
int64_t duration
Duration of the stream, in AV_TIME_BASE fractional seconds.
int avio_feof(AVIOContext *s)
feof() equivalent for AVIOContext.
uint8_t * av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type, int size)
Allocate new information of a packet.
#define AV_CH_LAYOUT_MONO
enum AVDiscard discard
Selects which packets can be discarded at will and do not need to be demuxed.
This structure stores compressed data.
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
#define AV_NOPTS_VALUE
Undefined timestamp value.