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
3a895533
Commit
3a895533
authored
Sep 14, 2012
by
Clément Bœsch
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
lavf/oggdec: rework allocations in ogg_new_streams().
parent
edca8038
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
12 additions
and
4 deletions
+12
-4
oggdec.c
libavformat/oggdec.c
+12
-4
No files found.
libavformat/oggdec.c
View file @
3a895533
...
@@ -165,28 +165,36 @@ static int ogg_new_stream(AVFormatContext *s, uint32_t serial, int new_avstream)
...
@@ -165,28 +165,36 @@ static int ogg_new_stream(AVFormatContext *s, uint32_t serial, int new_avstream)
{
{
struct
ogg
*
ogg
=
s
->
priv_data
;
struct
ogg
*
ogg
=
s
->
priv_data
;
int
idx
=
ogg
->
nstreams
++
;
int
idx
=
ogg
->
nstreams
;
AVStream
*
st
;
AVStream
*
st
;
struct
ogg_stream
*
os
;
struct
ogg_stream
*
os
;
size_t
size
;
ogg
->
streams
=
av_realloc
(
ogg
->
streams
,
if
(
av_size_mult
(
ogg
->
nstreams
+
1
,
sizeof
(
*
ogg
->
streams
),
&
size
)
<
0
||
ogg
->
nstreams
*
sizeof
(
*
ogg
->
streams
));
!
(
os
=
av_realloc
(
ogg
->
streams
,
size
)))
return
AVERROR
(
ENOMEM
);
ogg
->
streams
=
os
;
memset
(
ogg
->
streams
+
idx
,
0
,
sizeof
(
*
ogg
->
streams
));
memset
(
ogg
->
streams
+
idx
,
0
,
sizeof
(
*
ogg
->
streams
));
os
=
ogg
->
streams
+
idx
;
os
=
ogg
->
streams
+
idx
;
os
->
serial
=
serial
;
os
->
serial
=
serial
;
os
->
bufsize
=
DECODER_BUFFER_SIZE
;
os
->
bufsize
=
DECODER_BUFFER_SIZE
;
os
->
buf
=
av_malloc
(
os
->
bufsize
+
FF_INPUT_BUFFER_PADDING_SIZE
);
os
->
buf
=
av_malloc
(
os
->
bufsize
+
FF_INPUT_BUFFER_PADDING_SIZE
);
os
->
header
=
-
1
;
os
->
header
=
-
1
;
if
(
!
os
->
buf
)
return
AVERROR
(
ENOMEM
);
if
(
new_avstream
)
{
if
(
new_avstream
)
{
st
=
avformat_new_stream
(
s
,
NULL
);
st
=
avformat_new_stream
(
s
,
NULL
);
if
(
!
st
)
if
(
!
st
)
{
av_freep
(
&
os
->
buf
);
return
AVERROR
(
ENOMEM
);
return
AVERROR
(
ENOMEM
);
}
st
->
id
=
idx
;
st
->
id
=
idx
;
avpriv_set_pts_info
(
st
,
64
,
1
,
1000000
);
avpriv_set_pts_info
(
st
,
64
,
1
,
1000000
);
}
}
ogg
->
nstreams
++
;
return
idx
;
return
idx
;
}
}
...
...
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