Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
99f80c17
Commit
99f80c17
authored
Mar 16, 2008
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Handle all memory errors in MP4 esds
parent
7061a05d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
13 deletions
+27
-13
modules/demux/mp4/libmp4.c
modules/demux/mp4/libmp4.c
+27
-13
No files found.
modules/demux/mp4/libmp4.c
View file @
99f80c17
...
@@ -885,12 +885,24 @@ static int MP4_ReadLengthDescriptor( uint8_t **pp_peek, int64_t *i_read )
...
@@ -885,12 +885,24 @@ static int MP4_ReadLengthDescriptor( uint8_t **pp_peek, int64_t *i_read )
return
(
i_len
);
return
(
i_len
);
}
}
static
void
MP4_FreeBox_esds
(
MP4_Box_t
*
p_box
)
{
FREENULL
(
p_box
->
data
.
p_esds
->
es_descriptor
.
psz_URL
);
if
(
p_box
->
data
.
p_esds
->
es_descriptor
.
p_decConfigDescr
)
{
FREENULL
(
p_box
->
data
.
p_esds
->
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
);
FREENULL
(
p_box
->
data
.
p_esds
->
es_descriptor
.
p_decConfigDescr
);
}
}
static
int
MP4_ReadBox_esds
(
stream_t
*
p_stream
,
MP4_Box_t
*
p_box
)
static
int
MP4_ReadBox_esds
(
stream_t
*
p_stream
,
MP4_Box_t
*
p_box
)
{
{
#define es_descriptor p_box->data.p_esds->es_descriptor
#define es_descriptor p_box->data.p_esds->es_descriptor
unsigned
int
i_len
;
unsigned
int
i_len
;
unsigned
int
i_flags
;
unsigned
int
i_flags
;
unsigned
int
i_type
;
unsigned
int
i_type
;
unsigned
int
code
=
0
;
MP4_READBOX_ENTER
(
MP4_Box_data_esds_t
);
MP4_READBOX_ENTER
(
MP4_Box_data_esds_t
);
...
@@ -958,6 +970,11 @@ static int MP4_ReadBox_esds( stream_t *p_stream, MP4_Box_t *p_box )
...
@@ -958,6 +970,11 @@ static int MP4_ReadBox_esds( stream_t *p_stream, MP4_Box_t *p_box )
es_descriptor
.
p_decConfigDescr
=
es_descriptor
.
p_decConfigDescr
=
malloc
(
sizeof
(
MP4_descriptor_decoder_config_t
));
malloc
(
sizeof
(
MP4_descriptor_decoder_config_t
));
if
(
es_descriptor
.
p_decConfigDescr
==
NULL
)
{
free
(
es_descriptor
.
psz_URL
);
goto
error
;
}
MP4_GET1BYTE
(
es_descriptor
.
p_decConfigDescr
->
i_objectTypeIndication
);
MP4_GET1BYTE
(
es_descriptor
.
p_decConfigDescr
->
i_objectTypeIndication
);
MP4_GET1BYTE
(
i_flags
);
MP4_GET1BYTE
(
i_flags
);
...
@@ -983,24 +1000,21 @@ static int MP4_ReadBox_esds( stream_t *p_stream, MP4_Box_t *p_box )
...
@@ -983,24 +1000,21 @@ static int MP4_ReadBox_esds( stream_t *p_stream, MP4_Box_t *p_box )
es_descriptor
.
p_decConfigDescr
->
i_decoder_specific_info_len
=
i_len
;
es_descriptor
.
p_decConfigDescr
->
i_decoder_specific_info_len
=
i_len
;
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
=
malloc
(
i_len
);
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
=
malloc
(
i_len
);
if
(
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
)
if
(
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
==
NULL
)
memcpy
(
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
,
{
p_peek
,
i_len
);
MP4_FreeBox_esds
(
p_box
);
goto
error
;
}
memcpy
(
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
,
p_peek
,
i_len
);
code
=
1
;
MP4_READBOX_EXIT
(
1
);
error:
MP4_READBOX_EXIT
(
code
);
#undef es_descriptor
#undef es_descriptor
}
}
static
void
MP4_FreeBox_esds
(
MP4_Box_t
*
p_box
)
{
FREENULL
(
p_box
->
data
.
p_esds
->
es_descriptor
.
psz_URL
);
if
(
p_box
->
data
.
p_esds
->
es_descriptor
.
p_decConfigDescr
)
{
FREENULL
(
p_box
->
data
.
p_esds
->
es_descriptor
.
p_decConfigDescr
->
p_decoder_specific_info
);
}
FREENULL
(
p_box
->
data
.
p_esds
->
es_descriptor
.
p_decConfigDescr
);
}
static
int
MP4_ReadBox_avcC
(
stream_t
*
p_stream
,
MP4_Box_t
*
p_box
)
static
int
MP4_ReadBox_avcC
(
stream_t
*
p_stream
,
MP4_Box_t
*
p_box
)
{
{
...
...
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