ID3v2ExtraMeta *id3v2_extra_meta = NULL;
ff_id3v2_read(s, ID3v2_DEFAULT_MAGIC, &id3v2_extra_meta, len);
- if (id3v2_extra_meta)
+ if (id3v2_extra_meta) {
ff_id3v2_parse_apic(s, &id3v2_extra_meta);
+ ff_id3v2_parse_chapters(s, &id3v2_extra_meta);
+ }
ff_id3v2_free_extra_meta(&id3v2_extra_meta);
}
static int parse_video_info(AVIOContext *pb, AVStream *st)
{
- uint16_t size;
+ uint16_t size_asf; // ASF-specific Format Data size
+ uint32_t size_bmp; // BMP_HEADER-specific Format Data size
unsigned int tag;
st->codecpar->width = avio_rl32(pb);
st->codecpar->height = avio_rl32(pb);
avio_skip(pb, 1); // skip reserved flags
- size = avio_rl16(pb); // size of the Format Data
- tag = ff_get_bmp_header(pb, st, NULL);
+ size_asf = avio_rl16(pb);
+ tag = ff_get_bmp_header(pb, st, &size_bmp);
st->codecpar->codec_tag = tag;
st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, tag);
+ size_bmp = FFMAX(size_asf, size_bmp);
- if (size > BMP_HEADER_SIZE) {
+ if (size_bmp > BMP_HEADER_SIZE) {
int ret;
- st->codecpar->extradata_size = size - BMP_HEADER_SIZE;
+ st->codecpar->extradata_size = size_bmp - BMP_HEADER_SIZE;
if (!(st->codecpar->extradata = av_malloc(st->codecpar->extradata_size +
AV_INPUT_BUFFER_PADDING_SIZE))) {
st->codecpar->extradata_size = 0;
uint64_t interval; // index entry time interval in 100 ns units, usually it's 1s
uint32_t pkt_num, nb_entries;
int32_t prev_pkt_num = -1;
- int i, ret;
+ int i;
+ int64_t offset;
uint64_t size = avio_rl64(pb);
// simple index objects should be ordered by stream number, this loop tries to find
nb_entries = avio_rl32(pb);
for (i = 0; i < nb_entries; i++) {
pkt_num = avio_rl32(pb);
- ret = avio_skip(pb, 2);
- if (ret < 0) {
+ offset = avio_skip(pb, 2);
+ if (offset < 0) {
av_log(s, AV_LOG_ERROR, "Skipping failed in asf_read_simple_index.\n");
- return ret;
+ return offset;
}
if (prev_pkt_num != pkt_num) {
av_add_index_entry(st, asf->first_packet_offset + asf->packet_size *