Go to the documentation of this file.
135 #define ASF_MAX_STREAMS 127
136 #define FRAME_HEADER_SIZE 6
142 0xce, 0x75, 0xf8, 0x7b, 0x8d, 0x46, 0xd1, 0x11, 0x8d, 0x82, 0x00, 0x60, 0x97, 0xc9, 0xa2, 0xb2
145 static const ff_asf_guid asf_audio_conceal_none = {
148 0x00, 0x57, 0xfb, 0x20, 0x55, 0x5B, 0xCF, 0x11, 0xa8, 0xfd, 0x00, 0x80, 0x5f, 0x5c, 0x44, 0x2b
151 #define PRINT_IF_GUID(g, cmp) \
152 if (!ff_guidcmp(g, &(cmp))) \
153 av_log(NULL, AV_LOG_TRACE, "(GUID: %s) ", # cmp)
162 else PRINT_IF_GUID(
g, asf_audio_conceal_none);
181 else PRINT_IF_GUID(
g, stream_bitrate_guid);
185 for (
i = 0;
i < 16;
i++)
191 #define print_guid(g) while(0)
262 "Unsupported value type %d in tag %s.\n",
type,
key);
306 int type_specific_size, sizeX;
309 int test_for_ext_stream_audio, is_dvr_ms_audio = 0;
334 test_for_ext_stream_audio = 0;
345 test_for_ext_stream_audio = 1;
361 if (test_for_ext_stream_audio) {
380 if (is_dvr_ms_audio) {
392 if (
size >= (pos2 + 8 - pos1 + 24)) {
447 if (tag1 ==
MKTAG(
'D',
'V',
'R',
' ')) {
473 int ext_len, payload_ext_ct, stream_ct,
i;
474 uint32_t leak_rate, stream_num;
475 unsigned int stream_languageid_index;
490 if (stream_num < 128)
497 if (stream_num < 128) {
502 for (
i = 0;
i < stream_ct;
i++) {
508 for (
i = 0;
i < payload_ext_ct;
i++) {
531 int len1, len2, len3, len4, len5;
540 get_tag(
s,
"copyright", 0, len3, 32);
551 int desc_count,
i,
ret;
554 for (
i = 0;
i < desc_count;
i++) {
555 int name_len, value_type, value_len;
565 if (!value_type && value_len % 2)
570 if (!strcmp(
name,
"AspectRatioX"))
572 else if (!strcmp(
name,
"AspectRatioY"))
587 for (j = 0; j < stream_count; j++) {
589 unsigned int lang_len =
avio_r8(pb);
591 sizeof(lang))) < lang_len)
605 int n, stream_num, name_len_utf16, name_len_utf8, value_len;
609 for (
i = 0;
i < n;
i++) {
619 if (value_len < 0 || value_len > UINT16_MAX)
622 name_len_utf8 = 2*name_len_utf16 + 1;
630 i, stream_num, name_len_utf16, value_type, value_len,
name);
632 if (!strcmp(
name,
"AspectRatioX")){
633 int aspect_x =
get_value(
s->pb, value_type, 16);
635 asf->
dar[stream_num].
num = aspect_x;
636 }
else if(!strcmp(
name,
"AspectRatioY")){
637 int aspect_y =
get_value(
s->pb, value_type, 16);
639 asf->
dar[stream_num].
den = aspect_y;
653 int i, count, name_len,
ret;
663 for (
i = 0;
i < count;
i++) {
677 if ((
unsigned)name_len > INT_MAX / 2)
680 sizeof(
name))) < name_len)
706 for (
i = 0;
i<128;
i++)
719 if (!(asf->
hdr.
flags & 0x01) && gsize >= 100)
761 "DRM protected stream detected, decoding will likely fail!\n");
771 if (
len > UINT16_MAX)
776 if (
len > UINT16_MAX)
781 if (
len > UINT16_MAX)
786 "Ext DRM protected stream detected, decoding will likely fail!\n");
787 av_dict_set(&
s->metadata,
"encryption",
"ASF Extended Content Encryption", 0);
798 "gpos mismatch our pos=%"PRIu64
", end=%"PRId64
"\n",
811 for (
i = 0;
i < 128;
i++) {
813 if (stream_num >= 0) {
821 }
else if ((asf->
dar[0].
num > 0) && (asf->
dar[0].
den > 0) &&
835 if (rfc1766 && strlen(rfc1766) > 1) {
836 const char primary_tag[3] = { rfc1766[0], rfc1766[1],
'\0' };
851 #define DO_2BITS(bits, var, defval) \
852 switch (bits & 3) { \
854 var = avio_rl32(pb); \
858 var = avio_rl16(pb); \
879 uint32_t packet_length, padsize;
896 if (
c == 0x82 && !
d && !e)
909 "ff asf bad header %x at:%"PRId64
"\n",
c,
avio_tell(pb));
911 if ((
c & 0x8f) == 0x82) {
954 if (!packet_length || packet_length >= (1
U << 29)) {
956 "invalid packet_length %"PRIu32
" at:%"PRId64
"\n",
960 if (padsize >= packet_length) {
962 "invalid padsize %"PRIu32
" at:%"PRId64
"\n", padsize,
avio_tell(pb));
978 if (rsize > packet_length - padsize) {
981 "invalid packet header length %d for pktlen %"PRIu32
"-%"PRIu32
" at %"PRId64
"\n",
982 rsize, packet_length, padsize,
avio_tell(pb));
986 if (packet_length < asf->hdr.min_pktsize)
1010 asfst = &asf->
streams[num & 0x7f];
1015 av_log(asf,
AV_LOG_TRACE,
"key:%d stream:%d seq:%d offset:%d replic_size:%d num:%X packet_property %X\n",
1052 s->streams[asf->
stream_index]->sample_aspect_ratio = aspect;
1179 "stream:%d, expected:%d but got %d from pkt)\n",
1210 "freeing incomplete packet size %d, new %d\n",
1238 av_log(asf,
AV_LOG_TRACE,
"new packet: stream:%d key:%d packet_key:%d audio:%d size:%d\n",
1260 "packet fragment position invalid %u,%u not in %u\n",
1274 if (ret < 0 || asf->packet_frag_offset +
ret == 0)
1289 if (
s->key &&
s->keylen == 20)
1313 "pkt.size != ds_packet_size * ds_span (%d %d %d)\n",
1321 uint8_t *newdata = buf->
data;
1323 memset(newdata + asf_st->
pkt.
size, 0,
1325 while (offset < asf_st->
pkt.
size) {
1327 int row = off / asf_st->
ds_span;
1328 int col = off % asf_st->
ds_span;
1399 for (
i = 0;
i < 128;
i++) {
1414 for (
i = 0;
i < 128;
i++) {
1432 int64_t *ppos, int64_t pos_limit)
1439 int64_t
pos = *ppos;
1443 for (
i = 0;
i <
s->nb_streams;
i++)
1446 if (
s->packet_size > 0)
1448 s->packet_size *
s->packet_size +
1467 asf_st = &asf->
streams[
s->streams[
i]->id];
1516 int64_t itime, last_pos = -1;
1526 "itime:0x%"PRIx64
", pct:%d, ict:%d\n", itime, pct, ict);
1528 for (
i = 0;
i < ict;
i++) {
1539 if (
pos != last_pos) {
1541 pktnum, pktct, index_pts);
1561 AVStream *st =
s->streams[stream_index];
1565 if (
s->packet_size <= 0)
const ff_asf_guid ff_asf_ext_stream_embed_stream_header
static const AVClass asf_class
const ff_asf_guid ff_asf_jfif_media
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
#define AV_LOG_WARNING
Something somehow does not look correct.
uint8_t * extradata
Extra binary data needed for initializing the decoder, codec-dependent.
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option name
const AVInputFormat ff_asf_demuxer
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
int ff_get_guid(AVIOContext *s, ff_asf_guid *g)
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
enum AVMediaType codec_type
General type of the encoded data.
uint64_t send_time
time to send file, in 100-nanosecond units invalid if broadcasting (could be ignored)
#define AVERROR_EOF
End of file.
uint8_t * data
The data buffer.
static int asf_read_content_desc(AVFormatContext *s, int64_t size)
static void skip_to_key(AVFormatContext *s)
static int asf_parse_packet(AVFormatContext *s, AVIOContext *pb, AVPacket *pkt)
Parse data from individual ASF packets (which were previously loaded with asf_get_packet()).
uint32_t preroll
timestamp of the first packet, in milliseconds if nonzero - subtract from time
@ AV_PKT_DATA_PALETTE
An AV_PKT_DATA_PALETTE side data packet contains exactly AVPALETTE_SIZE bytes worth of palette.
static int asf_build_simple_index(AVFormatContext *s, int stream_index)
int error
contains the error code or 0 if no error happened
const ff_asf_guid ff_asf_video_stream
const ff_asf_guid ff_asf_simple_index_header
#define AV_LOG_VERBOSE
Detailed information.
uint32_t codec_tag
Additional information about the codec (corresponds to the AVI FOURCC).
int av_read_frame(AVFormatContext *s, AVPacket *pkt)
Return the next frame of a stream.
const ff_asf_guid ff_asf_stream_header
const ff_asf_guid ff_asf_codec_comment_header
uint64_t data_offset
beginning of the first data packet
int64_t avio_size(AVIOContext *s)
Get the filesize.
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
static int asf_get_packet(AVFormatContext *s, AVIOContext *pb)
Load a single ASF packet into the demuxer.
static av_always_inline int ff_guidcmp(const void *g1, const void *g2)
unsigned int packet_frag_size
uint32_t flags
0x01 - broadcast 0x02 - seekable rest is reserved should be 0
uint32_t stream_bitrates[128]
max number of streams, bitrate for each (for streaming)
ASFStream streams[128]
it's max number and it's not that big
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.
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
void av_shrink_packet(AVPacket *pkt, int size)
Reduce packet size, correctly zeroing padding.
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.
uint64_t data_object_size
size of the data object
static av_cold int read_close(AVFormatContext *ctx)
static av_always_inline int64_t avio_tell(AVIOContext *s)
ftell() equivalent for AVIOContext.
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf type
static int asf_read_ext_content_desc(AVFormatContext *s, int64_t size)
int64_t duration
Decoding: duration of the stream, in stream time base.
int av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
unsigned int avio_rl16(AVIOContext *s)
uint64_t create_time
time of creation, in 100-nanosecond units since 1.1.1601 invalid if broadcasting
static int asf_read_stream_properties(AVFormatContext *s, int64_t size)
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static int get_value(AVIOContext *pb, int type, int type2_size)
#define FF_ARRAY_ELEMS(a)
static int asf_read_close(AVFormatContext *s)
ASFStream * asf_st
currently decoded stream
int avio_get_str16le(AVIOContext *pb, int maxlen, char *buf, int buflen)
Read a UTF-16 string from pb and convert it to UTF-8.
int64_t packet_frag_timestamp
static int asf_read_seek(AVFormatContext *s, int stream_index, int64_t pts, int flags)
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values.
const ff_asf_guid ff_asf_data_header
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
#define DO_2BITS(bits, var, defval)
static int asf_read_marker(AVFormatContext *s, int64_t size)
#define av_assert0(cond)
assert() equivalent, that is always enabled.
static int asf_probe(const AVProbeData *pd)
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
unsigned int packet_frag_offset
int64_t data_offset
offset of the first packet
static int asf_read_packet(AVFormatContext *s, AVPacket *pkt)
@ AVMEDIA_TYPE_DATA
Opaque data information usually continuous.
static int64_t fsize(FILE *f)
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
enum AVStreamParseType need_parsing
@ AVDISCARD_ALL
discard all
AVBufferRef * buf
A reference to the reference-counted buffer where the packet data is stored.
AVCodecParameters * codecpar
Codec parameters associated with this stream.
#define LIBAVUTIL_VERSION_INT
static int read_header(FFV1Context *f)
Describe the class of an AVClass context structure.
ff_asf_guid guid
generated by client computer
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it.
const ff_asf_guid ff_asf_header
const AVMetadataConv ff_asf_metadata_conv[]
Rational number (pair of numerator and denominator).
const char * av_default_item_name(void *ptr)
Return the context name.
uint32_t ignore
preroll is 64 bits - but let's just ignore it
This structure contains the data a format has to probe a file.
char stream_languages[128][6]
max number of streams, language for each (RFC1766, e.g. en-US)
uint64_t play_time
play time, in 100-nanosecond units invalid if broadcasting
const ff_asf_guid ff_asf_head1_guid
const ff_asf_guid ff_asf_digital_signature
int ff_asf_handle_byte_array(AVFormatContext *s, const char *name, int val_len)
Handles both attached pictures as well as id3 tags.
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
int extradata_size
Size of the extradata content in bytes.
static const AVOption options[]
unsigned int avio_rl32(AVIOContext *s)
@ AVDISCARD_NONKEY
discard all frames except keyframes
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
AVPacket * parse_pkt
The generic code uses this as a temporary packet to parse packets or for muxing, especially flushing.
const char * ff_convert_lang_to(const char *lang, enum AVLangCodespace target_codespace)
Convert a language code to a target codespace.
static int64_t start_time
static int asf_read_metadata(AVFormatContext *s, int64_t size)
#define AV_NOPTS_VALUE
Undefined timestamp value.
uint32_t min_pktsize
size of a data packet invalid if broadcasting
uint32_t max_pktsize
shall be the same as for min_pktsize invalid if broadcasting
#define FRAME_HEADER_SIZE
@ AVMEDIA_TYPE_UNKNOWN
Usually treated as AVMEDIA_TYPE_DATA.
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
int avio_r8(AVIOContext *s)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
int flags
A combination of AV_PKT_FLAG values.
uint64_t data_object_offset
data object offset (excl. GUID & size)
AVBufferRef * av_buffer_alloc(size_t size)
Allocate an AVBuffer of the given size using av_malloc().
#define AV_LOG_INFO
Standard information.
const ff_asf_guid ff_asf_command_stream
int ffio_limit(AVIOContext *s, int size)
const ff_asf_guid ff_asf_content_encryption
#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...
uint16_t stream_language_index
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
const ff_asf_guid ff_asf_ext_stream_header
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default value
#define AV_OPT_FLAG_DECODING_PARAM
a generic parameter which can be set by the user for demuxing or decoding
static int64_t asf_read_pts(AVFormatContext *s, int stream_index, int64_t *ppos, int64_t pos_limit)
static int asf_read_frame_header(AVFormatContext *s, AVIOContext *pb)
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
int ff_get_wav_header(AVFormatContext *s, AVIOContext *pb, AVCodecParameters *par, int size, int big_endian)
int64_t av_rescale(int64_t a, int64_t b, int64_t c)
Rescale a 64-bit integer with rounding to nearest.
const ff_asf_guid ff_asf_extended_content_header
int id
Format-specific stream ID.
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
int64_t avio_seek(AVIOContext *s, int64_t offset, int whence)
fseek() equivalent for AVIOContext.
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 av_hex_dump_log(void *avcl, int level, const uint8_t *buf, int size)
Send a nice hexadecimal dump of a buffer to the log.
const ff_asf_guid ff_asf_audio_stream
const ff_asf_guid ff_asf_metadata_library_header
uint64_t file_size
in bytes invalid if broadcasting
static int asf_read_file_properties(AVFormatContext *s, int64_t size)
AVPacketSideData * side_data
Additional packet data that can be provided by the container.
#define AV_INPUT_BUFFER_PADDING_SIZE
int asfid2avid[128]
conversion table from asf ID 2 AVStream ID
const AVCodecTag ff_codec_bmp_tags[]
const ff_asf_guid ff_asf_comment_header
uint8_t * av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type, size_t size)
Allocate new information of a packet.
static int asf_read_language_list(AVFormatContext *s, int64_t size)
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
const ff_asf_guid ff_asf_language_guid
const ff_asf_guid ff_asf_ext_content_encryption
static void asf_reset_header(AVFormatContext *s)
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
const ff_asf_guid ff_asf_file_header
AVIndexEntry * index_entries
Only used if the format does not support seeking natively.
const ff_asf_guid ff_asf_metadata_header
int bits_per_coded_sample
The number of bits per sample in the codedwords.
const ff_asf_guid ff_asf_head2_guid
A reference to a data buffer.
uint32_t max_bitrate
bandwidth of stream in bps should be the sum of bitrates of the individual media streams
#define avpriv_request_sample(...)
static void get_tag(AVFormatContext *s, const char *key, int type, int len, int type2_size)
int request_probe
stream probing state -1 -> probing finished 0 -> no probing requested rest -> perform probing with re...
static av_always_inline int diff(const uint32_t a, const uint32_t b)
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
This structure stores compressed data.
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
int64_t pos
byte position in stream, -1 if unknown
uint64_t avio_rl64(AVIOContext *s)
const ff_asf_guid ff_asf_my_guid
#define flags(name, subs,...)
const ff_asf_guid ff_asf_marker_header
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.
int64_t bit_rate
The average bitrate of the encoded data (in bits per second).
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
#define MKTAG(a, b, c, d)
static int64_t read_timestamp(AVFormatContext *s, int stream_index, int64_t *ppos, int64_t pos_limit, int64_t(*read_timestamp)(struct AVFormatContext *, int, int64_t *, int64_t))
static int asf_read_ext_stream_properties(AVFormatContext *s, int64_t size)
const ff_asf_guid ff_asf_video_conceal_none
@ AV_CODEC_ID_MPEG2VIDEO
preferred ID for MPEG-1/2 video decoding
void ff_asfcrypt_dec(const uint8_t key[20], uint8_t *data, int len)
const ff_asf_guid ff_asf_codec_comment1_header
static int asf_read_header(AVFormatContext *s)
const ff_asf_guid ff_asf_ext_stream_audio_stream
int av_index_search_timestamp(AVStream *st, int64_t timestamp, int flags)
Get the index for a specific timestamp.
int avio_feof(AVIOContext *s)
Similar to feof() but also returns nonzero on read errors.