|
|
|
@ -836,7 +836,7 @@ static int get_stream_idx(int *d){ |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
static int avi_sync(AVFormatContext *s) |
|
|
|
|
static int avi_sync(AVFormatContext *s, int exit_early) |
|
|
|
|
{ |
|
|
|
|
AVIContext *avi = s->priv_data; |
|
|
|
|
AVIOContext *pb = s->pb; |
|
|
|
@ -916,7 +916,9 @@ start_sync: |
|
|
|
|
if( (st->discard >= AVDISCARD_DEFAULT && size==0) |
|
|
|
|
/*|| (st->discard >= AVDISCARD_NONKEY && !(pkt->flags & AV_PKT_FLAG_KEY))*/ //FIXME needs a little reordering
|
|
|
|
|
|| st->discard >= AVDISCARD_ALL){ |
|
|
|
|
if (!exit_early) { |
|
|
|
|
ast->frame_offset += get_duration(ast, size); |
|
|
|
|
} |
|
|
|
|
avio_skip(pb, size); |
|
|
|
|
goto start_sync; |
|
|
|
|
} |
|
|
|
@ -936,6 +938,8 @@ start_sync: |
|
|
|
|
(d[2] == 'd' && d[3] == 'c') || |
|
|
|
|
(d[2] == 'w' && d[3] == 'b')*/) { |
|
|
|
|
|
|
|
|
|
if (exit_early) |
|
|
|
|
return 0; |
|
|
|
|
//av_log(s, AV_LOG_DEBUG, "OK\n");
|
|
|
|
|
if(d[2]*256+d[3] == ast->prefix) |
|
|
|
|
ast->prefix_count++; |
|
|
|
@ -1117,7 +1121,7 @@ resync: |
|
|
|
|
return size; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if ((err = avi_sync(s)) < 0) |
|
|
|
|
if ((err = avi_sync(s, 0)) < 0) |
|
|
|
|
return err; |
|
|
|
|
goto resync; |
|
|
|
|
} |
|
|
|
@ -1131,13 +1135,22 @@ static int avi_read_idx1(AVFormatContext *s, int size) |
|
|
|
|
int nb_index_entries, i; |
|
|
|
|
AVStream *st; |
|
|
|
|
AVIStream *ast; |
|
|
|
|
unsigned int index, tag, flags, pos, len; |
|
|
|
|
unsigned int index, tag, flags, pos, len, first_packet = 1; |
|
|
|
|
unsigned last_pos= -1; |
|
|
|
|
int64_t idx1_pos, first_packet_pos = 0, data_offset = 0; |
|
|
|
|
|
|
|
|
|
nb_index_entries = size / 16; |
|
|
|
|
if (nb_index_entries <= 0) |
|
|
|
|
return -1; |
|
|
|
|
|
|
|
|
|
idx1_pos = avio_tell(pb); |
|
|
|
|
avio_seek(pb, avi->movi_list+4, SEEK_SET); |
|
|
|
|
if (avi_sync(s, 1) == 0) { |
|
|
|
|
first_packet_pos = avio_tell(pb) - 8; |
|
|
|
|
} |
|
|
|
|
avi->stream_index = -1; |
|
|
|
|
avio_seek(pb, idx1_pos, SEEK_SET); |
|
|
|
|
|
|
|
|
|
/* Read the entries and sort them in each stream component. */ |
|
|
|
|
for(i = 0; i < nb_index_entries; i++) { |
|
|
|
|
tag = avio_rl32(pb); |
|
|
|
@ -1146,9 +1159,6 @@ static int avi_read_idx1(AVFormatContext *s, int size) |
|
|
|
|
len = avio_rl32(pb); |
|
|
|
|
av_dlog(s, "%d: tag=0x%x flags=0x%x pos=0x%x len=%d/", |
|
|
|
|
i, tag, flags, pos, len); |
|
|
|
|
if(i==0 && pos > avi->movi_list) |
|
|
|
|
avi->movi_list= 0; //FIXME better check
|
|
|
|
|
pos += avi->movi_list; |
|
|
|
|
|
|
|
|
|
index = ((tag & 0xff) - '0') * 10; |
|
|
|
|
index += ((tag >> 8) & 0xff) - '0'; |
|
|
|
@ -1157,6 +1167,12 @@ static int avi_read_idx1(AVFormatContext *s, int size) |
|
|
|
|
st = s->streams[index]; |
|
|
|
|
ast = st->priv_data; |
|
|
|
|
|
|
|
|
|
if(first_packet && first_packet_pos && len) { |
|
|
|
|
data_offset = first_packet_pos - pos; |
|
|
|
|
first_packet = 0; |
|
|
|
|
} |
|
|
|
|
pos += data_offset; |
|
|
|
|
|
|
|
|
|
av_dlog(s, "%d cum_len=%"PRId64"\n", len, ast->cum_len); |
|
|
|
|
|
|
|
|
|
if(pb->eof_reached) |
|
|
|
|