Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
7d843100
Commit
7d843100
authored
Sep 17, 2012
by
Luca Barbato
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
matroskadec: properly support BlockDuration
parent
c831ebf6
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
5 deletions
+17
-5
matroskadec.c
libavformat/matroskadec.c
+17
-5
No files found.
libavformat/matroskadec.c
View file @
7d843100
...
@@ -1992,7 +1992,7 @@ static int matroska_parse_frame(MatroskaDemuxContext *matroska,
...
@@ -1992,7 +1992,7 @@ static int matroska_parse_frame(MatroskaDemuxContext *matroska,
static
int
matroska_parse_block
(
MatroskaDemuxContext
*
matroska
,
uint8_t
*
data
,
static
int
matroska_parse_block
(
MatroskaDemuxContext
*
matroska
,
uint8_t
*
data
,
int
size
,
int64_t
pos
,
uint64_t
cluster_time
,
int
size
,
int64_t
pos
,
uint64_t
cluster_time
,
uint64_t
duration
,
int
is_keyframe
,
uint64_t
block_
duration
,
int
is_keyframe
,
int64_t
cluster_pos
)
int64_t
cluster_pos
)
{
{
uint64_t
timecode
=
AV_NOPTS_VALUE
;
uint64_t
timecode
=
AV_NOPTS_VALUE
;
...
@@ -2002,7 +2002,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
...
@@ -2002,7 +2002,7 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
int16_t
block_time
;
int16_t
block_time
;
uint32_t
*
lace_size
=
NULL
;
uint32_t
*
lace_size
=
NULL
;
int
n
,
flags
,
laces
=
0
;
int
n
,
flags
,
laces
=
0
;
uint64_t
num
;
uint64_t
num
,
duration
;
if
((
n
=
matroska_ebmlnum_uint
(
matroska
,
data
,
size
,
&
num
))
<
0
)
{
if
((
n
=
matroska_ebmlnum_uint
(
matroska
,
data
,
size
,
&
num
))
<
0
)
{
av_log
(
matroska
->
ctx
,
AV_LOG_ERROR
,
"EBML block data error
\n
"
);
av_log
(
matroska
->
ctx
,
AV_LOG_ERROR
,
"EBML block data error
\n
"
);
...
@@ -2021,8 +2021,6 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
...
@@ -2021,8 +2021,6 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
st
=
track
->
stream
;
st
=
track
->
stream
;
if
(
st
->
discard
>=
AVDISCARD_ALL
)
if
(
st
->
discard
>=
AVDISCARD_ALL
)
return
res
;
return
res
;
if
(
duration
==
AV_NOPTS_VALUE
)
duration
=
track
->
default_duration
/
matroska
->
time_scale
;
block_time
=
AV_RB16
(
data
);
block_time
=
AV_RB16
(
data
);
data
+=
2
;
data
+=
2
;
...
@@ -2039,7 +2037,6 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
...
@@ -2039,7 +2037,6 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
is_keyframe
=
0
;
/* overlapping subtitles are not key frame */
is_keyframe
=
0
;
/* overlapping subtitles are not key frame */
if
(
is_keyframe
)
if
(
is_keyframe
)
av_add_index_entry
(
st
,
cluster_pos
,
timecode
,
0
,
0
,
AVINDEX_KEYFRAME
);
av_add_index_entry
(
st
,
cluster_pos
,
timecode
,
0
,
0
,
AVINDEX_KEYFRAME
);
track
->
end_timecode
=
FFMAX
(
track
->
end_timecode
,
timecode
+
duration
);
}
}
if
(
matroska
->
skip_to_keyframe
&&
track
->
type
!=
MATROSKA_TRACK_TYPE_SUBTITLE
)
{
if
(
matroska
->
skip_to_keyframe
&&
track
->
type
!=
MATROSKA_TRACK_TYPE_SUBTITLE
)
{
...
@@ -2054,6 +2051,21 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
...
@@ -2054,6 +2051,21 @@ static int matroska_parse_block(MatroskaDemuxContext *matroska, uint8_t *data,
if
(
res
)
if
(
res
)
goto
end
;
goto
end
;
if
(
block_duration
!=
AV_NOPTS_VALUE
)
{
duration
=
block_duration
/
laces
;
if
(
block_duration
!=
duration
*
laces
)
{
av_log
(
matroska
->
ctx
,
AV_LOG_WARNING
,
"Incorrect block_duration, possibly corrupted container"
);
}
}
else
{
duration
=
track
->
default_duration
/
matroska
->
time_scale
;
block_duration
=
duration
*
laces
;
}
if
(
timecode
!=
AV_NOPTS_VALUE
)
track
->
end_timecode
=
FFMAX
(
track
->
end_timecode
,
timecode
+
block_duration
);
for
(
n
=
0
;
n
<
laces
;
n
++
)
{
for
(
n
=
0
;
n
<
laces
;
n
++
)
{
if
((
st
->
codec
->
codec_id
==
AV_CODEC_ID_RA_288
||
if
((
st
->
codec
->
codec_id
==
AV_CODEC_ID_RA_288
||
st
->
codec
->
codec_id
==
AV_CODEC_ID_COOK
||
st
->
codec
->
codec_id
==
AV_CODEC_ID_COOK
||
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment